基于ADB Shell 实现的 Android TV、电视盒子万能遥控器 — ADB Remote ATV

ADB Remote ATV

Android TV 的遥控器,基于 ADB Shell 命令

ADB Remote ATV 是一个 Android TV 的遥控器,基于 ADB Shell 命令,泛用性更高。

下面的 shell 命令,是软件的基本原理,通过 shell 命令可模拟物理遥控器的基本按键,此外还可以快捷启动指定APP、借助手机软键盘输入中/英字符等。

# 输入事件
adb shell input text <string> # 向设备输入字符
adb shell input keyevent <key_code> # 向设备输入按键事件
# 启动软件
adb shell am start <package/activity>	# 启动设备上的软件
shell ime set <app>	# 切换输入法
shell settings get secure default_input_method	# 获取当前输入法

软件功能

按键

对于的 shell 命令如下:

adb shell input keyevent <key_code> # 向设备输入按键事件

其中的 keycode如下表:

功能字符常量数字键值
返回键KEYCODE_BACK4
按键HomeKEYCODE_HOME3
菜单键KEYCODE_MENU82
扬声器静音键KEYCODE_VOLUME_MUTE164
音量增加键KEYCODE_VOLUME_UP24
音量减小键KEYCODE_VOLUME_DOWN25
导航键 向上KEYCODE_DPAD_UP19
导航键 向下KEYCODE_DPAD_DOWN20
导航键 向左KEYCODE_DPAD_LEFT21
导航键 向右KEYCODE_DPAD_RIGHT22
导航键 确定键KEYCODE_DPAD_CENTER23
数字按键KEYCODE_0 - KEYCODE_97 - 16
退格键KEYCODE_DEL67
TV 键KEYCODE_TV170
电源键KEYCODE_TV_POWER177
多媒体键 播放/暂停KEYCODE_MEDIA_PLAY_PAUSE85
多媒体键 快进KEYCODE_MEDIA_FAST_FORWARD95
多媒体键 快退KEYCODE_MEDIA_REWIND89
多媒体键 上一首KEYCODE_MEDIA_PREVIOUS88
多媒体键 下一首KEYCODE_MEDIA_NEXT87

字符输入

支持中/英字符,借助手机软键盘将字符输入到 Android TV 中。注意中文字符需要ADBKeyboard支持。

英文字符的 shell 命令如下:

shell input text <string> # 向设备输入按键事件

中文字符的 shell 命令如下,需要ADBKeyboard的支持:

shell am start -a android.intent.action.VIEW -d <string>

切换输入法命令如下:

shell ime set <app>
# 例如
shell ime set com.android.adbkeyboard/.AdbIME # 切换到ADBKeyboard

获取当前输入法:

shell settings get secure default_input_method

快捷启动

下图是一些可快速启动的软件

对应的 shell 命令如下:

shell am start <package/activity> # 向设备输入按键事件
# 例如
shell am start com.github.tvbox.osc/.ui.activity.HomeActivity	# 启动TVBox

快捷启动软件可从软件仓库中添加,仓库从在线地址中解析,该 json 文件为项目根目录中的apps.json。例如

[
 {
 "name": "TVBox",
 "icon": "https://raw.githubusercontent.com/SX-Code/ADBRemoteATV/main/icons/tvbox.png",
 "url": "com.github.tvbox.osc/.ui.activity.HomeActivity"
 },
 {
 "name": "TVBox UI美化版",
 "icon": "https://raw.githubusercontent.com/SX-Code/ADBRemoteATV/main/icons/tvbox.png",
 "url": "com.github.tvbox.osc.tk/com.github.tvbox.osc.ui.activity.HomeActivity"
 },
]

其中:

  • name:为该软件的名称
  • icon:为该软件的图标,便于展示
  • url:为该软件的启动路径。格式参考com.github.tvbox.osc/.ui.activity.HomeActivity

如何获取一个 APP 的启动路径,可从该软件的 AndroidManifest.xml 文件中获取,下面是一个示例文件,

  • manifest标签中找到package属性,为启动路径的包 package
  • 从带有LAUNCHERactivity中找到android:name属性,为启动路径的 activity
  • package/activity组合起来就是启动命令的路径参数。
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
 android:compileSdkVersion="33" 
 android:compileSdkVersionCodename="13" 
 package="tech.simha.androidtvremote" 
 platformBuildVersionCode="33" platformBuildVersionName="13">
 
 <application 
 android:appComponentFactory="androidx.core.app.CoreComponentFactory" 
 android:hardwareAccelerated="true" 
 android:icon="@mipmap/launcher_icon" 
 android:label="Remote ATV" 
 android:name="android.app.Application">
 
 <activity 
 android:exported="true" 
 android:hardwareAccelerated="true" 
 android:launchMode="singleTop" 
 android:name="tech.simha.androidtvremote.MainActivity" 
 android:screenOrientation="portrait" 
 android:theme="@style/LaunchTheme" 
 android:windowSoftInputMode="adjustResize">
 <intent-filter>
 <action android:name="android.intent.action.MAIN"/>
 <category android:name="android.intent.category.LAUNCHER"/>
 </intent-filter>
 </activity>
 </application>
</manifest>

软件界面

项目地址

Gitee:https://gitee.com/SX-Code/ADBRemoteATV
Github: https://github.com/SX-Code/ADBRemoteATV

鸣谢

ADBlibhttps://github.com/cgutman/AdbLib

ADBKeyboardhttps://github.com/senzhk/ADBKeyBoard?tab=readme-ov-file

圆形菜单按键https://github.com/D10NGYANG/DL10RoundMenuView

数字进度条https://github.com/daimajia/NumberProgressBar

作者:sw-code原文地址:https://www.cnblogs.com/sw-code/p/18206967

%s 个评论

要回复文章请先登录注册