Android Wear数据层资源传输详解 - 基于kesenhoo/android-training-course-in-chinese项目

Android Wear数据层资源传输详解 - 基于kesenhoo/android-training-course-in-chinese项目

android-training-course-in-chinese Android官方培训课程中文版 android-training-course-in-chinese 项目地址: https://gitcode.com/gh_mirrors/an/android-training-course-in-chinese

概述

在Android Wear开发中,资源(Assets)传输是实现可穿戴设备与手持设备间大数据交换的关键技术。本文将深入讲解如何在Android Wear应用中使用Assets进行高效的数据传输,包括资源创建、发送和接收的全过程。

为什么需要资源传输

在可穿戴设备与手持设备通信时,我们经常需要传输图片等二进制数据。直接传输这些数据会面临以下挑战:

  1. 蓝牙带宽有限,大文件传输效率低
  2. 重复传输相同内容浪费资源
  3. 数据元大小限制(100KB)

Android Wear提供的Asset机制完美解决了这些问题,它能够:

  • 自动缓存数据避免重复传输
  • 支持大文件传输
  • 优化蓝牙带宽使用

资源创建与发送

创建Asset对象

将Bitmap转换为Asset的标准方法:

private static Asset createAssetFromBitmap(Bitmap bitmap) {
    final ByteArrayOutputStream byteStream = new ByteArrayOutputStream();
    bitmap.compress(Bitmap.CompressFormat.PNG, 100, byteStream);
    return Asset.createFromBytes(byteStream.toByteArray());
}

关键点:

  • 使用PNG格式压缩保证图片质量
  • ByteArrayOutputStream将Bitmap转为字节流
  • createFromBytes()方法创建Asset对象

发送Asset的两种方式

1. 使用PutDataRequest直接发送
// 从资源加载Bitmap
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.image);
// 创建Asset
Asset asset = createAssetFromBitmap(bitmap);
// 创建数据请求
PutDataRequest request = PutDataRequest.create("/image");
// 添加Asset
request.putAsset("profileImage", asset);
// 发送数据
Wearable.DataApi.putDataItem(mGoogleApiClient, request);
2. 使用PutDataMapRequest发送
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.image);
Asset asset = createAssetFromBitmap(bitmap);
// 创建数据映射请求
PutDataMapRequest dataMap = PutDataMapRequest.create("/image");
// 将Asset放入数据映射
dataMap.getDataMap().putAsset("profileImage", asset)
// 转换为数据请求并发送
PutDataRequest request = dataMap.asPutDataRequest();
PendingResult<DataApi.DataItemResult> pendingResult = Wearable.DataApi
        .putDataItem(mGoogleApiClient, request);

两种方式的区别:

  • PutDataRequest更直接简单
  • PutDataMapRequest适合需要传输多个数据项的场景
  • 最终都是通过putDataItem()方法发送

接收与处理资源

监听数据变化

@Override
public void onDataChanged(DataEventBuffer dataEvents) {
  for (DataEvent event : dataEvents) {
    // 检查事件类型和路径
    if (event.getType() == DataEvent.TYPE_CHANGED &&
        event.getDataItem().getUri().getPath().equals("/image")) {
      // 从事件中获取数据映射项
      DataMapItem dataMapItem = DataMapItem.fromDataItem(event.getDataItem());
      // 提取Asset对象
      Asset profileAsset = dataMapItem.getDataMap().getAsset("profileImage");
      // 将Asset转换为Bitmap
      Bitmap bitmap = loadBitmapFromAsset(profileAsset);
      // 使用Bitmap更新UI等操作
    }
  }
}

将Asset转换为Bitmap

public Bitmap loadBitmapFromAsset(Asset asset) {
    if (asset == null) {
        throw new IllegalArgumentException("Asset必须非空");
    }
    
    // 建立Google API客户端连接
    ConnectionResult result = mGoogleApiClient.blockingConnect(TIMEOUT_MS, TimeUnit.MILLISECONDS);
    if (!result.isSuccess()) {
        return null;
    }
    
    // 获取Asset的输入流
    InputStream assetInputStream = Wearable.DataApi.getFdForAsset(
            mGoogleApiClient, asset).await().getInputStream();
    mGoogleApiClient.disconnect();

    if (assetInputStream == null) {
        Log.w(TAG, "请求了未知的Asset");
        return null;
    }
    
    // 将输入流解码为Bitmap
    return BitmapFactory.decodeStream(assetInputStream);
}

关键注意事项:

  1. 必须检查Asset是否为null
  2. 需要先建立GoogleApiClient连接
  3. 使用getFdForAsset()获取输入流
  4. 记得断开连接释放资源
  5. 处理可能的null输入流情况

最佳实践建议

  1. 图片优化:在传输前将图片调整为适合可穿戴设备屏幕的尺寸
  2. 错误处理:添加适当的异常处理和日志记录
  3. 性能考虑:大文件传输可能影响用户体验,需进行充分测试
  4. 资源释放:及时关闭流和断开连接
  5. 路径命名:使用有意义的路径名称便于维护

总结

通过本文,我们详细了解了Android Wear数据层中资源传输的完整流程。Asset机制为可穿戴设备与手持设备间的大数据交换提供了高效可靠的解决方案。掌握这些技术后,开发者可以轻松实现图片等二进制数据在设备间的传输,为用户提供更丰富的可穿戴体验。

android-training-course-in-chinese Android官方培训课程中文版 android-training-course-in-chinese 项目地址: https://gitcode.com/gh_mirrors/an/android-training-course-in-chinese

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

施谨贞Des

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值