当前位置: 首页 > news >正文

第二十三天 实践分布式软总线,实现两个设备之间的简单通信

初学HarmonyOS:实践分布式软总线,实现设备间简单通信

引言

随着物联网技术的快速发展,设备之间的通信变得越来越重要。HarmonyOS作为华为推出的分布式操作系统,提供了强大的分布式能力,尤其是分布式软总线技术,能够轻松实现设备间的通信。本文将从初学者的角度出发,带你一步步学习如何使用HarmonyOS的分布式软总线,实现两个设备之间的简单通信。

什么是分布式软总线?

分布式软总线是HarmonyOS的核心技术之一,它允许设备在局域网内自动发现、连接和通信。通过分布式软总线,设备可以像在同一个总线上一样进行数据交换,而无需关心底层的网络细节。这种技术非常适合用于智能家居、智能办公等场景。

环境准备

在开始之前,我们需要准备好开发环境:

  1. 安装DevEco Studio:这是HarmonyOS的官方开发工具,支持代码编写、调试和模拟器运行。
  2. 创建HarmonyOS项目:在DevEco Studio中创建一个新的HarmonyOS项目,选择“Empty Ability”模板。
  3. 准备两台设备:可以是两台手机,或者一台手机和一台模拟器。

项目结构

在DevEco Studio中创建的项目结构如下:

MyApplication
│
├── entry
│   └── src
│       └── main
│           ├── java
│           │   └── com.example.myapplication
│           │       ├── MainAbility.java
│           │       └── MyApplication.java
│           └── resources
│               └── base
│                   ├── layout
│                   │   └── ability_main.xml
│                   └── element
│                       └── string.json
└── build.gradle

实现设备发现

首先,我们需要实现设备的自动发现功能。HarmonyOS提供了DeviceManager类来管理设备发现和连接。

1. 添加权限

config.json中添加以下权限:

{
  "module": {
    "reqPermissions": [
      {
        "name": "ohos.permission.DISTRIBUTED_DATASYNC"
      }
    ]
  }
}

2. 初始化DeviceManager

MainAbility.java中初始化DeviceManager

import ohos.distributedschedule.interwork.DeviceManager;
import ohos.distributedschedule.interwork.DeviceInfo;

public class MainAbility extends Ability {
    private DeviceManager deviceManager;

    @Override
    public void onStart(Intent intent) {
        super.onStart(intent);
        deviceManager = DeviceManager.getInstance();
        discoverDevices();
    }

    private void discoverDevices() {
        List<DeviceInfo> deviceInfos = deviceManager.getDeviceList(DeviceInfo.FLAG_GET_ALL_DEVICE);
        for (DeviceInfo deviceInfo : deviceInfos) {
            System.out.println("发现设备: " + deviceInfo.getDeviceName());
        }
    }
}

3. 运行代码

运行代码后,你会在控制台看到发现的设备列表。如果没有发现设备,请确保两台设备在同一个局域网内。

实现设备间通信

设备发现后,我们可以通过分布式软总线实现设备间的通信。HarmonyOS提供了DistributedDataManager类来管理分布式数据。

1. 添加依赖

build.gradle中添加以下依赖:

dependencies {
    implementation 'ohos:distributedschedule:1.0.0'
}

2. 发送数据

MainAbility.java中实现发送数据的功能:

import ohos.distributedschedule.interwork.DistributedDataManager;
import ohos.distributedschedule.interwork.DeviceInfo;

public class MainAbility extends Ability {
    private DistributedDataManager distributedDataManager;

    @Override
    public void onStart(Intent intent) {
        super.onStart(intent);
        distributedDataManager = DistributedDataManager.getInstance();
        sendData();
    }

    private void sendData() {
        DeviceInfo deviceInfo = deviceManager.getDeviceList(DeviceInfo.FLAG_GET_ALL_DEVICE).get(0);
        String data = "Hello, Device!";
        distributedDataManager.sendData(deviceInfo.getDeviceId(), data.getBytes(), new DistributedDataManager.DataCallback() {
            @Override
            public void onSuccess() {
                System.out.println("数据发送成功");
            }

            @Override
            public void onFailure(int errorCode) {
                System.out.println("数据发送失败,错误码: " + errorCode);
            }
        });
    }
}

3. 接收数据

在另一台设备上实现接收数据的功能:

import ohos.distributedschedule.interwork.DistributedDataManager;

public class MainAbility extends Ability {
    private DistributedDataManager distributedDataManager;

    @Override
    public void onStart(Intent intent) {
        super.onStart(intent);
        distributedDataManager = DistributedDataManager.getInstance();
        receiveData();
    }

    private void receiveData() {
        distributedDataManager.registerDataListener(new DistributedDataManager.DataListener() {
            @Override
            public void onDataReceived(String deviceId, byte[] data) {
                String receivedData = new String(data);
                System.out.println("接收到数据: " + receivedData);
            }
        });
    }
}

4. 运行代码

运行代码后,发送数据的设备会将数据发送到接收数据的设备,接收设备会在控制台打印出接收到的数据。

总结

通过本文的学习,你应该已经掌握了如何使用HarmonyOS的分布式软总线实现设备间的简单通信。我们从设备发现开始,逐步实现了数据的发送和接收。希望这篇文章能够帮助你快速入门HarmonyOS的分布式开发。

下一步

如果你对HarmonyOS的分布式开发感兴趣,可以继续学习以下内容:

  1. 分布式任务调度:了解如何在多个设备间调度任务。
  2. 分布式数据管理:深入学习如何在多个设备间同步数据。
  3. 分布式UI:探索如何在多个设备间共享UI组件。

参考文档

  • HarmonyOS官方文档
  • DevEco Studio使用指南
  • 分布式软总线技术详解

希望这篇文章对你有所帮助,祝你在HarmonyOS的学习和开发中取得更多进展!

相关文章:

  • 通过Nginx负载均衡+Keepalived实现业务高可用
  • Unity:使用DoTween实现按钮的缩放
  • Ubuntu 22.04 安装Nvidia驱动加速deepseek
  • 大模型RAG中的retrieve策略
  • AE 安装包 绿色版(Win,Mac)(2018-2025)合集
  • conda env remove与conda remove
  • RuoYi使用$.modal.closeTab方法关闭当前tab标签页刷新另外一个tab标签页
  • Python毕业设计选题:基于Python的社区爱心养老管理系统设计与实现_django
  • 国漫工业化革命:AI如何让“一人团队”产出影视级动画?
  • Bend Labs弯曲传感器:柔性设计,多轴测量,高精度传感
  • 时间无关和时间相关的N-S方程
  • 凸函数和凹函数的定义怎么来的?
  • openssl的aes128_ECB加密解密运算实例
  • 【精】使用 Apktool 反编译 APK 并重新签名的详细教程
  • 工具MyBatis Generator(MBG)
  • 网页聊天室测试报告
  • ubuntu下r8125网卡重启丢失修复案例一则
  • 使用 Java 更新 Word 文档中的图表数据-超详细
  • Qt 对象树详解:从原理到运用
  • 多线程之旅:锁策略
  • 荣成网站建设/搜索引擎营销的作用