背景:
在经常做窗口显示相关开发时候,进程需要采用以下几个命令:
dumpsys SurfaceFlinger --主要dump出相关显示图层Layer信息
dumpsys window windows --主要dump出相关的window信息,也就是windowstate信息
但是在aosp15版本使用dumpsys SurfaceFlinger时候发现输出相比以前版本如aosp14,有较大的更新,下面来具体看看相关的dump的差异。
dump相关的差异对比
先来看看aosp15的dump中的一些新特性:
SurfaceFlinger New Frontend Enabled:true
Active Layers - layers with client handles (count = 81)
Composition list
LayerStack=0
Layer [190] Wallpaper BBQ wrapper#190
visible reason= buffer=11141145165824 frame=1 color{< 0, 0, 0, 1 >}
bounds={-72,-148,3108,2859.5} toDisplayTransform={ scale x=3.1795 y=3.1797 tx=-72.0000 ty=-148.0000 }
Layer [213] com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#213
visible reason= buffer=12799002542087 frame=6 color{< 0, 0, 0, 1 >}
bounds={0,0,2960,1440}
input{(DUPLICATE_TOUCH_TO_WALLPAPER) touchableRegion={0,0,2960,1440}}
Layer [209] StatusBar#209
visible reason= buffer=11141145165828 frame=26 color{< 0, 0, 0, 1 >}
bounds={0,0,84,1440}
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY) touchableRegion={0,0,84,1440}}
Layer [216] Taskbar#216
visible reason= buffer=12799002542090 frame=21 color{< 0, 0, 0, 1 >}
bounds={0,2792,2960,1440} toDisplayTransform={ tx=0.0000 ty=2792.0000 }
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY | SLIPPERY) touchableRegion={0,2792,2960,1440}}
Input list
LayerStack=0
Layer [216] Taskbar#216
visible reason= buffer=12799002542090 frame=21 color{< 0, 0, 0, 1 >}
bounds={0,2792,2960,1440} toDisplayTransform={ tx=0.0000 ty=2792.0000 }
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY | SLIPPERY) touchableRegion={0,2792,2960,1440}}
Layer [209] StatusBar#209
visible reason= buffer=11141145165828 frame=26 color{< 0, 0, 0, 1 >}
bounds={0,0,84,1440}
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY) touchableRegion={0,0,84,1440}}
Layer [213] com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#213
visible reason= buffer=12799002542087 frame=6 color{< 0, 0, 0, 1 >}
bounds={0,0,2960,1440}
input{(DUPLICATE_TOUCH_TO_WALLPAPER) touchableRegion={0,0,2960,1440}}
Layer [218] 39a2f ActivityRecordInputSink com.android.launcher3/.uioverrides.QuickstepLauncher#218
invisible reason=nothing to draw
bounds={0,0,2960,1440}
input{(NO_INPUT_CHANNEL | NOT_FOCUSABLE) replaceTouchableRegionWithCrop touchableRegion={0,0,2960,1440}}
Layer [189] com.android.systemui.wallpapers.ImageWallpaper#189
invisible reason=nothing to draw
bounds={-14400,-29600,29600,14400} toDisplayTransform={ scale x=3.1795 y=3.1797 tx=-72.0000 ty=-148.0000 }
input{(NOT_FOCUSABLE | NOT_TOUCHABLE | PREVENT_SPLITTING | IS_WALLPAPER) touchableRegion={-71,-147,-147,-71}}
Layer Hierarchy
ROOT
├─ Display 0 name="Built-in Screen"#169
│ ├─ WindowedMagnification:0:31#129
│ │ ├─ HideDisplayCutout:0:14#130
│ │ │ └─ OneHanded:0:14#131
│ │ │ ├─ FullscreenMagnification:0:12#132
│ │ │ │ ├─ Leaf:0:1#133
│ │ │ │ │ └─ WallpaperWindowToken{c162fc5 token=android.os.Binder@a6f563c}#187
│ │ │ │ │ └─ fd0fa1b com.android.systemui.wallpapers.ImageWallpaper#188
│ │ │ │ │ └─ com.android.systemui.wallpapers.ImageWallpaper#189
│ │ │ │ │ └─ Wallpaper BBQ wrapper#190
│ │ │ │ ├─ DefaultTaskDisplayArea#134
│ │ │ │ │ ├─ Task=1#173
│ │ │ │ │ │ ├─ Task=504#205
│ │ │ │ │ │ │ └─ ActivityRecord{9dd283c u0 com.androi[...]3/.uioverrides.QuickstepLauncher#206
│ │ │ │ │ │ │ ├─ 39a2f ActivityRecordInputSink com.an[...]3/.uioverrides.QuickstepLauncher#218
│ │ │ │ │ │ │ ├─ fef5fb1 com.android.launcher3/com.an[...]r3.uioverrides.QuickstepLauncher#207
│ │ │ │ │ │ │ │ ├─ com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#213 requestedFrameRate: {0.00 Hz FrameRateCompatibility::Default FrameRateCategory::NoPreference}
│ │ │ │ │ │ │ │ └─ (Relative) ImeContainer#137 parent=206
│ │ │ │ │ │ │ │ └─ WindowToken{e8a7c8b type=2011 android.os.Binder@3e1625a}#201
│ │ │ │ │ │ │ │ └─ Surface(name=64140f3 InputMethod)/@0[...]mation-leash of insets_animation#219
│ │ │ │ │ │ │ │ └─ 64140f3 InputMethod#202
│ │ │ │ │ │ └─ home_task_overlay_container#174
│ │ │ │ │ └─ Task=3#177
│ │ │ │ │ ├─ Task=4#178
│ │ │ │ │ │ └─ Dim layer#182
│ │ │ │ │ └─ Task=5#179
│ │ │ │ │ └─ Dim layer#184
│ │ │ │ └─ Leaf:3:12#135
│ │ │ │ └─ WindowToken{da512ac type=2038 android.os.BinderProxy@7878020}#180
│ │ │ │ └─ 5bae1bd ShellDropTarget#181
│ │ │ └─ ImePlaceholder:13:14#136
│ │ ├─ OneHanded:15:15#138
│ │ │ └─ FullscreenMagnification:15:15#139
│ │ │ └─ Leaf:15:15#140
│ │ │ └─ WindowToken{ddb9d1e type=2000 android.os.BinderProxy@e743da0}#198
│ │ │ └─ Surface(name=39539ff StatusBar)/@0x9[...]mation-leash of insets_animation#215
│ │ │ └─ 39539ff StatusBar#199
│ │ │ └─ StatusBar#209 requestedFrameRate: {0.00 Hz FrameRateCompatibility::Default FrameRateCategory::NoPreference}
│ │ ├─ HideDisplayCutout:16:16#141
│ │ │ └─ OneHanded:16:16#142
│ │ │ └─ FullscreenMagnification:16:16#143
│ │ │ └─ Leaf:16:16#144
│ │ ├─ OneHanded:17:17#145
│ │ │ └─ FullscreenMagnification:17:17#146
│ │ │ └─ Leaf:17:17#147
│ │ │ └─ WindowToken{e913107 type=2040 android.os.BinderProxy@9c13b21}#196
│ │ │ └─ 32c3234 NotificationShade#197
│ │ ├─ HideDisplayCutout:18:23#148
│ │ │ └─ OneHanded:18:23#149
│ │ │ └─ FullscreenMagnification:18:23#150
│ │ │ └─ Leaf:18:23#151
│ │ ├─ Leaf:24:25#152
│ │ │ └─ WindowToken{5b4a718 type=2019 android.os.BinderProxy@9928a31}#210
│ │ │ └─ Surface(name=5b4348a Taskbar)/@0x7d2[...]mation-leash of insets_animation#214
│ │ │ └─ 5b4348a Taskbar#211
│ │ │ └─ Taskbar#216 requestedFrameRate: {0.00 Hz FrameRateCompatibility::Default FrameRateCategory::NoPreference}
│ │ └─ HideDisplayCutout:26:31#153
│ │ └─ OneHanded:26:31#154
│ │ ├─ FullscreenMagnification:26:27#155
│ │ │ └─ Leaf:26:27#156
│ │ ├─ Leaf:28:28#157
│ │ └─ FullscreenMagnification:29:31#158
│ │ └─ Leaf:29:31#159
│ ├─ HideDisplayCutout:32:35#160
│ │ ├─ OneHanded:32:32#161
│ │ │ └─ Leaf:32:32#162
│ │ ├─ FullscreenMagnification:33:33#163
│ │ │ └─ Leaf:33:33#164
│ │ └─ OneHanded:34:35#165
│ │ └─ FullscreenMagnification:34:35#166
│ │ └─ Leaf:34:35#167
│ ├─ Leaf:36:36#168
│ ├─ Accessibility Overlays#172
│ ├─ Input Overlays#171
│ └─ Display Overlays#170
├─ Input Consumer recents_animation_input_consumer#208
├─ WindowToken{e882739 type=2024 android.os.BinderProxy@a617300}#191
│ └─ b02417e ScreenDecorOverlay#192
└─ WindowToken{4e3c7c4 type=2024 android.os.BinderProxy@75a62d7}#193
└─ 171f6ad ScreenDecorOverlayBottom#194
Offscreen Hierarchy
ROOT
└─ Task=2#175
aosp 15版本有以下几个比较明显新特性:
特性1
输出Composition list信息,这个输出就是代表最后参与合成的Layer信息:
LayerStack=0
Layer [190] Wallpaper BBQ wrapper#190
visible reason= buffer=11141145165824 frame=1 color{< 0, 0, 0, 1 >}
bounds={-72,-148,3108,2859.5} toDisplayTransform={ scale x=3.1795 y=3.1797 tx=-72.0000 ty=-148.0000 }
Layer [213] com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#213
visible reason= buffer=12799002542087 frame=6 color{< 0, 0, 0, 1 >}
bounds={0,0,2960,1440}
input{(DUPLICATE_TOUCH_TO_WALLPAPER) touchableRegion={0,0,2960,1440}}
Layer [209] StatusBar#209
visible reason= buffer=11141145165828 frame=26 color{< 0, 0, 0, 1 >}
bounds={0,0,84,1440}
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY) touchableRegion={0,0,84,1440}}
Layer [216] Taskbar#216
visible reason= buffer=12799002542090 frame=21 color{< 0, 0, 0, 1 >}
bounds={0,2792,2960,1440} toDisplayTransform={ tx=0.0000 ty=2792.0000 }
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY | SLIPPERY) touchableRegion={0,2792,2960,1440}}
可以看出这里输出当前屏幕画面显示的Layer情况,这里其实有点类似的HWC列表输出的更加详细一些的信息汇总。
看看正常HWC的信息如下:
特性2
Input list这个代表是Layer信息有输入交互相关的Layer,也就是展示在这里的Layer信息,其实都是会被传递到InputDispatcher中。
Input list
LayerStack=0
Layer [216] Taskbar#216
visible reason= buffer=12799002542090 frame=21 color{< 0, 0, 0, 1 >}
bounds={0,2792,2960,1440} toDisplayTransform={ tx=0.0000 ty=2792.0000 }
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY | SLIPPERY) touchableRegion={0,2792,2960,1440}}
Layer [209] StatusBar#209
visible reason= buffer=11141145165828 frame=26 color{< 0, 0, 0, 1 >}
bounds={0,0,84,1440}
input{(NOT_FOCUSABLE | TRUSTED_OVERLAY) touchableRegion={0,0,84,1440}}
Layer [213] com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#213
visible reason= buffer=12799002542087 frame=6 color{< 0, 0, 0, 1 >}
bounds={0,0,2960,1440}
input{(DUPLICATE_TOUCH_TO_WALLPAPER) touchableRegion={0,0,2960,1440}}
Layer [218] 39a2f ActivityRecordInputSink com.android.launcher3/.uioverrides.QuickstepLauncher#218
invisible reason=nothing to draw
bounds={0,0,2960,1440}
input{(NO_INPUT_CHANNEL | NOT_FOCUSABLE) replaceTouchableRegionWithCrop touchableRegion={0,0,2960,1440}}
Layer [189] com.android.systemui.wallpapers.ImageWallpaper#189
invisible reason=nothing to draw
bounds={-14400,-29600,29600,14400} toDisplayTransform={ scale x=3.1795 y=3.1797 tx=-72.0000 ty=-148.0000 }
input{(NOT_FOCUSABLE | NOT_TOUCHABLE | PREVENT_SPLITTING | IS_WALLPAPER) touchableRegion={-71,-147,-147,-71}}
上面Input list输出内容可以看出,这里重点展示的触摸相关的区域信息,而且还会有当前input layer没有visibility的原因显示,因为layer虽然可以成为InputDispatcher中的传递对象,但是他不一定显示,最经典的就是ActivityRecordInputSink这种。
特性3
Layer Hierarchy会展示出SurfaceFlinger层面的一个层级结构树,这个层级结构树是SurfaceFlinger对所有的Layer层面的,这个其实在以前wms课程中也有详细讲解,这个和wms层面的层级结构树一般都是一一对应的。
sf层级结构树情况
wms中窗口层级结构树情况
确实直接有了sf层面的层级结构树后,就再不需要和以前一样要对挨个Layer进行查询parent,然后拼接出相关的结构树。
虽然有了上面几个新特性的亮点功能,但是也发现aosp15版本把一些比较重要的信息进行了删除裁剪,这里最明显是再也没有详细的Layer信息。
详细Layer信息差异部分
aosp14版本有详细的Layer信息输出
+ Layer (ActivityRecord{9ab378d u0 com.android.launcher3/.uioverrides.QuickstepLauncher t287}#96) uid=1000
Region TransparentRegion (this=0 count=0)
Region VisibleRegion (this=0 count=0)
Region SurfaceDamageRegion (this=0 count=0)
layerStack= 0, z= 0, pos=(0,0), size=( 0, 0), crop=[ 0, 0, -1, -1], cornerRadius=0.000000, isProtected=0, isTrustedOverlay=0, isOpaque=0, invalidate=1, dataspace=BT709 sRGB Full range, defaultPixelFormat=Unknown/None, backgroundBlurRadius=0, color=(-1.000,-1.000,-1.000,1.000), flags=0x00000000, tr=[0.00, 0.00][0.00, 0.00]
parent=Task=287#95
zOrderRelativeOf=none
activeBuffer=[ 0x 0: 0,Unknown/None], tr=[0.00, 0.00][0.00, 0.00] queued-frames=0 metadata={9:4bytes}, cornerRadiusCrop=[0.00, 0.00, 0.00, 0.00], shadowRadius=0.000,
+ Layer (faa830c com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#97) uid=1000
Region TransparentRegion (this=0 count=0)
Region VisibleRegion (this=0 count=0)
Region SurfaceDamageRegion (this=0 count=0)
layerStack= 0, z= 0, pos=(0,0), size=( 0, 0), crop=[ 0, 0, 0, 0], cornerRadius=0.000000, isProtected=0, isTrustedOverlay=0, isOpaque=0, invalidate=1, dataspace=BT709 sRGB Full range, defaultPixelFormat=Unknown/None, backgroundBlurRadius=0, color=(-1.000,-1.000,-1.000,1.000), flags=0x00000000, tr=[0.00, 0.00][0.00, 0.00]
parent=ActivityRecord{9ab378d u0 com.android.launcher3/.uioverrides.QuickstepLauncher t287}#96
zOrderRelativeOf=none
activeBuffer=[ 0x 0: 0,Unknown/None], tr=[0.00, 0.00][0.00, 0.00] queued-frames=0 metadata={9:4bytes}, cornerRadiusCrop=[0.00, 0.00, 0.00, 0.00], shadowRadius=0.000,
+ Layer (com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#99) uid=10109
Region TransparentRegion (this=0 count=0)
Region VisibleRegion (this=0 count=1)
[ 0, 0, 1440, 2960]
Region SurfaceDamageRegion (this=0 count=0)
layerStack= 0, z= 0, pos=(0,0), size=( 0, 0), crop=[ 0, 0, -1, -1], cornerRadius=0.000000, isProtected=0, isTrustedOverlay=0, isOpaque=0, invalidate=0, dataspace=BT709 sRGB Full range, defaultPixelFormat=RGBA_8888, backgroundBlurRadius=0, color=(-1.000,-1.000,-1.000,1.000), flags=0x00000100, tr=[0.00, 0.00][0.00, 0.00]
parent=faa830c com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher#97
zOrderRelativeOf=none
activeBuffer=[1440x2960:2816,RGBA_8888], tr=[0.00, 0.00][0.00, 0.00] queued-frames=0 metadata={9:4bytes, ownerPID:1138, ownerUID:10109, dequeueTime:20729563622, windowType:1}, cornerRadiusCrop=[0.00, 0.00, 0.00, 0.00], shadowRadius=0.000,
但是在aosp15版本的dumpsys SurfaceFlinger中再也没有见到这个详细Layer的影子,应该也是为了精简一下dump的输出信息。因为如果带上所有的Layer信息的话,会导致每次的输出信息过多,可能要观察核心的一些信息比较难。
但是只要分析过显示相关问题的同学都知道,其实每个Layer详细信息又是非常重要的一个分析依据,比如Layer的一些显示区域VisibleRegion,flags,cornerRadiusCrop,layerStack,crop等都是非常核心的一些参考数据。
特别是在没有条件抓取Winscope相关信息时候,dumpsys信息就作为唯一信息参考源头,因为很多user版本时候,不让抓取Winscope,或者Winscope抓取要连接电脑等,抓取获取Winscope成本比较高,但是dumpsys SurfaceFlinger这个基本上没啥门槛,很容易获取。
基于以上aosp15版本上dumpsys SurfaceFlinger没有相关的详细Layer信息应该如何解决呢?是否可以考虑把详细的Layer信息进行输出呢?
这块就留给学员朋友们的一个小作业哈,难度较低,希望大家积极踊跃完成哈。
更多framework实战开发干货,请关注下面“千里马学框架”。