sqlite3 SQL query 使用

本文探讨了在Android系统中解决开机铃声无法被静音设置抑制的问题。通过分析发现,使用系统属性persist.sys.mode_ringer无法实现预期效果,转而采用sqlite3直接读取settings.db数据库中的模式设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

sqlite3 SQL query 使用

 

在android 上的加了开机铃声功能。修改后,铃声模式设置为静音,但铃声还会响。第一个想到的解决方法是

1)在加一个系统属性persist.sys.mode_ringer,

2)在 setRingMode->persistRingerMode中同步到persist.sys.mode_ringer,

3)启动脚本中使用 getprop persist.sys.mode_ringer 取数据.来控制。

代码写好后,开机实际使用时,设置静音后,开机铃声还是有。很是意外。adb登录,用命令行直接 getprop persist.sys.mode_ringer,发现数据是空的。adb 直接设置成功,重启,静音有效。有点郁闷

 

重新浏览一下代码,发现了可能的问题,权限问题。persist默认是要system权限,然后su shell之后,试了一下,果然操作无效。要改所有可以设置静音的应用工作量太大。想到了第二个方法

使用sqlite3 直接读取 保存到 data/data/com.android.providers.settings/databases/settings.db

参考: http://zhidao.baidu.com/question/203386308.html

 

DATABASE=/data/data/com.android.providers.settings/databases/settings.db
SQL="SELECT value FROM system where name='mode_ringer'"
RINGER_MODE=`sqlite3 $DATABASE "$SQL"`

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值