微信消息语音播报秒实现

1. 监听系统消息通知

注册一个监听系统消息的服务

复制代码
<service
            android:name=".MyNotificationListenerService"
            android:exported="true"
            android:permission="android.permission.BIND_NOTIFICATION_LISTENER_SERVICE" >
            <intent-filter>
                <action android:name="android.service.notification.NotificationListenerService" />
            </intent-filter>
        </service>

实现这个服务,解析消息通知,如果是来自微信,则组装成微信消息,提取发送者,和消息内容,更新到livedata中

Kotlin 复制代码
class MyNotificationListenerService : NotificationListenerService() {

    companion object{
        val wxMessage = MutableLiveData<WxMessage>()
    }
    override fun onNotificationPosted(sbn: StatusBarNotification) {
        // 捕获通知
        val notification = sbn.notification
        // 根据用户设置过滤通知
        println("linlian ${sbn.packageName},${sbn.notification.tickerText}")

        if (PACKAGE_WX == sbn.packageName) {
            convertToWxMessage(sbn)?.let {
                wxMessage.postValue(it)
            }

        }
    }

    /**
     * 将微信消息转换成发送者,和消息内容
     */
    private fun convertToWxMessage(sbn: StatusBarNotification): WxMessage? {
        try {
            sbn.notification.tickerText?.let {
                val splits = it.split(
                    delimiters = arrayOf(":"),
                    ignoreCase = false,
                    limit = 2
                )
                if (splits.size == 2) {
                   return  WxMessage(splits[0], splits[1])
                }

            }
        } catch (e: Exception) {
            e.printStackTrace()
        }
        return null

    }
}

怎么启动这个消息监听服务呢

Kotlin 复制代码
  /*
    显示设置界面,运行我们的应用监听服务
     */
    private fun startNotificationSetting() {
        startActivity(Intent(ACTION_NOTIFICATION_LISTENER_SETTINGS));
    }

这时候会启动系统设置界面,我们需要允许我们的应用

如何判断系统是否允许我们监听了呢

Kotlin 复制代码
 /**
     * 判断应用是否有权限
     */
    private fun isServiceSettingEnable(): Boolean {
        var enable = false
        val packageName = packageName
        val flat: String =
            Settings.Secure.getString(contentResolver, "enabled_notification_listeners")
        if (flat != null) {
            enable = flat.contains(packageName)
        }
        return enable
    }

允许了则直接跳过,不允许的话,启动设置界面,引导用户设置。

2.语音播报

语音播报的话,主要使用TextToSpeech

初始化,设置中文

Kotlin 复制代码
 tts = TextToSpeech(this) { status ->
            println("linlian status=$status")
            if (TextToSpeech.SUCCESS == status) {
                tts.setLanguage(Locale.CHINESE)
            }
        }

监听livedata

Kotlin 复制代码
wxMessage.observe(this, object : Observer<WxMessage> {
            override fun onChanged(value: WxMessage) {
                tts.speak(
                    "收到来自${value.sender}的消息,${value.message}",
                    TextToSpeech.QUEUE_FLUSH,
                    null
                )
            }

        })

that's it

相关推荐
水煮蛋不加蛋23 分钟前
RAG 赋能客服机器人:多轮对话与精准回复
人工智能·ai·机器人·大模型·llm·rag
池央1 小时前
GPUGeek携手ComfyUI :低成本文生图的高效解决方案
人工智能
Mr.Winter`3 小时前
深度强化学习 | 图文详细推导软性演员-评论家SAC算法原理
人工智能·深度学习·神经网络·机器学习·数据挖掘·机器人·强化学习
强盛小灵通专卖员3 小时前
分类分割详细指标说明
人工智能·深度学习·算法·机器学习
特立独行的猫a5 小时前
HarmonyOS 【诗韵悠然】AI古诗词赏析APP开发实战从零到一系列(一、开篇,项目介绍)
人工智能·华为·harmonyos·古诗词
yu4106215 小时前
2025年中期大语言模型实力深度剖析
人工智能·语言模型·自然语言处理
feng995208 小时前
技术伦理双轨认证如何重构AI工程师能力评估体系——基于AAIA框架的技术解析与行业实证研究
人工智能·aaif·aaia·iaaai
2301_776681658 小时前
【用「概率思维」重新理解生活】
开发语言·人工智能·自然语言处理
蜡笔小新..8 小时前
从零开始:用PyTorch构建CIFAR-10图像分类模型达到接近1的准确率
人工智能·pytorch·机器学习·分类·cifar-10
富唯智能9 小时前
转运机器人可以绕障吗?
人工智能·智能机器人·转运机器人