Passbook学习笔记
一、Passbook是什么
- iOS 6 Passbook 入门 1/2
- iOS 6 Passbook 入门 2/2
二、特性
1、可以设置时间和位置参数
2、可更新
- 自动更新
- 用户手动下拉更新
3、系统要求
4、Passbook可以不依赖app
5、有三种添加方式
- 邮件
- web浏览器
- 客户端
三、类型划分
1、五种类型
- boardingPass(登机牌)
- coupon(优惠券)
- storeCard (购物券)
- eventTicket(活动门票)
- generic(通用)
- 在外形上:
- 界面布局
四、内部结构
- pass.json – 关于这个 pass 的信息区域的描述,包括他们的内容, 和元信息,这是一个Passbook的核心部分。
- manifest.json – 这个文件描述了这个 pass 中的文件列表, 和每个文件的 SHA1 校验和。
- signature – manifest.json 一个分离的的 DER 签名, 通过苹果提供的证书生成的。
- background.png – 显示在 pass 正面的图片。
- background@2x.png – 视网膜屏尺寸的显示在 pass 正面的图片。
- logo.png – 在 pass 的头部区域显示的 logo。 苹果推荐的是一个纯色单色的 logo。 图片的尺寸由你决定, 但是高度不能大于 50px 以便适合头部的高度。
- logo@2x.png – 视网膜屏幕的 logo 图片
- icon.png – pass 的一个小图标, 当 pass 作为 email 附件的时候会被用到。 在写这篇教程的时候, 还没有关于这个图片尺寸的文档,但看起来像是 29×29 像素(大尺寸的图标会被缩放,所以他们的显示效果也不错)。
- icon@2x.png – 视网膜版本的图标
- strip.png 和 strip@2x.png – 用作主条目的背景;仅用于优惠劵和购物券
Passbook的主要文件是 pass.json 这个 JSON 文件。 在它里面你声明了这个 Passbook 正面和反面的所有信息; 我们还需要提供需要显示的图片(优惠券仅仅需要指定background.png和它的视网膜版本);最终,还需要一个清单文件manifest.json,它包含了所有这些文件的 SHA1 校验和;另外还的有一个分开的签名文件signature, 签名文件用于验证这个 Passbook 在创建之后没有被修改过。
五、pass.json文件
1、至少包含的字段
{"formatVersion" : 1,"passTypeIdentifier" : "pass.com.lashou.passbook","serialNumber" : "gT6zrHkaW","teamIdentifier" : "4SK4K45JGW","organizationName" : "Skyport Airways","description" : "SFO to JFK",
}
- formatVersion – 文件格式的版本,需要注意的是,必须用数字,而不是用字符串,否则会无效。
- passTypeIdentifier – 这是 Pass 的标识。 这个和 iOS 中的 bundle identifier 差不多。 稍后会更多的介绍关于这个标识的内容。
- serialNumber – 这个是 pass 的序列号。 你可以用任何方式生成它 – 它可以是数组, 例如 “00193”(注意,它仍然被写成字符串值), 或者是字母和数字的组合,像是你在登机牌上面看到的序列号(例如 “XS83A”)。需要注意的是同一个passTypeIdentifier下面不能包含相同的serialNumber,否则会被认为是统一个Passbook,导致安装时发生覆盖。
- teamIdentifier – 这是苹果分配和每个 iOS 开发者的一个唯一的十个字符的标识。 如果你创建过你自己的 iOS 应用,你应该已经熟悉它了。 你可以登陆到 iOS Member Center 并点击你的组织名来找到你的 team identifier。你可以在 “Company/Organization ID” 标签后面找到它。
- organizationName – 你的组织名称。
- description – 关于 pass 一个简短的介绍。
2、用于控制显示效果的字段
另外还可以通过下面的键值对调整Passbook的显示效果:
"logoText" : "Free Hugs LLC",
"foregroundColor" : "rgb(255, 255, 255)",
"backgroundColor" : "rgb(135, 129, 189)",
"labelColor" : "rgb(45, 54, 129)"
- logoText – 这是显示在 pass 头部并且紧挨着 logo 图片的文本。
- foregroundColor – 文本的颜色。
- backgroundColor – pass 的背景颜色。 Passbook 将会根据背景色的色值来创建一个漂亮的渐变效果, 这样来给 pass 的正面一个良好的视觉外观, 苹果推荐使用鲜艳的颜色。
- labelColor – 根据你的背景颜色,pass 上面的标签将会被渲染为一个和背景色反差比较大的颜色。如果你需要的话, 你可以为这些标签指定你自己的颜色。
下图更形象的展示了上述字段的作用效果:
3、条形码
"barcode" : {"message" : "All you need is love","format" : "PKBarcodeFormatPDF417","messageEncoding" : "iso-8859-1"
}
- message – 这是条形码包含的数据。 它可以是唯一的编码, 持有者的客户ID, 或者其他任何东西。 在 Free Hug 的例子中, 它仅仅是一个文本消息,用来让持有者得到一个免费的拥抱。
- format – 条形码的格式名称。 用来生成 2D 条形码。
- messageEncoding – 用来解码消息的文本编码名称。 如果你使用非拉丁语言, 你将要用 UTF8 或者其他形式适合你的文本编码(如果你私用标准的英语和数字, 它的默认值是 “iso-8859-1”)。
关于条形码,有两点说明:
②目前Passbook条形码只支持三种较新的格式:PKBarcodeFormatQR,PKBarcodeFormatPDF417和PKBarcodeFormatAztec。即上面的format字段可以选取上述三个值中的一个作为自己得编码格式。
4、如何决定不同的Passbook风格
"boardingPass" : {"transitType" : "PKTransitTypeAir","headerFields" : [{"label" : "GATE","key" : "gate","value" : "23","changeMessage" : "Gate changed to %@."}],"primaryFields" : [{"key" : "depart","label" : "SAN FRANCISCO","value" : "SFO"},{"key" : "arrive","label" : "NEW YORK","value" : "JFK"}],"secondaryFields" : [{"key" : "passenger","label" : "PASSENGER","value" : "John Appleseed"}],"auxiliaryFields" : [{"key" : "expires","label" : "EXPIRES","value" : "2 weeks"},{"key" : "datefdasf","label" : "DATE","value" : "7/22",},{"key" : "expires","label" : "EXPIRES","value" : "2 weeks"},{"key" : "datefdasf","label" : "DATE","value" : "7/22",}],"backFields" : [{"key" : "terms","label" : "TERMS","value" : "Extension of Validity\nIf after having commenced your journey."}]}
- 顶部抬头(图中区域1,对应headerFields). 顶部条包含了一个容易辨认的 Logo 和一个公司名称。 头部区域用户会在 Passbook 的列表中看到。 它包含了你要给用户提供的最关键的信息, 这样他们就可以辨认出他们需要的 pass 了。
- 主体区域(图中区域2,对应primaryFields). 这部分包含了 pass 的内容。 每个 pass 在这个区域都有不同的风格, 它通常在 pass 打开时显示最主要的信息。 像是 “打折 20%”, “一杯免费咖啡”, “余额 $120″ 或是其他这类的信息非常有用。
- 附加信息(图中区域3和4,分别对应auxiliaryFields和secondaryFields). 第三个部分用作附加信息 – 仍然是很重要的资料(例子中的促销的有效性和开始时间), 但绝对不像关于 pass 是什么东西这样的信息那么重要。
- 条形码(图中区域5,对应barcode). 条形码包含了编码后的信息, 可以通过条形码扫描器很容易的将这些信息转移到其他系统中。在上面的例子中, 条形码包含了一个加密代码。 档被扫描器节解码后, 它会给这个 pass 的所有者一个免费的拥抱(立即发送)。
{"key" : "depart","label" : "SAN FRANCISCO","value" : "SFO"
}
这些字段的意义如下:
- key – 字段的名称,不会显示到界面中,而且我试过key重复也没问题。
- label – 字段的副区域文本,会显示在主文本区域的上边。
- value – 字段的主区域文本,会显示在副区域文本的下面。
至此,Passbook包含的全部文件都讲完了。
Passbook学习笔记相关推荐
- PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 call
您的位置 首页 PyTorch 学习笔记系列 PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 发布: 2017年8月4日 7,195阅读 ...
- 容器云原生DevOps学习笔记——第三期:从零搭建CI/CD系统标准化交付流程
暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...
- 容器云原生DevOps学习笔记——第二期:如何快速高质量的应用容器化迁移
暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...
- 2020年Yann Lecun深度学习笔记(下)
2020年Yann Lecun深度学习笔记(下)
- 2020年Yann Lecun深度学习笔记(上)
2020年Yann Lecun深度学习笔记(上)
- 知识图谱学习笔记(1)
知识图谱学习笔记第一部分,包含RDF介绍,以及Jena RDF API使用 知识图谱的基石:RDF RDF(Resource Description Framework),即资源描述框架,其本质是一个 ...
- 计算机基础知识第十讲,计算机文化基础(第十讲)学习笔记
计算机文化基础(第十讲)学习笔记 采样和量化PictureElement Pixel(像素)(链接: 采样的实质就是要用多少点(这个点我们叫像素)来描述一张图像,比如,一幅420x570的图像,就表示 ...
- Go 学习推荐 —(Go by example 中文版、Go 构建 Web 应用、Go 学习笔记、Golang常见错误、Go 语言四十二章经、Go 语言高级编程)
Go by example 中文版 Go 构建 Web 应用 Go 学习笔记:无痕 Go 标准库中文文档 Golang开发新手常犯的50个错误 50 Shades of Go: Traps, Gotc ...
- MongoDB学习笔记(入门)
MongoDB学习笔记(入门) 一.文档的注意事项: 1. 键值对是有序的,如:{ "name" : "stephen", "genda" ...
最新文章
- 【从零学习OpenCV 4】安装过程中问题解决方案
- html怎么将页面放到中间,HTML – 如何将div放在另外两个(左和右)div之间?
- SQL Server 2017 2019 Linux(Centos、Unbuntu16.04、Unbuntu18.04、Unbuntu20.04)安装过程详解
- 2-django进阶之日志功能(亲测)
- python list转换成树形结构_python递归查询菜单并转换成json实例
- RabbitMQ 添加用户(入门试炼_第2篇)
- AttributeError: module 'cv2' has no attribute 'imread'
- 关于phpexcel读取时间字段的格式不正确
- 在.net core 2.0中生成exe文件
- 『计算机视觉』Mask-RCNN_训练网络其一:数据集与Dataset类
- Oracle---PL/SQL 基础知识
- UnityVS(2012)安装教程
- 采用LM1875组成的各种功放电路
- vue v-for实现多行等分布局-三等分
- JavaScript|表格背景颜色改变页面
- 计算机控制plc应用论文,PLC自动控制系系统在变频器中的运用
- OGRE关于 Demo_Ocean 例子的分析
- mysql myisam 主键关联_MySQL中myisam和innodb的主键索引有什么区别?
- 搜狗输入法的符号大全里面可以输入下标
- 苹果新款笔记本_微软为Bing桌面体验也带来了语音搜索功能_苹果 新款MacBook Pro 13英寸_笔记本新闻...