在Firefox OS 学习——Gaia 编译分析 这篇文章多次提到manifest.webapp文件,对于做过android app 开发的人来说,都很熟悉Android.mk 和Manifest.xml文件。在Firefox OS中,manifest.webapp的作用是综合了android 中的Android.mk 和Manifest.xml的作用。下面就具体说说manifest.webapp的结构及其内容。
manifest.webapp采用的是json的数据格式(键值对的形式),它描述了app 的name,icon,loacl,premissions等相关的信息。先看一个相对完整的manifest.webapp的格式及其内容:
{ "name": "MozillaBall", "description": "Exciting Open Web development action!", "launch_path": "/", "version": "1.0", "type": "privileged", "icons": { "16": "/img/icon_16.png", "48": "/img/icon_48.png", "128": "/img/icon_128.png" }, "developer": { "name": "Mozilla", "url": "https://mozilla.org/en-US" }, "installs_allowed_from": [ "https://marketplace.mozilla.org" "https://marketplace.example.org" ], "appcache_path": "/cache.manifest", "locales": [ "es": { "description": "¡Acción abierta emocionante del desarrollo del Web!", "developer": { "url": "https://mozilla.org/es-ES" } } "it": { "description": "Azione aperta emozionante di sviluppo di fotoricettore!", "developer": { "url": "http://it.mozillalabs.com/" } } ], "default_locale": "en", "screen_size": { "min_width": "600", "min_height": "300" }, "required_features": [ "touch", "geolocation", "webgl" ], "orientation": "landscape", "permissions": { "contacts": { "description": "Required for autocompletion in the share screen", "access": "read" } }, "fullscreen": "true", "activities": { "share": { "filters": { "type": ["image/png", "image/gif"] } "href": "/share.html", "disposition": "window" } } }属性
上述code清单中的各种属性,用法,含义,下面做详细介绍。这些属性必须包含String,其实它的属性大致可以分为两类:强制属性,可选属性。
1.强制属性
name:默认locale下,web app的名称,显示在设备中app的名称,最大支持128字符
description:默认locale下,web app的简短描述(查询了一些资料,没发现它的功能)最大支持1024字符
default_locale:设置默认的locale,确定name,description的语言环境。
2.可选属性
launch_path:指定web app被打开时,首先加载的东西,一般都是"/index.html".如果值缺省了(即"/"),将加载域名的东西。
version:web app的版本号,
type:确定这个app 和manifest如何被runtime解析,还有所使用的安全机制。它的值只能是下面三个中一个:
* web:正常的web app可以单独存在,在应用商店可以下载安装,并且会列举有限的权限。type 不指定时,默认是web。
* privileged:就像android Ios 一样单独存在的app,会在本地安装一个文件包。它需要通过应用商店的审核。
* certified:不用于第三发app中,属于系统级别的东西,例如系统设置,拨号器,电源管理等。类似android:sharedUserId 作用把。
icons:app icon,支持 16 x 16, 32 x 32, 48 x 48, 64 x 64, 128 x 128 and 256 x 256
developer:开发者相关的信息,包括开发者名称,及其URL。
installs_allowed_from:指定app可以从那些应用商店安装,"*"可以从任何地方安装," "无法从任何网站商店安装。
appcache_path:存放app cache manifest的绝对路径,当打开安装的web app时,cache.manifest会被解析。静态的一些资源会被存放到缓存中。
locales:重写一些locales特定的值,适应不同的语言。locales, installs_allowed_from, default_locale是不能被重写的。如果locales被设置了,default_locale也必须被设置。
screen_size:包含两个属性min_width,min_height,分别设置app适应的最小宽度和高度(以像素为单位)。
required_features:包含app 能正确运行需要的一些强制属性。具体的值尚无定论。这个在app中可能用的很少。
orientation:锁定app的屏幕方向,和android orientation的功能一样。它的值必须是下面四个中的一个或多个:
* portrait-primary:锁定单一portrait显示。如果设备有明显的portrait,就是显示成portrait。如果设备从landscape顺时针旋转90度,app也显示portrait。
* landscape-primary:锁定单一landscape显示。如果设备有明显的landscape,就是显示成landscape。如果设备从portrait顺时针旋转90度,app也显示landscape。
* portrait-secondary:锁定单一portrait显示。如果设备有明显的portrait,就是显示成portrait。如果设备从landscape逆时针旋转90度,app也显示portrait。
* landscape-secondary:锁定单一landscape显示。如果设备有明显的landscape,就是显示成landscape。如果设备从portrait逆时针旋转90度,app也显示landscape。
* portrait:相当于["portrait-primary", "portrait-secondary"]这种组合模式。
* landscape:相当于["landscape-primary", "landscape-secondary"]组合模式
permissions:描述app 所需要的权限,android开发者对着部分就很熟悉了。只是的它格式和写法不同。下面给了example:
"permissions": { "contacts": { "description": "Required for autocompletion in the share screen", "access": "readcreate" }, "alarms": { "description": "Required to schedule notifications" } }permissions详细的请参照 App_permissions。
fullscreen:设置app是否全屏,只能true 或者false。默认应该是false吧(有待验证)。
activities:指定这个app可以支持的web activities。activities命名没有什么讲究。下面给出个例子:
"activities": { "share": { "filters": { "type": ["image/png", "image/gif"] } "href": "/share.html", "disposition": "window" } }关于activities中的三个属性
filters
,
href
,
disposition
and
returnValue
请参考 Activity handler description。
redirects:针对 privileged 或 certified类型 app做第三方认证。从第三方认证后需要重定向当前app URL。但是privileged 或 certified类型 app是没有可以使用的web URL,所以它只能重定向到app 内部的URL。下面给个exanple:
"redirects": [ {"from": "http://mydomain.com/oauth2/flow.html", "to": "/redirects/redirect.html"}, {"from": "http://mydomain.com/oauth2/dialogs_end.html", "to": "/redirects/dialogs_end.html"} ]
origin:针对 privileged 或 certified类型 app的属性,功能之一就是很容易通过类似的OAuth , Persona等认证。格式是app://<UUID>.example:
"origin": "app://my-app.com"
messages:捕获系统消息作出的反映,example:
"messages": [ { "telephony-new-call": "/dialer/index.html#keyboard-view" }, { "bluetooth-dialer-command": "/dialer/index.html#keyboard-view" }, { "headset-button": "/dialer/index.html#keyboard-view" }, { "notification": "/dialer/index.html#keyboard-view" }, { "alarm": "/facebook/fb_sync.html" } ]上面的例子中,当接受的电话打进请求消息时,会弹出keyboard-view,以便用会作出接听,挂断的操作。
chrome:
在屏幕底部添加一个导航栏,对于没有返回按钮的app,可以快速增加一个导航栏。
左边的图是导航栏隐藏的时候的图,右边是显示时候的图。
到此,manifest.webapp结构的内容基本上都涉及到了。都只是粗略的弄懂概念而已,具体的细节还要在应用中去具体甄别。
参考文章:App manifest
Web Application Manifest Format and Management APIs