问题还原
某天,测试同事突然报所有应用都变成竖屏了,实际上系统默认就是横屏显示的,某些应用强制显示横屏的应用,也被显示成了竖屏。
问题分析
如何通过adb命令切换横竖屏
很明显,是系统的某个属性的变化导致了应用被显示竖屏,网上搜索发现adb命令可切换横竖屏:
arduino
adb shell settings put system screen_orientation 1 // 横屏
adb shell settings put system screen_orientation 0 // 竖屏
执行命令可发现执行之后表现与问题一致:横屏变成了竖屏显示。
执行adb 命令之后日志中的差异点
对比日志可以看出执行命令前后,android.content.res.Configuration
中的android.app.WindowConfiguration
的mRotation
有区别,横屏时为ROTATION_0
,竖屏为ROTATION_90
,在出现问题中的日志中搜索,可以发现的确出现了变化:
结合重启之后仍旧为竖屏,可以猜想是执行了类似上述设置属性的命令。
研究Scrcpy源码
与测试同事沟通了解到,其使用了投屏软件Scrcpy,那么会不会是投屏软件执行了横竖屏切换的逻辑呢? 下载Scrcpy的源码(github.com/Genymobile/...%25EF%25BC%258C "https://github.com/Genymobile/scrcpy)%EF%BC%8C") 源码里尝试搜索landscape
:
逐一排查,在server\src\main\java\com\genymobile\scrcpy\device\Device.java目录下发现旋转设备相关的实现:
再搜索"rotateDevice":
从类名及实现可以断定:scrcpy是支持旋转Android设备的 ,但是搜索TYPE_ROTATE_DEVICE
,看起来找不到真正的调用地方(由于对代码不熟,故并未深入了解),此时已经感觉无从下手了。
scrcpy --help
从代码角度可以确定,scrcpy是支持旋转Android设备的 , 联想到Linux不少命令都可以通过 --help查看其用法,故尝试执行scrcpy.exe --help
,在结果中尝试查找"Rotate":
注意到Rotate device screen
对应了快捷键ALT + R(windows):
尝试在scrcpy页面执行快捷键ALT + R,果然,执行完之后就变成竖屏了!!!
结论
测试同事在scrcpy页面不小心 按了捷键ALT + R ,导致执行了scrcpy旋转屏幕的操作,非问题~