微信消息语音播报秒实现

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

相关推荐
嘀咕博客2 分钟前
超级助理:百度智能云发布的AI助理应用
人工智能·百度·ai工具
张子夜 iiii20 分钟前
深度学习-----《PyTorch神经网络高效训练与测试:优化器对比、激活函数优化及实战技巧》
人工智能·pytorch·深度学习
小星星爱分享22 分钟前
抖音多账号运营新范式:巨推AI如何解锁流量矩阵的商业密码
人工智能·线性代数·矩阵
aneasystone本尊43 分钟前
剖析 GraphRAG 的项目结构
人工智能
AI 嗯啦1 小时前
计算机视觉--opencv(代码详细教程)(三)--图像形态学
人工智能·opencv·计算机视觉
鱼香l肉丝1 小时前
第四章-RAG知识库进阶
人工智能
邵洛1 小时前
阿里推出的【 AI Qoder】,支持MCP工具生态扩展
人工智能
CPU NULL1 小时前
Spring拦截器中@Resource注入为null的问题
java·人工智能·后端·spring
老顾聊技术1 小时前
深度解析比微软的GraphRAG简洁很多的LightRAG,一看就懂
人工智能
盼小辉丶1 小时前
PyTorch实战(1)——深度学习概述
人工智能·pytorch·深度学习