news 2026/6/10 15:31:42

从零跑起 RokidDemo:开发小白也能搞定的入门实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
从零跑起 RokidDemo:开发小白也能搞定的入门实践

真正连在一起、做互动、做协同的基线工程。你能在它里边看到:

扫描发现 Rokid 眼镜,并完成蓝牙连接与鉴权

拉取眼镜的状态(电量、音量、亮度、充电)并在手机端展示与调节

打开眼镜相机拍照并把图片回传到手机端保存与入库

下发自定义界面到眼镜端(比如弹出一个文字提示)

发送全局消息/TTS 反馈

模拟遥控器按键,通过 HID 报文控制眼镜(方向、返回、音量)

把这些交互过程写入数据库,能分页查看记录

一句话:它就是你要做“手机+眼镜”协同应用时的起跑线。项目代码地址已经在github上了,这里感谢作者的代码样例:https://github.com/StudiousXiaoYu/RokidDemo

安装环境(Windows)#

这个环节很关键,基本所有“构建失败”“设备不识别”的坑都和环境有关。

安装Kotlin#

由于整个项目代码环境是Kotlin环境,我们先本地IDE中安装好相关插件。

image

安装 Android Studio 和 OpenJDK 11#

查看是否有安装环境

winget search --source winget Android | Select-String -Pattern "Android Studio|SDK|Platform Tools|OpenJDK"

image

安装OpenJDK.11

winget install -e --id Microsoft.OpenJDK.11 --accept-source-agreements --accept-package-agreements

image

安装AndroidStudio

winget install -e --id Google.AndroidStudio --accept-source-agreements --accept-package-agreements

image

安装PlatformTools

winget install -e --id Google.PlatformTools --accept-source-agreements --accept-package-agreements

image

自此基本环境就安装完成了。

安装 Android SDK 组件#

确保安装这些:

Android SDK Platform 36(匹配项目 compileSdk 36)

Android SDK Build-Tools 35(或兼容版本)

Android SDK Platform-Tools(包含 adb)

Android SDK Command-line Tools (latest)(方便命令行管理)

启动Android SDK Studio后,我们进入设置页找到“SDK Tools”,找到相关的工具,点击下载即可,如图所示:

image

真机调试准备#

手机开启“开发者选项”和“USB 调试”。

image

第一次连接时,手机会弹窗问是否允许 USB 调试,请选择允许并勾选“始终允许”。

Windows 某些设备会缺驱动,装 Google USB Driver。确保终端输入 adb devices 能看到设备。

项目技术细节#

这一节把工程先跑起来,跟着做就能过构建。 先做三步:设置 local.properties → 添加 Rokid 仓库 → 引入 client-m 依赖。

项目根目录有 local.properties,需要把 sdk.dir 指向你机器的 Android SDK 路径(常见是 C:\Users\你的用户名\AppData\Local\Android\Sdk)。

image

sdk.dir=C:\Users\yu\AppData\Local\Android\Sdk

仓库与依赖(Gradle)

在顶层加仓库,在模块里加依赖,然后点 Gradle Sync。

// settings.gradle

pluginManagement {

repositories {

gradlePluginPortal()

google()

mavenCentral()

maven { url 'https://maven.rokid.com/repository/maven-public' }

}

}

dependencyResolutionManagement {

repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)

repositories {

google()

mavenCentral()

maven { url 'https://maven.rokid.com/repository/maven-public' }

}

}

// app/build.gradle

android {

defaultConfig {

minSdk = 28

}

}

dependencies {

implementation("com.rokid.cxr:client-m:1.0.1-20250812.080117-2")

}

检查:sdk.dir 路径有效,依赖能解析,Sync 无报错。

Manifest 权限与特性(Android 12+)#

先把这些权限加到 AndroidManifest.xml,Android 12+ 还需要在运行时申请。

<uses-feature android:name="android.hardware.bluetooth_le" android:required="true" />

<uses-permission android:name="android.permission.BLUETOOTH" />

<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />

<uses-permission android:name="android.permission.BLUETOOTH_CONNECT" />

<uses-permission android:name="android.permission.BLUETOOTH_SCAN" />

<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" android:maxSdkVersion="30" />

<uses-permission android:name="android.permission.READ_MEDIA_IMAGES" />

<uses-permission android:name="android.permission.POST_NOTIFICATIONS" />

蓝牙相关权限在连接前先申请;前台服务能避免进程被系统回收。

构建与安装#

现在把包编译到真机上。 前置条件:adb devices 显示设备为 device。

windows的命令脚本已经在项目里了。

构建 Debug 包:

.\gradlew.bat assembleDebug -x lint

安装到设备:

.\gradlew.bat installDebug

启动入口 Activity:

adb shell am start -n com.blue.armobile/com.blue.glassesapp.feature.init.InitActivity

首次进入会弹权限提示,请授予存储与通知权限以免初始化阻塞。

image

添加相关的权限后,我们就可以正常进入手机端的应用界面了,如图所示:

image

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 14:58:46

网络安全到底要怎么学?这份3个月上岸攻略,已经帮500+小白

网络安全学习宝典&#xff1a;3个月入门VS半年挣扎&#xff0c;收藏这份高效学习法&#xff0c;少走弯路&#xff01; 文章系统化呈现了网络安全高效学习路线&#xff0c;从理论知识、渗透测试基础、操作系统、网络协议到Web渗透&#xff0c;强调编程能力是"脚本小子&quo…

作者头像 李华
网站建设 2026/6/10 13:21:57

如何使用openCustomDialog禁止手势关闭的实现方案?提供源码和方案思路

如何使用openCustomDialog禁止手势关闭的实现方案?提供源码和方案思路 一、结论 要实现禁止手势 / 外部点击关闭弹窗,核心依赖两个关键配置: 1、autoCancel 参数: 控制点击弹窗外部遮障层是否触发关闭,设置为 false 可直接禁用该关闭方式。 **2、onWillDismiss 回调: *…

作者头像 李华
网站建设 2026/6/10 14:51:32

电商秒杀系统实战:Redisson分布式锁的最佳实践

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个电商秒杀场景下的Redisson分布式锁应用示例。要求&#xff1a;1. 模拟商品库存扣减场景 2. 实现不同粒度的锁控制&#xff08;商品ID级别和用户ID级别&#xff09; 3. 处理…

作者头像 李华
网站建设 2026/6/9 18:31:41

华为登顶全球腕戴市场,智能手表行业主数据管理解析

12月17日&#xff0c;国际权威市场研究机构IDC发布了最新一期《全球可穿戴设备市场季度跟踪报告》。数据显示&#xff0c;华为在2025年前三季度以显著优势稳居全球腕戴设备出货量榜首&#xff0c;不仅在中国市场出货量高达2080万台、同比增长27%&#xff0c;更在全球范围内持续…

作者头像 李华
网站建设 2026/6/10 14:56:09

Spring Boot 集成分析

1. 工程结构概览Spring AI 通过 Spring Boot Starter 和 Auto Configuration 机制&#xff0c;实现了零配置的 AI 应用开发。开发者只需要添加依赖和配置属性&#xff0c;就能使用各种 AI 能力。spring-ai-spring-boot-starters/ # Starter 模块├── spring-ai-starter-model…

作者头像 李华
网站建设 2026/6/10 14:55:11

4、命令行解析与扩展及变量相关知识详解

命令行解析与扩展及变量相关知识详解 1. 命令行解析与扩展 在命令行操作中,有多种解析和扩展机制,这些机制能极大地提高操作效率和灵活性。 1.1 引号内参数换行 引号内的参数可以包含换行符。例如: $ sa "Argument containing ⏎ > a newline" :Argument…

作者头像 李华