热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ios自动加了html,移动端HybridiOS添加快捷方式到主屏幕_html/css_WEBITnose

关于Hybrid研发模式,这里就不多说了,是目前移动端主流的研发模式。当我们的APP内部集成有很多Web实现的功能时,甚至某些Web实现的

关于Hybrid研发模式,这里就不多说了,是目前移动端主流的研发模式。当我们的APP内部集成有很多Web实现的功能时,甚至某些Web实现的模块作为一部分独立的功能,打开的频率很高,这个时候,可以将对应的功能页面以快捷方式添加到桌面上。如果Web功能与APP相对独立,可以通过此快捷方式直接代开Safari,用户可以在Safari中完成想要的操作。另一方面如果Web功能的实现与APP高度耦合,或者出于增加APP的用户粘性角度,可以通过点击此快捷方式唤醒我们的APP并跳转到我们自己APP中的相应模块。

addBaiduToDesktop.gif

基本实现思想

利用Safari自带的添加到主屏幕功能,有两种实现方案, 实现方案一: 调用Safari访问外部页面,将外部页面作为快捷页面添加到桌面。优点:实现简单,工作量少,页面灵活可随时更改。缺点:无网状态下,无法生成快捷方式。 实现方案二: 通过应用内部启动httpServer,调用safari访问localhost,同时,在主页通过跳转到新的Data URI页面。优点:不需要服务器,没网也能完成操作。缺点:依赖的类库较多,而且实现较麻烦。

功能封装及技术实现

方案一比较简单,就不再多说了。本文主要针对方案二,其中用到的一些知识包括HTML、cocoaHttpServer、Data URI Scheme等,关于Data URI Scheme相关知识,可以参考我的另一篇文章。前端-Data URI Scheme:http://www.jianshu.com/p/ea49397fcd13 封装方法

针对方案二,对功能进行了封装,仅需调用3行代码,即可实现动态添加快捷方式到桌面。项目地址:https://github.com/dlgenius/DLAddToDesktop

DLAddToDesktopLib.gif

功能封装 用到的一些类库 CocoaHTTPServer

GTMBase64

使用方式:1.工程中导入CocoaHTTPServer、GTMBase64类库2.将Demo中的DLAddToDesktopLib文件夹拷贝到工程中

lib.png

3.在需要添加到主页面的按钮事件中加入如下代码 DLAddToDesktopHandler *handler = [DLAddToDesktopHandler sharedInsance]; NSString *imageString = [[UIImage imageNamed:@"webIcon"] dataURISchemeImage]; [handler addToDesktopWithDataURISchemeImage:imageString title:@"Donglei" urlScheme:@"DLAddToDesktop://"];

4.别忘记设置项目的URL Types

URL Schemes.jpg

下面是一些主要的方法, /** * @brief 创建DLCreateShortcutHandler单例 * * @return DLCreateShortcutHandler单例 */+(DLCreateShortcutHandler *)sharedInsance;/** * @brief 通过Safari添加快捷方式到桌面 * * @param dataURISchemeImage data URI scheme * @param title 快捷方式桌面名称 * @param urlScheme ios APP的URL Scheme * * @return void */- (void)addToDesktopWithDataURISchemeImage:(NSString *)dataURISchemeImage title:(NSString *)title urlScheme:(NSString *)urlScheme; /** * @brief 生成Data URL Scheme 形式的图片字符串 * * @return Data URL Scheme 形式的图片字符串 */- (NSString *)dataURISchemeImage;

技术实现 HTML 相关

苹果Safari本身支持网页添加到主屏幕功能,苹果官方文档参考,https://developer.apple.com/library/safari/documentation/AppleApplications/Reference/SafariWebContent/ConfiguringWebApplications/ConfiguringWebApplications.html

封装的库中,HTML头文件有如下代码 DLCSTitle

其中, apple-mobile-web-app-capable是用来定义应用全屏展示的。

apple-mobile-web-app-status-bar-style,在定义了。apple-mobile-web-app-capable的前提下,设置状态栏的属性值apple-mobile-web-app-status-bar-style才有效。

viewport,width用于指定宽度,initial-scale指定初始化的缩略比例,minimum-scale指定缩小的比例,而maximum-scale则是放大的比例,当然这些缩放都取决于user-scalable——决定用户是否能缩放页面。

rel='apple-touch-icon' href='DLCSImageData',添到主屏幕的图标,有两种属性值apple-touch-icon和apple-touch-icon-precomposed,区别就在于是否会应用iOS中自动给图标添加的那层高光。

另外,HTML中可以加入下面代码对添加到桌面的快捷方式设置启动页,使其更像一个APP,

但我们封装的代码中并没有加入此功能,关于没有实现的原因,其实很简单,由于我们的技术实现方案是首先通过访问本地地址,然后跳到一个Data URI Scheme形式下的HTML页面,而添加到主屏幕的也是这个Data URI Scheme形式下的HTML页面,Data URI 是拼接在地址栏里的,图片数据经过Data URI形式编码处理,会生成一个很长的支付串,启动页图片一般都比较大,又经过了base64编码,加上我们添加到主屏幕的icon也经过了这样的处理,有可能会超出Safari对URL长度的限制,导致无法打开页面的问题,还有主要的原因就是data URI Scheme 移动端的性能很低,不适合内嵌大图。但如果采用方案一,我们是通过访问外部页面来实现添加到主屏幕功能的,可以考虑实现此功能。 CocoaHTTPServer 相关

CocoaHTTPServer封装的很好,用起来也很简单 //config HttpServer _myHTTPServer = [[HTTPServer alloc] init]; [_myHTTPServer setType:@"_http._tcp."]; [_myHTTPServer setPort:port]; //setWebPath NSString *serverWebPath = [self getServerWebPath]; BOOL created = [[NSFileManager defaultManager] createDirectoryAtPath:serverWebPath withIntermediateDirectories:YES attributes:nil error:nil]; if(created){ [_myHTTPServer setDocumentRoot:serverWebPath]; }

通过以上代码我们就建立了一个本地服务器,然后调用start开启本地服务即可, - (void)startServer{ NSError *error; if([_myHTTPServer start:&error]) { DDLogInfo(@"Started HTTP Server on port %hu", [_myHTTPServer listeningPort]); } else { DDLogError(@"Error starting HTTP Server: %@", error); }} 业务逻辑实现相关

这里没有复杂的业务逻辑,主要是读取HTML文档、替换HTML文件中相应字段、存储HTML文档到HTTPServer的WebPath下,再通过Safar打开本地服务。大家可以去阅读我的源码。

项目地址

项目地址:https://github.com/dlgenius/DLAddToDesktop

Thanks

iOS中为网站添加图标到主屏幕以及增加启动画面 http://blog.csdn.net/lgd5979/article/details/7877998...



推荐阅读
  • 【高效构建全面的iOS直播应用】(美颜功能深度解析)
    本文深入探讨了如何高效构建全面的iOS直播应用,特别聚焦于美颜功能的技术实现。通过详细解析美颜算法和优化策略,帮助开发者快速掌握关键技术和实现方法,提升用户体验。适合对直播应用开发感兴趣的开发者阅读。 ... [详细]
  • 浅析python实现布隆过滤器及Redis中的缓存穿透原理_python
    本文带你了解了位图的实现,布隆过滤器的原理及Python中的使用,以及布隆过滤器如何应对Redis中的缓存穿透,相信你对布隆过滤 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • window下的python安装插件,Go语言社区,Golang程序员人脉社 ... [详细]
  • DVWA学习笔记系列:深入理解CSRF攻击机制
    DVWA学习笔记系列:深入理解CSRF攻击机制 ... [详细]
  • CSS3 @font-face 字体应用技术解析与实践
    在Web前端开发中,HTML教程和CSS3的结合使得网页设计更加多样化。长期以来,Web设计师受限于“web-safe”字体的选择。然而,CSS3中的`@font-face`规则允许从服务器端加载自定义字体,极大地丰富了网页的视觉效果。通过这一技术,设计师可以自由选择和使用各种字体,提升用户体验和页面美观度。本文将深入解析`@font-face`的实现原理,并提供实际应用案例,帮助开发者更好地掌握这一强大工具。 ... [详细]
  • 本文深入探讨了 hCalendar 微格式在事件与时间、地点相关活动标记中的应用。作为微格式系列文章的第四篇,前文已分别介绍了 rel 属性用于定义链接关系、XFN 微格式增强链接的人际关系描述以及 hCard 微格式对个人和组织信息的描述。本次将重点解析 hCalendar 如何通过结构化数据标记,提高事件信息的可读性和互操作性。 ... [详细]
  • 在今天的实践中,我深入学习了网页图像抓取技术,通过编写爬虫程序批量获取网站上的图片资源。具体来说,我选择了一个包含大量高质量图片的网站作为练习对象,并成功实现了将这些图片批量下载到本地存储。这一过程不仅提升了我对爬虫技术的理解,还增强了我的编程能力。 ... [详细]
  • 在尝试对从复杂 XSD 生成的类进行序列化时,遇到了 `NullReferenceException` 错误。尽管已经花费了数小时进行调试和搜索相关资料,但仍然无法找到问题的根源。希望社区能够提供一些指导和建议,帮助解决这一难题。 ... [详细]
  • 在前一篇文章中,我们介绍了如何使用Requests库发送GET请求。本文将深入探讨如何通过Requests库发送POST请求,包括参数格式、请求封装等关键技巧,并通过“历史上的今天”API实例进行详细说明。 ... [详细]
  • Java中将Map及其他对象高效转换为JSON格式的方法探讨 ... [详细]
  • 适用于 SSR/WASM 的 ZXing Blazor 扫码组件,高效集成与优化
    本项目基于 ZXing 封装了适用于 SSR 和 WASM 的 Blazor 扫码组件,能够高效地集成到 Blazor 应用中,并支持通过手机或桌面电脑的摄像头进行扫码操作。该组件库不仅简化了开发流程,还提供了高性能的扫码体验。项目地址:[链接] ... [详细]
  • IOC是spring的核心技术之一。在spring中IOC(控制反转)就是由IOC容器来控制程序࿰ ... [详细]
  • IIS启用Gzip的方法与优缺点分析是千自学中一篇关于Discuz论坛的文章简介:现代的浏览器IE6和Firefox都支持客户端Gzip,也就是说,在服务器上的网页,传输之前,先使用Gzip压缩再传输给客户端,客户端接收之后由浏览器解压显示,这样虽然稍微占用了一些服务器和客户端的C ... [详细]
  • 在PHP中实现腾讯云接口签名,以完成人脸核身功能的对接与签名配置时,需要注意将文档中的POST请求改为GET请求。具体步骤包括:使用你的`secretKey`生成签名字符串`$srcStr`,格式为`GET faceid.tencentcloudapi.com?`,确保参数正确拼接,避免因请求方法错误导致的签名问题。此外,还需关注API的其他参数要求,确保请求的完整性和安全性。 ... [详细]
author-avatar
Chen.X.Jie
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有