DataItem
رابطی را تعریف می کند که سیستم برای همگام سازی داده ها بین گوشی های دستی و پوشیدنی ها استفاده می کند. یک DataItem
به طور کلی از اجزای زیر تشکیل شده است:
- Payload: یک آرایه بایتی که میتوانید با دادهها تنظیم کنید و به شما امکان میدهد سریالسازی و سریالزدایی اشیاء خود را انجام دهید. حجم محموله به 100 کیلوبایت محدود شده است.
- Path: یک رشته منحصر به فرد که باید با یک اسلش رو به جلو شروع شود، مانند
"/path/to/data"
.
توجه: Data Layer API فقط میتواند پیام ارسال کند و دادهها را با تلفنهای Android یا ساعتهای Wear OS همگامسازی کند. اگر دستگاه Wear OS شما با دستگاه iOS جفت شده باشد، Data Layer API کار نخواهد کرد.
به همین دلیل، از API لایه داده به عنوان راه اصلی برای برقراری ارتباط با شبکه استفاده نکنید. در عوض، از همان الگوی یک برنامه تلفن همراه پیروی کنید، با برخی تفاوتهای جزئی .
شما معمولاً DataItem
مستقیماً پیاده سازی نمی کنید. در عوض، کارهای زیر را انجام دهید:
- یک شی
PutDataRequest
ایجاد کنید، یک مسیر رشته ای را برای شناسایی منحصر به فرد مورد مشخص کنید. - برای تنظیم payload
setData()
را فراخوانی کنید. - اگر تاخیر در همگامسازی بر تجربه کاربر تأثیر منفی میگذارد،
setUrgent()
را فراخوانی کنید. - از متد
putDataItem
از کلاسDataClient
برای درخواست از سیستم استفاده کنید تا آیتم داده را ایجاد کند.
هنگام درخواست اقلام داده، سیستم اشیایی را برمی گرداند که رابط DataItem
را به درستی پیاده سازی می کنند. با این حال، بهجای کار با بایتهای خام با استفاده از setData()
، توصیه میکنیم از نقشه داده استفاده کنید، که یک آیتم داده را با یک رابط Bundle
مانند نمایش میدهد.
برای اطلاعات بیشتر، به برنامه DataLayer Sample مراجعه کنید.
همگام سازی داده ها با نقشه داده
در صورت امکان از کلاس DataMap
استفاده کنید. این رویکرد به شما امکان میدهد با اقلام داده در قالب Android Bundle
کار کنید، بنابراین سیستم سریالسازی و سریالزدایی اشیاء را برای شما انجام میدهد و میتوانید دادهها را با جفتهای کلید-مقدار دستکاری کنید.
برای استفاده از نقشه داده:
- با تنظیم مسیر مورد داده، یک شی
PutDataMapRequest
ایجاد کنید.توجه: رشته مسیر یک شناسه منحصر به فرد برای آیتم داده است که به شما امکان می دهد از هر طرف اتصال به آن دسترسی داشته باشید. مسیر باید با یک اسلش رو به جلو شروع شود. اگر از داده های سلسله مراتبی در برنامه خود استفاده می کنید، یک طرح مسیر ایجاد کنید که با ساختار داده ها مطابقت داشته باشد.
- برای بدست آوردن نقشه داده ای که می توانید مقادیر را روی آن تنظیم کنید
PutDataMapRequest.getDataMap()
را فراخوانی کنید. - با استفاده از متدهای
put...()
مانندputString()
مقادیر را برای نقشه داده تنظیم کنید. - اگر تاخیر در همگامسازی بر تجربه کاربر تأثیر منفی میگذارد،
setUrgent()
را فراخوانی کنید. - برای بدست آوردن یک شی
PutDataRequest
PutDataMapRequest.asPutDataRequest()
را فراخوانی کنید. - از متد
putDataItem
از کلاسDataClient
برای درخواست از سیستم استفاده کنید تا آیتم داده را ایجاد کند.توجه: اگر اتصال گوشی و دستگاههای پوشیدنی قطع شده باشد، پس از برقراری مجدد اتصال، دادهها بافر میشوند و همگامسازی میشوند.
متد increaseCounter()
در مثال زیر نحوه ایجاد نقشه داده و قرار دادن داده ها در آن را نشان می دهد:
کاتلین
private const val COUNT_KEY = "com.example.key.count" class MainActivity : Activity() { private lateinit var dataClient: DataClient private var count = 0 ... // Create a data map and put data in it private fun increaseCounter() { val putDataReq: PutDataRequest = PutDataMapRequest.create("/count").run { dataMap.putInt(COUNT_KEY, count++) asPutDataRequest() } val putDataTask: Task<DataItem> = dataClient.putDataItem(putDataReq) } ... }
جاوا
public class MainActivity extends Activity { private static final String COUNT_KEY = "com.example.key.count"; private DataClient dataClient; 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(); Task<DataItem> putDataTask = dataClient.putDataItem(putDataReq); } ... }
برای اطلاعات بیشتر در مورد رسیدگی به Tasks
، به مستندات مرجع مراجعه کنید.
اولویت DataItem را تنظیم کنید
DataClient
API به درخواست های فوری برای همگام سازی اشیاء DataItem
اجازه می دهد. به طور معمول، سیستم تحویل اقلام داده به شبکه Wear OS را به تاخیر می اندازد تا عمر باتری دستگاه های کاربر را بهبود بخشد، اما اگر تأخیر در همگام سازی اقلام داده بر تجربه کاربر تأثیر منفی بگذارد، می توانید آنها را به عنوان فوری علامت گذاری کنید. به عنوان مثال، در یک برنامه کنترل از راه دور که در آن کاربر انتظار دارد اقداماتش فوراً منعکس شود، میتوانید با فراخوانی setUrgent()
از سیستم بخواهید موارد داده شما را فوراً همگامسازی کند.
اگر setUrgent()
فراخوانی نکنید، ممکن است سیستم تا 30 دقیقه قبل از همگام سازی موارد داده غیر فوری تاخیر کند، اگرچه معمولاً می توانید انتظار داشته باشید که تاخیر فقط چند دقیقه باشد. فوریت پیشفرض غیر فوری است، بنابراین اگر نیاز به حفظ رفتار همگامسازی فوری از نسخههای قبلی Wear OS API دارید، باید از setUrgent()
استفاده کنید.
به رویدادهای مورد داده گوش دهید
اگر یک طرف اتصال لایه داده یک مورد داده را تغییر داد، هر گونه تغییر در طرف دیگر اتصال را به کاربر اطلاع دهید. می توانید این کار را با پیاده سازی شنونده برای رویدادهای مورد داده انجام دهید.
قطعه کد در مثال زیر زمانی که مقدار شمارنده تعریف شده در مثال قبلی تغییر می کند، برنامه را مطلع می کند:
کاتلین
private const val COUNT_KEY = "com.example.key.count" class MainActivity : Activity(), DataClient.OnDataChangedListener { private var count = 0 override fun onResume() { super.onResume() Wearable.getDataClient(this).addListener(this) } override fun onPause() { super.onPause() Wearable.getDataClient(this).removeListener(this) } override fun onDataChanged(dataEvents: DataEventBuffer) { dataEvents.forEach { event -> // DataItem changed if (event.type == DataEvent.TYPE_CHANGED) { event.dataItem.also { item -> if (item.uri.path.compareTo("/count") == 0) { DataMapItem.fromDataItem(item).dataMap.apply { updateCount(getInt(COUNT_KEY)) } } } } else if (event.type == DataEvent.TYPE_DELETED) { // DataItem deleted } } } // Method to update the count private fun updateCount(int: Int) { ... } ... }
جاوا
public class MainActivity extends Activity implements DataClient.OnDataChangedListener { private static final String COUNT_KEY = "com.example.key.count"; private int count = 0; @Override protected void onResume() { super.onResume(); Wearable.getDataClient(this).addListener(this); } @Override protected void onPause() { super.onPause(); Wearable.getDataClient(this).removeListener(this); } @Override public void onDataChanged(DataEventBuffer dataEvents) { for (DataEvent event : dataEvents) { if (event.getType() == DataEvent.TYPE_CHANGED) { // DataItem changed 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 deleted } } } // Method to update the count private void updateCount(int c) { ... } ... }
این فعالیت رابط DataClient.OnDataChangedListener
را پیاده سازی می کند. اکتیویتی خود را به عنوان شنونده رویدادهای آیتم داده در متد onResume()
اضافه می کند و شنونده را در متد onPause()
حذف می کند. برای مشاهده پیاده سازی با استفاده از تصاویر، مشاهده مدل ها و خدمات، به برنامه DataLayer Sample مراجعه کنید.
همچنین می توانید شنونده را به عنوان یک سرویس پیاده سازی کنید. برای اطلاعات بیشتر، گوش دادن به رویدادهای لایه داده را ببینید.