mirror of
https://github.com/LawnchairLauncher/lawnchair.git
synced 2026-03-04 01:46:49 +00:00
Fix issue with grouped task rects being calculated slightly off
- This was causing bleed through between split tasks and perhaps some rounded corners to be calculated incorrectly - Also reset the translation after it is adjusted for dismissing in case the dismiss gesture is canceled. This doesn't fix the issue with bleed through between the task views (to be fixed separately), but makes sure it isn't permanently set on the task Bug: 206739664 Test: Split tasks, swipe up and check the bounds Change-Id: I34430e958ca7a75f48621bc27a281e93fdf97179
This commit is contained in:
@@ -451,24 +451,19 @@ public class PortraitPagedViewHandler implements PagedOrientationHandler {
|
||||
public void setSplitTaskSwipeRect(DeviceProfile dp, Rect outRect,
|
||||
StagedSplitBounds splitInfo, int desiredStagePosition) {
|
||||
boolean isLandscape = dp.isLandscape;
|
||||
float verticalDividerDiff = splitInfo.visualDividerBounds.height() / 2f;
|
||||
float horizontalDividerDiff = splitInfo.visualDividerBounds.width() / 2f;
|
||||
float diff;
|
||||
if (desiredStagePosition == SplitConfigurationOptions.STAGE_POSITION_TOP_OR_LEFT) {
|
||||
if (isLandscape) {
|
||||
diff = outRect.width() * (1f - splitInfo.leftTaskPercent) + horizontalDividerDiff;
|
||||
outRect.right -= diff;
|
||||
outRect.right = outRect.left + (int) (outRect.width() * splitInfo.leftTaskPercent);
|
||||
} else {
|
||||
diff = outRect.height() * (1f - splitInfo.topTaskPercent) + verticalDividerDiff;
|
||||
outRect.bottom -= diff;
|
||||
outRect.bottom = outRect.top + (int) (outRect.height() * splitInfo.topTaskPercent);
|
||||
}
|
||||
} else {
|
||||
if (isLandscape) {
|
||||
diff = outRect.width() * splitInfo.leftTaskPercent + horizontalDividerDiff;
|
||||
outRect.left += diff;
|
||||
outRect.left += (int) (outRect.width() *
|
||||
(splitInfo.leftTaskPercent + splitInfo.dividerWidthPercent));
|
||||
} else {
|
||||
diff = outRect.height() * splitInfo.topTaskPercent + verticalDividerDiff;
|
||||
outRect.top += diff;
|
||||
outRect.top += (int) (outRect.height() *
|
||||
(splitInfo.topTaskPercent + splitInfo.dividerHeightPercent));
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -479,9 +474,9 @@ public class PortraitPagedViewHandler implements PagedOrientationHandler {
|
||||
StagedSplitBounds splitBoundsConfig, DeviceProfile dp) {
|
||||
int spaceAboveSnapshot = dp.overviewTaskThumbnailTopMarginPx;
|
||||
int totalThumbnailHeight = parentHeight - spaceAboveSnapshot;
|
||||
int dividerBar = (splitBoundsConfig.appsStackedVertically ?
|
||||
splitBoundsConfig.visualDividerBounds.height() :
|
||||
splitBoundsConfig.visualDividerBounds.width());
|
||||
int dividerBar = splitBoundsConfig.appsStackedVertically
|
||||
? (int) (splitBoundsConfig.dividerHeightPercent * parentHeight)
|
||||
: (int) (splitBoundsConfig.dividerWidthPercent * parentWidth);
|
||||
int primarySnapshotHeight;
|
||||
int primarySnapshotWidth;
|
||||
int secondarySnapshotHeight;
|
||||
|
||||
Reference in New Issue
Block a user