上一篇搞定了音量无法调节,但是调节音量的时候音量条不显示,郁闷,全是坑。周末又不得不加班了。。。。
我们已经知道音量调节的具体实现函数是AudioService.java中adjustStreamVolume(),居然音量能调节,那说明设置的音量值能够传递下去,但是发送的消失没有去绘制UI,导致了音量条没有显示,所以,从代码入手,找到发送消息的地方。在adjustStreamVolume()中
的adjustIndex有个判断,当音量调节时,会把消息发送下去。进入adjustIndex()函数。具体的实现函数为public boolean setIndex(int index, int device, String caller)
具体看里面的实现,当changed为true时,说明音量值发生了变化,这时,会发送把值传递下去,同时去发消息去绘制UI,EXTRA_VOLUME_STREAM_VALUE为当前值的消息,EXTRA_PREV_VOLUME_STREAM_VALUE为调节前值的消息,EXTRA_VOLUME_STREAM_TYPE_ALIAS为流类型的消息。
所以查找EXTRA_VOLUME_STREAM_VALUE关键字,发现packages/SystemUI/src/com/android/systemui/volume/VolumeDialogControllerImpl.java中
有调用,因为是音量条不显示,肯定跟UI有关系,SystemUI嫌疑最大。
添加打印(在不清楚代码流程的情况下,多添加打印对理解代码流程有很大的帮助)。
这里的changed为true,会调用函数末尾的
然后调用
启动线程,这里的
发现entrySet()的构造实现如下
看来关键还是W这个类,进入W类,柳暗花明,发现了发消息的函数
加log发现进入了onVolumeChangedW() case,发现ShouldshowUI(flags),望文生义,很显然了吧
对比了8.0的代码
我曹,差别这么大,8.1的实现更复杂,判断更多。通过与管理sdk的商议,加上box的策略,完美解决!!!!
总结:遇到问题,以后多加log信息,这点相信程序员都是懂知道;遇到瓶颈时多问老前辈,有时候可能查找方向都是错的,会多做很多无用功。