编写:wly2014 - 原文: http://developer.android.com/training/wearables/data-layer/data-items.html
DataItem是指系统用于同步手持设备与可穿戴设备间数据的接口。一个DataItem通常包括以下几点:
Pyload - 一个字节数组,我们可以用来设置任何数据,让我们的对象序列化和反序列化。Pyload的大小限制在100k之内。
Path - 唯一且以前斜线开头的字符串(如:"/path/to/data")。
通常不直接实现DataItem,而是:
然而,我们建议使用Data Map来显示装在一个易用的类似Bundle接口中的数据元,而不是用setData()来处理原始字节。
使用DataMap类,将数据元处理为 Android Bundle的形式,因此会完成对象的序列化和反序列化,我们就可以以键值对(key-value)的形式操纵数据。
如何使用data map:
Note: 数据元的路径字符串是唯一确定的,这样能够使我们从连接任意一端访问数据元。路径须以前斜线开始。如果我们想在应用中使用分层数据,就要创建一个适合数据结构的路径方案。
Note: 如果手机和可穿戴设备没有连接,数据会缓冲并在重新建立连接时同步。
接下的例子中的increaseCounter()方法展示了如何创建一个data map,并设置数据:
increaseCounter()
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; ... // Create a data map and put data in it 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 。
如果数据层连接的一端数据发生改变,我们很可能想要被告知在连接的另一端发生的任何改变。我们可以通过实现一个数据元事件的监听器来完成。
当定义在上一个例子中的counter的值发生改变时,下面例子的代码片段能够通知我们的app。
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 接口。该activity在onConnected()方法中增加自身成为数据元事件的监听器,并在onPause()方法中移除监听器。
onConnected()
onPause()
我们也可以用一个service实现监听,请见 监听数据层事件。
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8