Merge "Revert "Send update config change when letterbox is moved"" into udc-qpr-dev
This commit is contained in:
@@ -34,7 +34,6 @@ import static android.view.Display.INVALID_DISPLAY;
|
||||
import static android.window.ConfigurationHelper.freeTextLayoutCachesIfNeeded;
|
||||
import static android.window.ConfigurationHelper.isDifferentDisplay;
|
||||
import static android.window.ConfigurationHelper.shouldUpdateResources;
|
||||
import static android.window.ConfigurationHelper.shouldUpdateWindowMetricsBounds;
|
||||
|
||||
import static com.android.internal.annotations.VisibleForTesting.Visibility.PACKAGE;
|
||||
import static com.android.internal.os.SafeZipPathValidatorCallback.VALIDATE_ZIP_PATH_FOR_PATH_TRAVERSAL;
|
||||
@@ -6118,11 +6117,6 @@ public final class ActivityThread extends ClientTransactionHandler
|
||||
public static boolean shouldReportChange(@Nullable Configuration currentConfig,
|
||||
@NonNull Configuration newConfig, @Nullable SizeConfigurationBuckets sizeBuckets,
|
||||
int handledConfigChanges, boolean alwaysReportChange) {
|
||||
// Always report changes in window configuration bounds
|
||||
if (shouldUpdateWindowMetricsBounds(currentConfig, newConfig)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
final int publicDiff = currentConfig.diffPublicOnly(newConfig);
|
||||
// Don't report the change if there's no public diff between current and new config.
|
||||
if (publicDiff == 0) {
|
||||
|
||||
@@ -106,7 +106,7 @@ public class ConfigurationHelper {
|
||||
* @see WindowManager#getCurrentWindowMetrics()
|
||||
* @see WindowManager#getMaximumWindowMetrics()
|
||||
*/
|
||||
public static boolean shouldUpdateWindowMetricsBounds(@NonNull Configuration currentConfig,
|
||||
private static boolean shouldUpdateWindowMetricsBounds(@NonNull Configuration currentConfig,
|
||||
@NonNull Configuration newConfig) {
|
||||
final Rect currentBounds = currentConfig.windowConfiguration.getBounds();
|
||||
final Rect newBounds = newConfig.windowConfiguration.getBounds();
|
||||
|
||||
@@ -451,8 +451,10 @@ public class ActivityThreadTest {
|
||||
final Rect bounds = activity.getWindowManager().getCurrentWindowMetrics().getBounds();
|
||||
assertEquals(activityConfigPortrait.windowConfiguration.getBounds(), bounds);
|
||||
|
||||
// Ensure changes in window configuration bounds are reported
|
||||
assertEquals(numOfConfig + 1, activity.mNumOfConfigChanges);
|
||||
// Ensure that Activity#onConfigurationChanged() not be called because the changes in
|
||||
// WindowConfiguration shouldn't be reported, and we only apply the latest Configuration
|
||||
// update in transaction.
|
||||
assertEquals(numOfConfig, activity.mNumOfConfigChanges);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
||||
Reference in New Issue
Block a user