mt6735 默认alarm铃声在media database中的id改变后,如何将新的id更新到settings.db去?

2024-03-08 17:48

本文主要是介绍mt6735 默认alarm铃声在media database中的id改变后,如何将新的id更新到settings.db去?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


[DESCRIPTION]
维护铃声有三个database,即internal.db、external.db和settings.db,internal.db和external.db分别是手机的系统RAM存储和外部存储的database,存放有audio文件的相关属性,如id、title等,见下表:
 
settings.db是维护系统设置的一些参数的存储,如下表:
 
其中settings.db中的valume字段里的值的最后的数字,指向的文件就是对应的internal.db或external.db中的_id这一项所表示的文件,如上图中settings.db中的alart_alerm右边的...media/9所指代的文件就是internal.db中的...Alarm_Classic.ogg的文件。其中alarm_alert即闹铃的默认铃声的key。
现在问题是:假如某些用户可能通过OTA升级或者其它方式将internal.db中的Alarm_Classic.ogg文件删除了,或者是该文件id发生了变化,这时候settings.db里的alarm_alert选项的valume所表示的id即9,其指代的文件就会不存在或者不是原来的文件。
如何解决这个问题呢?
[SOLUTION]
由于目前alarm这边尚缺乏文件id发生变化时实时触发settings.db对应的key更新的机制,所以提一个临时的解决方案,供客户参考使用。其思路为:当发现默认铃声id不存在或者已经改变时,根据所要设置的default 铃声的title,在internal.db中找到该title文件的id项,然后将其更新到settings.db的相关的key value中。
在文件(如AlarmClockFragment.java,由客户根据自己需求合适安排)中,修改如下:
1. 定义:
// start by mtk
import android.provider.MediaStore;
import android.provider.Settings;
// end by mtk
// start by mtk
private ContentResolver mContentResolver;
private static final String ALARM_RINGTONE_TITLE = "Oxygen";//需要用哪个文件作为默认,由客户自己指定
private static final String KEY_ALARM_ALERT = "alarm_alert"; //字段请自行斟酌
private static final String[] INTERNAL_COLUMNS = new String[] { //internal.db的id和title
MediaStore.Audio.Media._ID, MediaStore.Audio.Media.TITLE
};
private static final int ID_COLUMN_INDEX = 0;
private static final int TITLE_COLUMN_INDEX = 1;
// end by mtk


2.具体实现:
// start by mtk
long ringtoneId = 0; //文件在internal.db中的新的id
String oldDefaultUri = null;
String newDfaultUri = null;
mContentResolver = getActivity().getContentResolver();
//创建internal.db的id和title的查询列表
final Cursor internalCursor = mContentResolver.query(
MediaStore.Audio.Media.INTERNAL_CONTENT_URI, INTERNAL_COLUMNS,
null,
null, MediaStore.Audio.Media.DEFAULT_SORT_ORDER);
internalCursor.moveToPosition(-1);
//在查询列表中寻找title等于给定的default title,即 "Oxygen";
while (internalCursor.moveToNext()) {
String ringtoneTitle = internalCursor.getString(TITLE_COLUMN_INDEX);
if (ringtoneTitle.equals(ALARM_RINGTONE_TITLE)) {
ringtoneId = internalCursor.getLong(ID_COLUMN_INDEX);
//得到更新后的id
break;
}
}
oldDefaultUri = Settings.System.getString(mContentResolver, KEY_ALARM_ALERT);
newDfaultUri = oldDefaultUri.substring(0, oldDefaultUri.lastIndexOf("/") + 1)
+ String.valueOf(ringtoneId);
// 得到了新的id: newDfaultUri= "content://media/internal/audio/media/23"
setDefaultRingtone(newDfaultUri);
//写到settings.db中
Settings.System.putString(mContentResolver, KEY_ALARM_ALERT,newDfaultUri);
// end by mtk
验证结果:
 

注: 本文的title必须唯一对应一个文件,若对应多个文件,则需要改用其他字段。

资料来源:一牛网论坛

资料链接:MT6735

这篇关于mt6735 默认alarm铃声在media database中的id改变后,如何将新的id更新到settings.db去?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/787898

相关文章

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal