summaryrefslogtreecommitdiff
path: root/docs/html/sdk/api_diff/15/changes
diff options
context:
space:
mode:
authorTiger Huang <tigerhuang@google.com>2021-03-19 03:42:44 +0800
committerTiger Huang <tigerhuang@google.com>2021-03-24 04:19:48 +0800
commita7e33a41e54e25761704dc0217ba05d8db3f57d3 (patch)
tree57ff26e43d7a24ad02f18d3fa502c2f4894f9c49 /docs/html/sdk/api_diff/15/changes
parent33d3819bb2a8685fcde2497ee15f5de9950656c2 (diff)
Re-land: Make window stable while resizing
When the frame size and the frame position of the window are changed at the same time, setPosition to the surface will be applied first, and the client will draw on the new-size buffer later, which makes the window flicker. This CL uses applyWithNextDraw to make the new surface position can be applied while the new frame is drawn. applyWithNextDraw is applied only when - the window doesn't have a move animation. So if a window needs to make resizing stable, it may need PRIVATE_FLAG_NO_MOVE_ANIMATION. - it is visible, e.g., the surface is shown, and the window is OK to display -- for better performance. If applyWithNextDraw is used while the window frame is changed to an empty rectangle, e.g., Rect(10, 10 - 1000, 10), mNextDrawUseBlastSync will stay true forever, because we don't draw while the dirty area is empty, and ViewRootImpl would lose the only chance to clear the flag. performTraversals will never be executed. This CL makes mNextDrawUseBlastSync can be cleared in that case. Bug: 182729646 Fix: 176874720 Test: steps in the bug Change-Id: I81b0574ee8db7e4d9053639f56e04858d9feae90
Diffstat (limited to 'docs/html/sdk/api_diff/15/changes')
0 files changed, 0 insertions, 0 deletions