iOS上创建桌面快捷方式应用场景:
在iOS设备桌面创建app内某一个模块或页面的快捷方式,通过该快捷方式可以直接进入相应模块或页面。目前app内有该功能的有高德一键导 航,360安全卫士的小火箭。技术原理: 在iOS开发中可以使用openUrl的方式打开一个网页,并通过Safari浏览器的发送到主屏幕从而创建一个网页的快捷方式,这篇文章就是利用这个方 法来创建一个app的桌面快捷方式。首先在app内部开启一个轻量级的HttpServer,利用openurl:127.0.0.1 的方式打开本地页面,利用html的重定向将页面指向一个包含创建桌面快捷方式所有信息的,遵守data协议的url,这时利用Safari的发送到主屏 幕,就可以达到我们的要求。
技术难点:
1. 创建一个本地的httpServer。2. 创建本地页面以及data协议url时的编码格式。3. 在Safari未启动时或者app进入后台时,本地httpserver服务启动延迟。
- (id)init { if(self = [super init]){ //启动本地httpSever和服务器首页页面 NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); NSString *documentsPath = paths[0]; self.webRootDir = [documentsPath stringByAppendingPathComponent:@"web"]; BOOL isDirectory = YES; BOOL exsit = [[NSFileManager defaultManager] fileExistsAtPath:_webRootDir isDirectory:&isDirectory]; if(!exsit){ [[NSFileManager defaultManager] createDirectoryAtPath:_webRootDir withIntermediateDirectories:YES attributes:nil error:nil]; } self.mainPage = [NSString stringWithFormat:@"%@/web/index.html",documentsPath]; [DDLog addLogger:[DDTTYLogger sharedInstance]]; _httpServer = [[HTTPServer alloc] init]; [_httpServer setType:@"_http._tcp."]; [_httpServer setDocumentRoot:_webRootDir]; NSError *error; if([_httpServer start:&error]) { DDLogInfo(@"Started HTTP Server on port %hu", [_httpServer listeningPort]); } else { DDLogError(@"Error starting HTTP Server: %@", error); } [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(applicationDidEnterBackground:) name:UIApplicationDidEnterBackgroundNotification object:nil]; [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(applicationWillEnterForeground:) name:UIApplicationWillEnterForegroundNotification object:nil]; } return self; } - (void)applicationDidEnterBackground:(UIApplication *)application { if([[UIDevice currentDevice].systemVersion integerValue] >= 6.0){ sleep(1); }else { sleep(2); } [_httpServer stop]; } - (void)applicationWillEnterForeground:(UIApplication *)application { NSError *error; if(![_httpServer isRunning]){ if([_httpServer start:&error]) { DDLogInfo(@"Started HTTP Server on port %hu", [_httpServer listeningPort]); } else { DDLogError(@"Error starting HTTP Server: %@", error); } } } - (void)createLinkWithDict:(NSDictionary *)dict desktopLinkType:(SyDesktopLinkType)linkType; { NSString *title = [dict objectForKey:deskLinkTitle]; NSString *urlScheme = [dict objectForKey:deskLinkUrlScheme]; NSString *moduleID = [dict objectForKey:deskLinkModuleTag]; NSString *imageName = [dict objectForKey:deskLinkIconName]; NSMutableString *htmlStr = [[NSMutableString alloc] init]; [htmlStr appendString:@"<html><head>"]; [htmlStr appendString:@"<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">"]; NSMutableString *taragerUrl = [NSMutableString stringWithFormat:@"0;url=data:text/html;charset=UTF-8,<html><head><meta content=\"yes\" name=\"apple-mobile-web-app-capable\" /><meta content=\"text/html; charset=UTF-8\" http-equiv=\"Content-Type\" /><meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, user-scalable=no\" /><title>%@</title></head><body bgcolor=\"#ffffff\">",title]; NSString *htmlUrlScheme = [NSString stringWithFormat:@"<a href=\"%@",urlScheme]; NSString *dataUrlStr = nil; if(linkType == SyDesktopLinkType_One){ dataUrlStr = [NSString stringWithFormat:@"%@=%@&%@=%@\" id=\"qbt\" style=\"display: none;\"></a>",deskLinkModuleTag,moduleID,deskLinkType,[NSString stringWithInt:linkType]]; }else if (linkType == SyDesktopLinkType_Two){ //业务生成器功能 }else if(linkType == SyDesktopLinkType_Three){ } UIImage *image = [UIImage imageNamed:imageName]; NSData *imageData = UIImagePNGRepresentation(image); NSString *base6ImageStr = [imageData base64Encoding]; // 转码 // dataUrlStr = [dataUrlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; NSString *imageUrlStr = [NSString stringWithFormat:@"<span id=\"msg\"></span></body><script>if (window.navigator.standalone == true) { var lnk = document.getElementById(\"qbt\"); var evt = document.createEvent('MouseEvent'); evt.initMouseEvent('click'); lnk.dispatchEvent(evt);}else{ var addObj=document.createElement(\"link\"); addObj.setAttribute('rel','apple-touch-icon-precomposed'); addObj.setAttribute('href','data:image/png;base64,%@');",base6ImageStr]; NSString *lastHtmlStr = @"document.getElementsByTagName(\"head\")[0].appendChild(addObj); document.getElementById(\"msg\").innerHTML='<div style=\"font-size:12px;\">点击页面下方的 + 或 <img id=\"i\" src=\"\"> 按钮,在弹出的菜单中选择[添加至主屏幕],即可将选定的功能添加到主屏幕作为快捷方式。</div>';}</script></html>"; [taragerUrl appendString:htmlUrlScheme]; [taragerUrl appendString:dataUrlStr]; NSString *dataUrlEncode = [taragerUrl urlUTF8Encoded]; NSString *imageUrlEncode = [imageUrlStr urlUTF8Encoded]; NSString *lastHtmlStrEncode = [lastHtmlStr urlCFEncoded]; [htmlStr appendFormat:@"<meta http-equiv=\"REFRESH\" content=\"%@%@%@\">",dataUrlEncode,imageUrlEncode,lastHtmlStrEncode]; [htmlStr appendString:@"</head></html>"]; NSData *data = [htmlStr dataUsingEncoding:NSUTF8StringEncoding]; [data writeToFile:_mainPage atomically:YES]; NSString *urlStrWithPort = [NSString stringWithFormat:@"http://127.0.0.1:%d",[_httpServer listeningPort]]; [[UIApplication sharedApplication] openURL:[NSURL URLWithString:urlStrWithPort]]; }