原文链接: Today

最后更新:2017-02-18

译文:

应用的今日视图扩展被称作小部件。小部件为用户提供快速访问重要信息的入口。例如,用户打开今日视图实时查看股票价格或天气情况,查看今天的日程安排,或者执行一个快速任务,例如标记事件已经被完成。用户往往经常打开今日视图,是希望他们感兴趣的信息是即时可用。

在锁屏状态下,如果用户允许,今日视图小部件将出现在屏幕上面。用户可以在 设置 > Touch ID 与 密码 > 通知视图 来设置 "锁屏时允许访问"。

注意:

确保今天视图扩展是适合你所提供的功能。优秀的部件能为用户提供快速更新或启用非常简单的任务。如果你想创建一个应用程序扩展,执行一个多任务或帮助用户执行一个耗时的任务,如上传或下载内容,在今天视图扩展点不是正确的选择。

理解今日视图扩展

在 iOS & OS X 平台上,今日视图部件应该:

  • 确保内容总是最新的。
  • 适当地响应用户的交互。
  • 表现良好(特别指出iOS的部件必须合理使用内存,否则系统可能终止它们)

今日视图部件的用户交互是快速和有限的,因此你应该设计一个简单的,流线型的用户界面,突出用户感兴趣信息,在一般而言,限制小部件交互数量是一个不错的注意。尤其注意的是iOS的小部件不支持键盘输入。

注意

避免将滚动视图放在今天视图小部件里面。对用户来说,在今日部件中滚动视图是困难的。

用户配置今日视图不见根据其使用的平台不同而不一样。

iOS. 因为今日视图不允许使用键盘,用户需要能够使用包容器应用配置Widget的内容和行为。例如,在股票小部件,用户可以在符号的不同值之间切换,但他们必须打开的股票应用程序来管理列表中的符号。

OSX 容器应用可能无法执行任何功能,因此,今日视图部件需要提供方式在运行时候配置它,例如: OSX中,股票的小部件允许用户查找他们感兴趣的股票。OS X中的通知中心API包括可以用来让用户配置部件的方法。

当用户安装了带有今日视图部件的app 时, 今日视图部件就被加载到了今日视图里面去了。 用户可以在通知中心编辑、添加以及移除小部件。

使用Xcode 今日模板

Xcode的今天,模板提供默认的头和实现文件的主要类(名为:TodayViewController)、一个info.plist文件和一个接口文件(storyboard 或者 xib 文件)

默认情况下,今日视图模板提供一下 Info.plist 键值(这里显示为OS X的target)

<key>NSExtension</key>
<dict>
<key>NSExtensionPointIdentifier</key>
<string>com.apple.widget-extension</string>
<key>NSExtensionPrincipalClass</key>
<string>TodayViewController</string>
</dict>

如果你使用了自定义控制器,使用自定义的类名去替代 NSExtensionPrincipalClass的值 TodayViewController

iOS 如果你不想使用默认的模板,移除 NSExtensionMainStoryboard键,添加 NSExtensionPrincipalClass键,值为你自定义控制器的名称。

大多数你创建一个今天插件的工作涉及UI设计和自定义视图控制器类的功能。

设计UI

重要提醒

为了达到最佳效果,请使用自动布局来设计今天视图部件。

因为今日视图部件控件有限,部件的用户体验是专注、快速。你不应该创建一个默认很大的部件。在不同平台上,今日视图部件宽度必须在今日视图的宽度内,但它可以在高度上增加显示更多的内容。

通过Xcode 模板创建今日视图,小部件使用标准的自动布局约束的间隙 insets,为了获得inset用户计算,实现 widgetMarginInsetsForProposedMarginInsets 方法,(模板的主要视图控制器符合NCWidgetProviding协议,该协议提供了这种方法),一定要确保今日视图部件的内容在 标准间隙 insets 内,想了解更多关于小部件设计,可以查阅 iOS Human Interface Guidelines.

如果一个部件有额外的内容显示,你可以依靠自动布局约束来调整窗口小部件的高度。如果你不使用自动布局,您可以使用的UIViewController属性preferredContentSize要求高度的部件。 例如:

- (void)receivedAdditionalContent {
self.preferredContentSize = [self sizeNeededToShowAdditionalContent];
}

注意

不要为你的widget的高度,将要求用户滚动查看其所有内容

官方文档翻译-Today的更多相关文章

  1. Flume官方文档翻译——Flume 1.7.0 User Guide (unreleased version)中一些知识点

    Flume官方文档翻译--Flume 1.7.0 User Guide (unreleased version)(一) Flume官方文档翻译--Flume 1.7.0 User Guide (unr ...

  2. Flume官方文档翻译——Flume 1.7.0 User Guide (unreleased version)(二)

    Flume官方文档翻译--Flume 1.7.0 User Guide (unreleased version)(一) Logging raw data(记录原始数据) Logging the raw ...

  3. 蓝牙4.0——Android BLE开发官方文档翻译

    ble4.0开发整理资料_百度文库 http://wenku.baidu.com/link?url=ZYix8_obOT37JUQyFv-t9Y0Sv7SPCIfmc5QwjW-aifxA8WJ4iW ...

  4. GreenDao官方文档翻译(上)

    笔记摘要: 上一篇博客简单介绍了SQLite和GreenDao的比较,后来说要详细介绍下GreenDao的使用,这里就贴出本人自己根据官网的文档进行翻译的文章,这里将所有的文档分成上下两部分翻译,只为 ...

  5. Aircrack-ng官方文档翻译[中英对照]---Airdecap-ng

    Aircrack-ng官方文档翻译---Airdecap-ng   Description[简介] With airdecap-ng you can decrypt WEP/WPA/WPA2 capt ...

  6. Aircrack-ng官方文档翻译[中英对照]---Airmon-ng

    Aircrack-ng官方文档翻译---Airmon-ng Description[简介] This script can be used to enable monitor mode on wire ...

  7. Aircrack-ng官方文档翻译[中英对照]---Aireplay-ng

    Aircrack-ng官方文档翻译---Aireplay-ng[90%] Description[简介] Aireplay-ng is used to inject frames. Aireplay- ...

  8. Salt Stack 官方文档翻译 - 一个想做dba的sa - 博客频道 - CSDN.NET

    OSNIT_百度百科 Salt Stack 官方文档翻译 - 一个想做dba的sa - 博客频道 - CSDN.NET Salt Stack 官方文档翻译 分类: 自动运维 2013-04-02 11 ...

  9. Retrofit官方文档翻译

    Retrofit官方文档翻译 官方文档网址 http://square.github.io/retrofit/ 介绍 Retrofit 将你的 HTTP API 转换为 Java 接口. public ...

  10. Spark官方文档翻译(一)~Overview

    Spark官方文档翻译,有问题请及时指正,谢谢. Overview页 http://spark.apache.org/docs/latest/index.html Spark概述 Apache Spa ...

随机推荐

  1. 【Python基础】_2 Python基本语法与常识(迭代优化中...)

    2 Python的基本语法 为了保证Python解释器能顺利编译所编写的代码,也为了程序员对自己和别人所编写的程序易于阅读.维护,对编程语言的语法做一些基本约定是非常必要的. 2.1 编程方式 2.1 ...

  2. 自定义SpringBoot启动控制台图标

    使用过SpringBoot的小伙伴众所周知,在启动的过程中,在控制台会首先打印spring的图标以及版本号(这里以IDEA为例) 如果需要更改这个打印图标的话, 需要以下步骤: 1.打开SpringB ...

  3. Spring源码深度解析

    Spring源码分析 Spring Web入门及源码学习 [Spring源码分析]Bean加载流程概览 Spring Framework 实现原理与源码解析系统 Spring源码分析--水门 Spri ...

  4. P3958奶酪

    这个题是2017noip提高组的真题,是一个深度搜索题,得分轨迹:10-80-100pts. 在三维空间里,存在可能连通的洞(半径r),问是否可以通过这些洞从底部到达顶部.一开始我联想到了01迷宫,以 ...

  5. Hyper-V Centos7 虚拟机固定IP

    在网上看到很多篇文章,自己也去试验过,结果实现的效果都不是很理想,并不是自己所需要的,下面是我自己研究,最后成功的经验,希望能够帮到大家.少走一些弯路. 需求 1.无论物理机的网络环境怎么变化,都需要 ...

  6. 02:django model数据库操作

    Django其他篇 目录: 1.1 Django中使用MySQL 1.2 创建表 1.3 Django一对多表结构操作 1.4 Django多对多表结构操作 1.5 一大波Model操作 1.6 Mo ...

  7. Neo4j源代码分析

    1.下载neo4j源码 https://github.com/neo4j/neo4j/ 参考文章 原文地址:https://blog.csdn.net/e15273/article/details/7 ...

  8. css控制文本内容显示省略号

    1,单行文字显示省略号 div{ width:200px; overflow:hideen; white-space:nowrap; text-overflow:ellipsis; } 2,多行文字显 ...

  9. Qt下载(多种下载通道+所有版本)

    http://c.biancheng.net/view/3851.html Qt 体积很大,有 1GB~3GB,官方下载通道非常慢,相信很多读者会崩溃,所以建议大家使用国内的镜像网站(较快),或者使用 ...

  10. C scanf 函数的其他使用注意点

    1.scanf 函数中没有精度控制,如: scanf("%5.2f", &a )是非法的,不能企图用此语句数据小数位2位的实数 2.scanf中要求给出变量地址,如给出变量 ...