# 同步数据单元
编写:wly2014 - 原文: http://developer.android.com/training/wearables/data-layer/data-items.html
DataItem是指系统用于同步手持设备与可穿戴设备间数据的接口。一个DataItem通常包括以下几点:
Pyload- 一个字节数组,你可以用来设置任何数据,让你的object序列化和反序列化。Pyload的大小限制在100k之内。
Path- 唯一且以前斜线开头的string (如:"/path/to/data")。
通常不直接实现DataItem,而是:
然而,我们建议使用Data Map来显示装在一个易用的类似Bundle接口中的数据元,而用不是setData()来处理原始字节。
使用DataMap类,将数据元处理为 Android Bundle的形式,因此对象的序列化和反序列化就会完成,你就可以以 key-value 对的形式操纵数据。
如何使用:
Note: path 字符串对数据元是唯一确定的,这样能够使你从另一连接端访问。Path须以前斜线开始。如果你想在应用中使用分层数据,就要创建一个适合数据结构的路径方案。
Note: 如果手机和可穿戴设备没有连接,数据会缓冲并在重新建立连接时同步。
接下的例子中的increaseCounter()方法展示了如何创建一个data map,并设置数据:
public class MainActivity extends Activity implements
DataApi.DataListener,
GoogleApiClient.ConnectionCallbacks,
GoogleApiClient.OnConnectionFailedListener {
private static final String COUNT_KEY = "com.example.key.count";
private GoogleApiClient mGoogleApiClient;
private int count = 0;
...
// 创建一个 data map 并设置数据
private void increaseCounter() {
PutDataMapRequest putDataMapReq = PutDataMapRequest.create("/count");
putDataMapReq.getDataMap().putInt(COUNT_KEY, count++);
PutDataRequest putDataReq = putDataMapReq.asPutDataRequest();
PendingResult<DataApi.DataItemResult> pendingResult =
Wearable.DataApi.putDataItem(mGoogleApiClient, putDataReq);
}
...
}
有关控制 PendingResult 对象的更多信息,请参见 Wait for the Status of Data Layer Calls 。
如果一端的数据层的数据发生改变,想要在另一端被告知此改变,你可以通过实现一个数据元事件的监听器来完成。
下面例子的代码片段能够通知你的app,当定义在上一个例子中的counter的值发生改变时。
public class MainActivity extends Activity implements
DataApi.DataListener,
GoogleApiClient.ConnectionCallbacks,
GoogleApiClient.OnConnectionFailedListener {
private static final String COUNT_KEY = "com.example.key.count";
private GoogleApiClient mGoogleApiClient;
private int count = 0;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addApi(Wearable.API)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.build();
}
@Override
protected void onResume() {
super.onStart();
mGoogleApiClient.connect();
}
@Override
public void onConnected(Bundle bundle) {
Wearable.DataApi.addListener(mGoogleApiClient, this);
}
@Override
protected void onPause() {
super.onPause();
Wearable.DataApi.removeListener(mGoogleApiClient, this);
mGoogleApiClient.disconnect();
}
@Override
public void onDataChanged(DataEventBuffer dataEvents) {
for (DataEvent event : dataEvents) {
if (event.getType() == DataEvent.TYPE_CHANGED) {
// DataItem 改变了
DataItem item = event.getDataItem();
if (item.getUri().getPath().compareTo("/count") == 0) {
DataMap dataMap = DataMapItem.fromDataItem(item).getDataMap();
updateCount(dataMap.getInt(COUNT_KEY));
}
} else if (event.getType() == DataEvent.TYPE_DELETED) {
// DataItem 删除了
}
}
}
// 我们的更新 count 的方法
private void updateCount(int c) { ... }
...
}
这个activity是实现了 DataItem.DataListener 接口,并在onConnected()方法中增加自身成为数据元事件的监听者,和在onPause()方法中移除监听。
你也可以用一个service实现监听,请见 Listening for Data Layer Events。