创建自定义的布局

最后更新于:2022-04-01 01:41:39

> 编写: [kesenhoo](https://github.com/kesenhoo) - 原文: [http://developer.android.com/training/wearables/apps/layouts.html](http://developer.android.com/training/wearables/apps/layouts.html) 为可穿戴设备创建布局是和手持设备是一样的,除了我们需要为屏幕的尺寸和glanceability进行设计。但是不要期望通过搬迁手持应用的功能与UI到可穿戴上会有一个好的用户体验。仅仅在有需要的时候,我们才应该创建自定义的布局。请参考可穿戴设备的[design guidelines](http://developer.android.com/design/wear/index.html)学习如何设计一个优秀的可穿戴应用。 ### 创建自定义Notification 通常来说,我们应该在手持应用上创建好notification,然后让它自动同步到可穿戴设备上。这让我们只需要创建一次notification,然后可以在不同类型的设备(不仅仅是可穿戴设备,也包含车载设备与电视)上进行显示,免去为不同设备进行重新设计。 如果标准的notification风格无法满足我们的需求(例如[NotificationCompat.BigTextStyle](http://developer.android.com/reference/android/support/v4/app/NotificationCompat.BigTextStyle.html) 或者 [NotificationCompat.InboxStyle](http://developer.android.com/reference/android/support/v4/app/NotificationCompat.InboxStyle.html)),我们可以显示一个使用自定义布局的[activity](# "An activity represents a single screen with a user interface.")。我们只可以在可穿戴设备上创建并处理自定义的notification,同时系统不会将这些notification同步到手持设备上。 **Note:** 当在可穿戴设备上创建自定义的notification时,我们可以使用标准notification API(API Level 20),不需要使用Support Library。 为了创建自定义的notification,步骤如下: 1. 创建布局并设置这个布局为需要显示的[activity](# "An activity represents a single screen with a user interface.")的content view: ~~~ public void onCreate(Bundle bundle){ ... setContentView(R.layout.notification_activity); } ~~~ 1. 为了使得[activity](# "An activity represents a single screen with a user interface.")能够显示在可穿戴设备上,需要在manifest文件中为[activity](# "An activity represents a single screen with a user interface.")定义必须的属性。我们需要把[activity](# "An activity represents a single screen with a user interface.")声明为exportable,embeddable以及拥有一个空的task affinity。我们也推荐把[activity](# "An activity represents a single screen with a user interface.")的主题设置为`Theme.DeviceDefault.Light`。例如: ~~~ <activity android:name="com.example.MyDisplayActivity" android:exported="true" android:allowEmbedded="true" android:taskAffinity="" android:theme="@android:style/Theme.DeviceDefault.Light" /> ~~~ 1. 为[activity](# "An activity represents a single screen with a user interface.")创建[PendingIntent](http://developer.android.com/reference/android/app/PendingIntent.html),例如:: ~~~ Intent notificationIntent = new Intent(this, NotificationActivity.class); PendingIntent notificationPendingIntent = PendingIntent.getActivity(this, 0, notificationIntent, PendingIntent.FLAG_UPDATE_CURRENT); ~~~ 1. 创建[Notification](http://developer.android.com/reference/android/app/Notification.html)并执行[setDisplayIntent()](http://developer.android.com/reference/android/app/Notification.WearableExtender.html#setDisplayIntent(android.app.PendingIntent))方法,参数是前面创建的PendingIntent。当用户查看这个notification时,系统使用这个PendingIntent来启动[activity](# "An activity represents a single screen with a user interface.")。 1. 使用[notify()](http://developer.android.com/reference/java/lang/Object.html#notify())方法触发notification。 > **Note:** 当notification呈现在主页时,系统会根据notification的语义,使用一个标准的模板来呈现它。这个模板可以在所有的表盘上进行显示。当用户往上滑动notification时,将会看到为这个notification准备的自定义的[activity](# "An activity represents a single screen with a user interface.")。 ### 使用Wearable UI库创建布局 当我们使用Android Studio的工程向导创建一个Wearable应用的时候,会自动包含Wearable UI库。你也可以通过给`build.gradle`文件添加下面的依赖声明把库文件添加到项目: ~~~ dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.google.android.support:wearable:+' compile 'com.google.android.gms:play-services-wearable:+' } ~~~ 这个库文件帮助我们建立为可穿戴设备设计的UI。更详细的介绍请看[为可穿戴设备创建自定义UI](http://hukai.me/android-training-course-in-chinese/wearables/ui/index.html)。 下面是一些Wearable UI库中主要的类: - **BoxInsetLayout** - 一个能够感知屏幕的形状并把子控件居中摆放在一个圆形屏幕的FrameLayout。 - **CardFragment** - 一个能够可拉伸,垂直可滑动卡片的fragment。 - **CircledImageView** - 一个圆形的image view。 - **ConfirmationActivity** - 一个在用户完成一个操作之后用来显示确认动画的[activity](# "An activity represents a single screen with a user interface.")。 - **CrossFadeDrawable** - 一个drawable。该drawable包含两个子drawable和提供方法来调整这两个子drawable的融合方式。 - **DelayedConfirmationView** - 一个view。提供一个圆形倒计时器,这个计时器通常用于在一段短暂的延迟结束后自动确认某个操作。 - **DismissOverlayView** - 一个用来实现长按消失的View。 - **DotsPageIndicator** - 一个为GridViewPager提供的指示标记,用于指定当前页面相对于所有页面的位置。 - **GridViewPager** - 一个可以横向与纵向滑动的局部控制器。你需要提供一个GridPagerAdapter用来生成显示页面的数据。 - **GridPagerAdapter** - 一个提供给GridViewPager显示页面的adapter。 - **FragmentGridPagerAdapter** - 一个将每个页面表示为一个fragment的GridPagerAdapter实现。 - **WatchViewStub** - 一个可以根据屏幕的形状生成特定布局的类。 - **WearableListView** - 一个针对可穿戴设备优化过后的ListView。它会垂直的显示列表内容,并在用户停止滑动时自动显示最靠近的Item。 ### Wear UI library API reference 这个参考文献解释了如何详细地使用每个UI组件。查看[Wear API reference documentation](http://developer.android.com/reference/android/support/wearable/view/package-summary.html)了解上述类的用法。 ### 为用于Eclipse ADT下载Wearable UI库 如果你正在使用Eclipse ADT,那么下载[Wearable UI library](http://developer.android.com/shareables/training/wearable-support-lib.zip)将Wearable UI库导入到你的工程当中。 > **Note:** 我们推荐使用[Android Studio](http://developer.android.com/sdk/index.html)来开发可穿戴应用。
';