ConfiguringWebApplications

前言

正文

<!-- IOS Safari提供了两个私有接口: apple-touch-icon 和 apple-touch-icon-precomposed。 -->

<link rel="apple-touch-icon-precomposed" href="apple-touch-icon-precomposed-iphone.png" />

1)通过 apple-touch-icon 添加的图标是会带IOS图标统一的高光效果

2) 通过 apple-touch-icon-precomposed 添加的图标则是设计原图,不带高光渐变效果的。


  • apple-mobile-web-app-capable

<meta name="apple-mobile-web-app-capable" content="yes">


通过只读属性window.navigator.standalone来确定网页是否以全屏模式显示


  • apple-mobile-web-app-status-bar-style
<!-- 配合apple-mobile-web-app-capable 使用。 -->

1) 如果content设置为default,则状态栏正常显示。

2) 如果设置为blank,则状态栏会有一个黑色的背景。

3) 如果设置为blank-translucent,则状态栏显示为黑色半透明
  • apple-touch-icon: 图标是在 body.onload 时被渲染的
<!-- 没有指明 <sizes> 属性的大小,则默认值为57x57。 -->

<link rel="apple-touch-icon" sizes="72x72" href="touch-icon-ipad.png" />
<link rel="apple-touch-icon" sizes="114x114" href="touch-icon-iphone-retina.png" />
<link rel="apple-touch-icon" sizes="144x144" href="touch-icon-ipad-retina.png" />

<!-- 如果整个页面都没有指定任何的 apple-touch-icon 的图标的话,IOS则会自动去网站根目录寻找有 apple-touch-icon 和 apple-touch-icon-precomposed 前缀的图标文件。 -->

<!--图片格式  -->

1) HTTP REQUEST

次新的图片都需要请求服务器,从服务器下载

2)绝对路径、相对于当前页面的相对路径以及相对于网站根目录的路径 纯静态的图片

3) base64格式的图片


这是一个包含png文件头的长字符串,它可以是一张从静态图片转换的,也可以是从服务器返回的,还可以是canvas生成的

<img src="data:image/png;base64,(xxxxxx)" </img>

<!-- 更新桌面启动图标 -->
webapp里所有的js逻辑都只有在页面打开状态下才能运行,所以动态修改桌面启动图标的方法只有在每次点开后才能生效

不适合比如天气、新闻、twitter等即时性很高、后台主动推送的场景

<!-- 选择canvas作为动态图片来源 -->

使用base64的优点是,可以选择由canvas来动态生成,并且不需要有网络请求,直接在本地完成。

var canvas = document.createElement('canvas');
canvas.width = 144;
canvas.height = 144;
var context = canvas.getContext("2d");
var baseImg = canvas.toDataURL();  


<!-- 更新桌面图标的方法都应该绑定在 body.onload  -->




<!-- 通过js动态创建和修改指定桌面图标的 <link> 标签 -->

0) 从safari里将页面添加主屏幕时,IOS会检查页面里的 <link> 标签,读取图片的地址然后生成启动图标


  • allintext:iPhone存储web app icon的路径?
/var/mobile/Library/Prefrences

:/var/preferences root# rm -rf *.networkextension*

find / -name "*" | xargs grep "iosre" > ./cqtest.txt

find . -name "*" | xargs grep "iosre" > ./cqtest.txt


devzkndeMacBook-Pro:com.wl..git devzkn$ scp usb2222:/private/var/mobile/Library/Logs/CrashReporter/SpringBoard-2018-03-23-153316.ips ~


<!-- :~ root# find / -amin -1 -->
/private/var/mobile/Containers/Data/Application/316F71CA-00FE-4990-9F79-D4B490844E8F/Library/Preferences/com.apple.webapp.plist
<!-- 5) devzkndeMacBook-Pro:~ devzkn$ plutil -p  com.apple.webapp.plist -->
{
  "WebDatabaseDirectory" => "/var/mobile/Library/WebClips/34FB814D12744D389BC18AC2FB08222C.webclip/Storage"
  "WebKitDiskImageCacheSavedCacheDirectory" => ""
  "WebKitLocalCache" => "/var/mobile/Containers/Data/Application/316F71CA-00FE-4990-9F79-D4B490844E8F/Library/Caches/WebClips/34FB814D12744D389BC18AC2FB08222C"
  "WebKitLocalStorageDatabasePathPreferenceKey" => "/var/mobile/Library/WebClips/34FB814D12744D389BC18AC2FB08222C.webclip/Storage"
  "WebKitMediaPlaybackAllowsInline" => 1
  "WebKitMediaPlaybackRequiresUserGesture" => 0
  "WebKitOfflineWebApplicationCacheEnabled" => 1
  "WebKitShrinksStandaloneImagesToFit" => 1
  "WebKitStandalonePreferenceKey" => 1
  "WebKitStorageTrackerEnabledPreferenceKey" => 1
}


see also


-(void)addWebClipToHomeScreen:(id)homeScreen;

allintext:addWebClipToHomeScreen site:https://github.com


    Class UIApplication = NSClassFromString(@"UIApplication");
    id app = [UIApplication sharedApplication];
    Class UIWebClip = NSClassFromString(@"UIWebClip");
    id clip = [[UIWebClip class] performSelector:@selector(webClipWithIdentifier:)
                                      withObject:nil];
    NSLog(@"%@",clip);
    NSLog(@"%@", [[UIWebClip class] performSelector:@selector(webClipsDirectoryPath)]);
    if ([clip respondsToSelector:@selector(createOnDisk)]) {
        [clip performSelector:@selector(createOnDisk) withObject:nil];
    }
    if ([clip respondsToSelector:@selector(setIconImage:isPrecomposed:)]) {
        [clip performSelector:@selector(setIconImage:isPrecomposed:)
                   withObject:[UIImage imageNamed:@"maps"]
                   withObject:[NSNumber numberWithBool:YES]];
    }
    if ([clip respondsToSelector:@selector(setIdentifier:)]) {
        CFUUIDRef uuid = CFUUIDCreate(kCFAllocatorDefault);
        NSString *uuidstr = (NSString *)CFBridgingRelease(CFUUIDCreateString(kCFAllocatorDefault, uuid));
        [clip performSelector:@selector(setIdentifier:) withObject:uuidstr];
    }
    if ([clip respondsToSelector:@selector(setPageURL:)]) {
        //[clip performSelector:@selector(setPageURL:) withObject:[NSURL URLWithString:@"sms:9738203842"]];
    }
    if ([clip respondsToSelector:@selector(setTitle:)]) {
        [clip setValue:@"Test" forKeyPath:@"title"];
    }
    /*
     if ([clip respondsToSelector:@selector(updateOnDisk)]) {
     [clip performSelector:@selector(updateOnDisk) withObject:nil];
     }
     */
    NSLog(@"%@",[clip valueForKeyPath:@"identifier"]);
    if ([app respondsToSelector:@selector(addWebClipToHomeScreen:)]) {
        [app performSelector:@selector(addWebClipToHomeScreen:) withObject:[clip valueForKeyPath:@"identifier"]];
    }


        UIWebClip *clip = [UIWebClip webClipWithIdentifier:nil];

        CFUUIDRef uuid = CFUUIDCreate(kCFAllocatorDefault);
        NSString *uuidstr = (NSString *)CFUUIDCreateString(kCFAllocatorDefault, uuid);
        [clip setIdentifier:uuidstr];



        UIApplication *app = [UIApplication sharedApplication];
        [app addWebClipToHomeScreen:[clip identifier]];


#import "WebClipViewController.h"

#import "WebClipViewControllerRootView.h"
#import "WebClipViewControllerDelegate.h"
#import "WebClipTableViewCellLayoutManager.h"


#import "WebClipDelegate.h"




#import "WebBookmarksClientDelegateProtocol.h"

@interface UIWebClip : NSObject { }

+ (BOOL)webClipFullScreenValueForWebDocumentView:(id)webDocumentView;

+ (id)webClips;

+ (id)webClipIconsForWebClipLinkTags:(id)arg1 pageURL:(id)arg2;

+ (id)webClipIdentifierFromBundleIdentifier:(id)arg1;

+ (id)webClipWithIdentifier:(id)arg1;

+ (id)webClipWithURL:(id)arg1;

- (void)setStartupImage:(id)arg1;

- (void)setIconImage:(id)arg1 isPrecomposed:(BOOL)arg2;

- (void)setPageURL:(id)arg1;

- (BOOL)updateOnDisk;





<!-- https://github.com/grp/tweaks/blob/e70b851136aa038198da9cda784e2a6f6b535624/fullwebclips/Tweak.xm -->

%hook WebClipViewController

// make room for the added row on the iPad
- (CGSize)contentSizeForViewInPopoverView {


<!-- https://github.com/andrewwiik/Tweaks/blob/648d15433d58429858157e6b6f592cb64100208a/batteryicon/Tweak.xm -->

@class SBIconView;
@interface SBIcon : NSObject
- (void)reloadIconImage;
- (id)application;
@end


@interface SBBookmark : NSObject

@interface SBBookmarkIcon : SBLeafIcon

@interface SBIconController : NSObject

@interface SBApplicationController : NSObject
+ (id)sharedInstance;
- (id)applicationWithBundleIdentifier:(id)arg1;
@end

UIWebClip* BatteryIcon;


%hook SBUIController
- (void)finishLaunching {
    %orig;
        [BatteryIcon setIconImage:[UIImage imageWithContentsOfFile: @"/Library/Application Support/BatteryIcon/batterycharging70.png"] isPrecomposed:FALSE];
%hook SBIconController
- (void)iconTapped:(id)icon {
    if ([[(SBLeafIcon *)[icon valueForKey:@"_icon"] leafIdentifier] isEqualToString:@"com.creatix.batteryicon"]) {
        if (iOS8) {
            [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"prefs:root=General&path=USAGE/BATTERY_USAGE"]];
        }
        else {
        [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"prefs:root=BATTERY_USAGE"]];
    }
        %orig;
    }
    else {
        %orig;
    }
}
%end



<!-- https://github.com/saru2020/iphone-kirikae/blob/22432d1bfa53a4d26d96e2d0fde9133259e911ec/Extension/SpringBoardHooks.xm -->

@interface UIWebClip
@property(retain) NSURL *pageURL;
+ (id)webClipWithIdentifier:(id)identifier;
@end

    UIWebClip *clip = [UIWebClip webClipWithIdentifier:displayId];


<!-- https://github.com/rpetrich/BrowserChooser/blob/0b1fccb25d53f0b74299b98dc5a8566e5c4fb47c/Tweak.x -->

%hook SBBookmarkIcon

- (void)launch
{
    UIWebClip *webClip = [self webClip];





<!-- http://developer.apple.com/library/ios/#documentation/AppleApplications/Reference/SafariWebContent/ConfiguringWebApplications/ConfiguringWebApplications.html -->

"Web Clip"

它的作用类似于桌面浏览器的书签,用户通过点击Icon能直接快速打开这个url的网站


<!-- IOS Safari提供了两个私有接口: apple-touch-icon 和 apple-touch-icon-precomposed。
 -->



1) 桌面图标在页面里的声明仅仅存在 <link> 中,理论上我们只要动态修改 <link> 标签的图片地址就能实现动态的图标。

<!-- JS创建的link -->

function addlink(){    
        $('head').append('<link rel="apple-touch-icon-precomposed" href="../img/demo.png" />');        
        $('.lay-page').append('<br>已创建link~ 添加到主屏幕检查');

}


<!-- webapp里的图标是在body.onload的时候被渲染的-->

行不通:通过js在一个canvas中绘出新的图案,再将这个canvas转化成base64的图片,动态创建到一个 <link> 标签添加至head 

<!-- BodyLoadSetIcon -->

        var img = new Image();
        var canvas = document.createElement('canvas');
        canvas.width = 144;
        canvas.height = 144;
        var context = canvas.getContext("2d");
        context.fillStyle="#ef4372";
        context.fillRect(0,0,144,144);
        context.textAlign="center";
        context.fillStyle = '#ffffff';
        context.textBaseline = "middle";
        context.font = "bold 90px HelveticaNeue";
        context.fillText(num,70, 70);
        var baseImg = canvas.toDataURL();            
        $('head').append('<link id="touchIcon" rel="apple-touch-icon-precomposed" href="' + baseImg + '" />');
        $("body").append('<img src="'+baseImg +'" />');




http://tmt.io/tick/js/tick.js?20131225

https://github.com/hellometers/tick






<!-- 效果:Safari-添加到主屏幕功能 + App URL scheme 轻松实现。 -->

1) 在店铺页面有一个『添加本店铺到桌面的按钮』,点击后跳到 Safari 打开网页 A----data:text/html; 内嵌网页的方式,可能是为了离线

2) 在网页 A 提示用户点击工具栏分享按钮,再选择『添加到主屏幕』 --- 提示用户添加到桌面(注意指定网页 icon 的图片、标题)  ConfiguringWebApplications


3) 手机主界面出现该店铺的『网页快捷方式』--- safari 中打开网页是显示提示,点击主界面图标时如何控制跳转到应用,利用是否全屏显示standalone判断
window.navigator.standalone 参数,如果是 true (从主界面进入)则跳转到对应的 scheme, 如:taobao://shop.m.taobao.com/shop/shop_index.htm?user_id=37141631


4)点击『网页快捷方式』后,打开 Safari,短暂白屏后跳到手机淘宝应用自动打开此店铺 ---在应用内解析 scheme 作处理


<!-- 此效果可以说使用 https://github.com/zhangkn/AddIconToScreen、https://github.com/lijianfeigeek/iOS-desktop-->

JavaScript

Data URI Schema   --- 打开对应的店铺

Socket基本知识

Base64编码


<!-- 其它的可能性-->

1)查系统 scheme,快速进入设置 WIFI、VPN 界面,快速拨打电话

2)icon 与二维码结合使用:对于频繁需要在手机中让别人扫二维码的需要,可以直接扫主界面 icon(就是一个二维码)。这个能是最快展示二维码的方式,连应用都不用打开;


<!-- see also -->
1) https://developer.apple.com/library/ios/documentation/AppleApplications/Reference/SafariWebContent/ConfiguringWebApplications/ConfiguringWebApplications.html

2) iOS web app 桌面图标动态更新的解决方案。


<!-- 7. 判断是否为iPhone: -->

// 判断是否为 iPhone : 
function isAppleMobile() { 
    return (navigator.platform.indexOf('iPad') != -1); 
}; 



// set a web app capable website  Hiding Safari User Interface Components

<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="mobile-web-app-capable" content="yes">




<!-- Linking to Other Native Apps -->
<!-- <a href="tel:1-408-555-5555">Call me</a> -->



<body>
    <a href="addicon://" id="qbt" style="display:none"></a>
    <span id="msg"></span>
</body>


<!-- content -->


<html>
<head>
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <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" />
    <link rel='apple-touch-icon' href=''>
    <title>我的应用</title>
</head>
<body>
    <a href="addicon://" id="qbt" style="display:none"></a>
    <span id="msg"></span>
</body>
<script>
    if (window.navigator.standalone == true)
    {
        var lnk = document.getElementById("qbt").click();
    }
    else
    {
        document.getElementById("msg").innerHTML='<div style="font-size:12px">这里可以添加引导页面</div>';
    }
</script>
</html>

转载请注明: > ConfiguringWebApplications

在操作过程或者文章有问题的话欢迎在 原文 里提问或指正。

赞赏支持

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码支持
扫码打赏,你说多少就多少
最近的文章

C1DriverLicense

前言理论基础 学科三的背下来; <!-- 起步; -->一打(转向灯)二鸣(喇叭)三回头,再二踩(踩离合挂挡)(踩刹车松手刹),<!-- 收车; -->一拉(手刹)二退(空档)三关(转向灯)四熄(火)五松(安全带)夜间灯光模拟考试 请开启前照灯 夜间同方向,近距离跟车行驶——-近光 夜间与机动车会车 ——近光 夜间在照明良好的道路上行驶 —-近光 夜间直行通过路口—-近光 夜...…

other继续阅读
更早的文章

usefulConfig

前言正文tweak /Package/Library/MobileSubstrate/DynamicLibraries/.plist <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"><plist version="1.0...…

tool继续阅读
更多