0

0

Android 13+ 中蓝牙媒体按键事件获取失效的解决方案

心靈之曲

心靈之曲

发布时间:2026-01-04 14:15:20

|

854人浏览过

|

来源于php中文网

原创

Android 13+ 中蓝牙媒体按键事件获取失效的解决方案

android 13(api 33)起 `intent.getparcelableextra(string)` 已废弃,导致 `intent.extrakeyevent` 返回 null;需改用带泛型类型参数的新方法 `getparcelableextra(string, class)` 并适配 xamarin 绑定调用方式。

在 Android 13(API level 33)及更高版本中,Intent.GetParcelableExtra(string) 方法被正式标记为 [Obsolete],其底层实现已不再返回 KeyEvent 实例,直接调用将始终返回 null —— 这正是您遇到 keyEvent == null 的根本原因。Xamarin.Android 虽未同步更新所有绑定签名,但已支持新式泛型重载,必须显式指定类型以确保正确反序列化。

✅ 正确写法:使用泛型 GetParcelableExtra(Xamarin.Android 13.6+ 推荐)

请将 BroadcastReceiver.OnReceive 中的事件提取逻辑替换为:

Animate AI
Animate AI

Animate AI是个一站式AI动画故事视频生成工具

下载
if (intent.Action == Intent.ActionMediaButton)
{
    // ✅ 正确:显式指定 KeyEvent 类型,兼容 API 33+
    var keyEvent = intent.GetParcelableExtra(Intent.ExtraKeyEvent);

    if (keyEvent == null)
    {
        Log.Warn("MyMediaButtonReceiver", "KeyEvent is null — check Android version and manifest permissions.");
        return;
    }

    switch (keyEvent.KeyCode)
    {
        case Keycode.Headsethook:
            if (keyEvent.Action == KeyEventActions.Down)
                HandlePlayPause();
            break;
        case Keycode.MediaPlay:
        case Keycode.MediaPause:
        case Keycode.MediaPlayPause:
            if (keyEvent.Action == KeyEventActions.Down)
                HandlePlayPause();
            break;
        case Keycode.MediaNext:
            if (keyEvent.Action == KeyEventActions.Down)
                HandleNext();
            break;
        case Keycode.MediaPrevious:
            if (keyEvent.Action == KeyEventActions.Down)
                HandlePrevious();
            break;
        default:
            Log.Debug("MyMediaButtonReceiver", $"Unhandled key: {keyEvent.KeyCode}");
            break;
    }
}

⚠️ 关键注意事项

  • 最低 SDK 要求:确保 TargetFramework ≥ android33.0(即 CompileSdkVersion=33),并在 .csproj 中启用 UseAndroidX=true;
  • 权限与清单声明
    AndroidManifest.xml 中需声明 (虽非强制,但推荐用于后台媒体控制);
  • 广播接收器注册时机
    RegisterMediaButtonEventReceiver() 必须在 Application 或前台 Activity 生命周期内完成(不建议仅依赖后台 Service)。Android 8.0+ 对隐式广播和后台服务限制严格,建议改用 ForegroundService + StartForeground() 提升优先级,并在 OnCreate() 中注册;
  • 避免重复注册/泄漏
    在 OnDestroy() 或服务停止时调用 am.UnregisterMediaButtonEventReceiver(componentName),防止内存泄漏或事件重复触发;
  • 测试验证建议
    使用真实蓝牙耳机(如 Jabra、Bose)测试 KEYCODE_HEADSETHOOK 和 KEYCODE_MEDIA_* 行为;模拟器通常不触发真实媒体按键事件。

? 总结

GetParcelableExtra(Intent.ExtraKeyEvent) 是 Android 13+ 获取蓝牙媒体按键事件的唯一可靠方式。Xamarin.Android 已完整支持该泛型重载,无需反射或 JNI 介入。同时,请务必升级运行环境、校验生命周期管理,并优先采用前台服务保障广播接收器持续生效。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

314

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

435

2024.03.01

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1859

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2084

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

949

2024.11.28

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

462

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

8

2025.12.06

漫蛙2入口地址合集
漫蛙2入口地址合集

本专题整合了漫蛙2入口汇总,阅读专题下面的文章了解更多详细内容。

162

2026.01.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 10.8万人学习

Java 教程
Java 教程

共578课时 | 42.6万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 6.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号