工作中遇到一个问题,设备的显示方向和触摸方向旋转前后都是一致的,但是连接外接屏后,外接屏幕的触摸方向和显示方向不一致了。但是奇怪的是设备进行投屏后外接显示器的触屏又正常了!
直接将三种屏幕的deviceinfo信息打印出来对比:
可以发现7寸屏幕 被识别成了虚拟屏类型,触屏类型竟然识别不出来。
同步对比inputflinger的log可以发现:
因为找不到外部屏幕的viewport而使用了与设备主屏幕相同的viewport
DisplayManagerSerivec.java
TouchInputMapper.cpp
原因应该清楚了,因为设备旋转后是竖屏显示,触摸方向当然也会同步旋转,但是这个外接屏幕是横屏竖显,而又因为没有创建新的viewport 和使用的是设备主屏幕的viewport,所以导致外接屏幕显示方向和触屏方向错乱。
比较坑爹的是,正常的物理屏和虚拟屏是根据热插拔来区分的(HWComposer 中的onHotplugConnect),但是这个外接屏是由第三方apk进行投影显示的,所以才被设备识别成了虚拟屏。但是触屏类型显示为none,跟踪代码后发现,触屏类型由一个flag标志位与支持触屏标志位进行&运算得出,结果为0 就是不支持触屏。flag的来源 是创建虚拟屏时给定一个初始的flag,在创建过程中会不断根据设备信息添加新的flag。