diff options
author | Riddle Hsu <riddlehsu@google.com> | 2020-11-19 19:28:38 +0800 |
---|---|---|
committer | Riddle Hsu <riddlehsu@google.com> | 2020-11-19 20:29:17 +0800 |
commit | 275aba2deb2a9b7069e6ea66327dd6ca7854d6aa (patch) | |
tree | f7acfa09a7c6227a2be94af1fca48c8a71ed1569 /docs/html/sdk/api_diff/6 | |
parent | edf2036691bcba834c27eff0ffc0e709465ba2f4 (diff) |
Move handleCompleteDeferredRemoval to animator thread
The method may remove window hierarchy element in random
timing (usually depends on animation). If the caller
indirectly calls to performSurfacePlacement inside a loop
that also removes element, the loop may encounter index
out of bound exception. It is hard for the caller to aware
how to iterate window containers safely.
Because performSurfacePlacement always calls WindowAnimator
scheduleAnimationLocked, the movement of invocation should
not miss the original cases for deferred removal.
It also reduces unnecessary invocations up to 50% because
animator won't execute multiple times if it is scheduled,
while performSurfacePlacement calls each time. And the
partial cost may be moved out from binder thread.
Bug: 173270358
Test: CtsWindowManagerDeviceTestCases
Change-Id: If9a45403e7bbedb2073f8e6f6e90934af0c4c29e
Diffstat (limited to 'docs/html/sdk/api_diff/6')
0 files changed, 0 insertions, 0 deletions