原文地址app
Sony SmartWatch产品是用来补充/扩展Android移动设备功能的配件。SmartWatch为触屏配件,使用蓝牙跟Android手机或平板通讯。目前该产品包括SmartWatch(MN2)和SmartWatch 2(SW2)。布局
SmartWatch配置以下:性能
SmartWatch 2配置以下:设计
注意:LED和Text to speech不可用于为SmartWatch 2开发的appcode
一、蓝牙通讯 二、包括SmartWatch(MN2)和SmartWatch2(SW2)进程
SmartWatch配置: Vibrator, Accelerometer, Button(不可用于app) SmartWatch2配置: Vibrator, Accelerometer, Light sensor, Action key, Back key, Home key(不可用于app)事件
注意LED和Text to speech不可用于为SmartWatch 2开发的app图片
<table> <tr> <td> 产品 </td> <td> SmartWatch </td> <td> SmartWatch 2 </td> </tr> <tr> <td> 屏幕类型 </td> <td> OLED, 16-bit </td> <td> TFT, 16-bit </td> </tr> <tr> <td> 分辨率 </td> <td> w:128px, h:128px </td> <td> w:220, h:176px </td> </tr>ip
</table>ci
<table> <tr> <td> 产品 </td> <td> SmartWatch </td> <td> SmartWatch 2 </td> </tr> <tr> <td> Control API v1.0 </td> <td> 支持 </td> <td> 支持 </td> </tr> <tr> <td> Control API v2.0 </td> <td>
</td> <td> 支持 </td>
</tr> <tr> <td> Registration & Capabilities API v1.0 </td> <td> 支持 </td> <td> 支持 </td> </tr> <tr> <td> Registration & Capabilities API v2.0 </td> <td>
</td> <td> 支持 </td>
</tr> <tr> <td> Notification API v1.0 </td> <td> 支持 </td> <td> 支持 </td> </tr> <tr> <td> Notification API v2.0 </td> <td>
</td> <td> 支持 </td>
</tr> <tr> <td> Sensor API v1.0 </td> <td> 支持 </td> <td> 支持 </td> </tr> <tr> <td> Widget API v1.0 </td> <td> 支持 </td> <td>
</td>
</tr> </table>
1.针对SmartWatch
2.SmartWatch2
SmartWatch是高性能的智能配件,因此须要合理地使用电池。主应用和Sony Add-on SDK包含提供一些节省电量的功能。但Extension最好遵循如下建议:
使用传感器用SmartExtensionUtils.isSensorSupported()进行检查。可参考SampleSensorExtension参考这个方法的使用方法
加速度计仅可用于当前正在运行的Extension。若是屏幕熄灭,或按下power键,或者另外一个Extension启动了,致使当前Extension暂停,那么加速度计将中止。
若是Extension仍然想接收到传感器数据,则须要使用SCREEN_STATE_ON, SCREEN_STATE_OFF或 SCREEN_STATE_DIM Intent
全部的Smart Extension app运行在service中。Android中的service为后台进程,而同时运行的后台进程数量是有限的,因此Android会中止最近未使用的进程。甚至当Smart Extension app在前台显示时这种状况也会发生。一般这不会是什么大问题由于Smart Extension app仅在前台并和用户直接交互很短的一段时间。另外,SmartExtensionUtils中提供方法用于Smart Extension app与用户交互时被中止掉时的恢复。
对须要长时间运行且不该被停止的Smart Extension app,可使用Service.startForeground()方法来将后台进程变成前台进程。这么作的反作用是service在前台运行时状态栏会出现一个notification。
开发一款Extension后,当终端用户在SmartConnect中搜索兼容的应用时能被找到,能够增长曝光度。
为了更容易被搜索到,支持SmartWatch 2的应用最好在应用描述中增长如下内容:
Smart Connect extension for SmartWatch 2
这里讨论的是SmartWatch 2(略过了关于SmartWatch的,更多信息请参考原文)
若是Extension同时使用Control API 和 Notification API,在SmartWatch 2上点击Extension的图标时会弹出Notification页面——即显示最近的Notification。虽然SmartWatch 2还不支持launch mode,但仍是建议你在Extension注册时设置Extension的launch mode。这样能够防止将来SmartWatch 2升级(升级后能够支持完整的launch mode)时Extension的launch行为发生变化(将来缺省启动Extension的Control API部分)
Extension将其图片或布局发送到主应用,主应用会将图片和布局转换成配件支持的格式。
Extension使用Control API来控制整个屏幕。为了能支持为SmartWatch写的应用,某些状况下使用Control API提供的显示数据(图片或布局)会被缩放。缩放过程对Extension来讲是透明的。主应用自动缩放图片,触摸事件坐标等等,不会影响长宽比。缩放过程保证高度能够填满整个屏幕且正好水平居中。The scaling is triggered if the first display data sent by the Control API after it’s launched is positioned at (0,0) and the display data has a size of 128 x 128 pixels(????不清楚)当Extension不显示时缩放效果再也不起做用。若是原始大小是220x176px,不会对显示数据进行任何缩放。
使用Control API的Extension, 能够支持touch(经过CONTROL_ TOUCH_ EVENT_ INTENT, CONTROL_ OBJECT_ CLICK_ EVENT_ INTENT, CONTROL_ LIST_ ITEM_ CLICK_ INTENT或者ControlExtension.onTouch()方法)和swipe手势(经过CONTROL_ SWIPE_ EVENT_ INTENT 或者 ControlExtension.onSwipe()方法)。
当使用布局来绘制时,一屏上同时能够显示的View最多为50个。