diff options
author | Sunny Goyal <sunnygoyal@google.com> | 2018-01-18 17:14:05 -0800 |
---|---|---|
committer | Sunny Goyal <sunnygoyal@google.com> | 2018-01-19 12:16:54 -0800 |
commit | d1b3f5cb38adc32ac9c0d4391d717d7326efabe8 (patch) | |
tree | c423d50e18fd5deab348a0dbe6074a48da4d274e /src/com/android/launcher3/DropTargetBar.java | |
parent | 599752ed811d9e0a0e5764f3eff62c033bd91948 (diff) | |
download | android_packages_apps_Trebuchet-d1b3f5cb38adc32ac9c0d4391d717d7326efabe8.tar.gz android_packages_apps_Trebuchet-d1b3f5cb38adc32ac9c0d4391d717d7326efabe8.tar.bz2 android_packages_apps_Trebuchet-d1b3f5cb38adc32ac9c0d4391d717d7326efabe8.zip |
Using same layout for drop-target bar in landscape and portrait
> Adding a tooltip on drag over when the text is not visible
Bug: 71709920
Change-Id: I1897a8dacd191fb1aeaec37f5d5c73c49517192a
Diffstat (limited to 'src/com/android/launcher3/DropTargetBar.java')
-rw-r--r-- | src/com/android/launcher3/DropTargetBar.java | 146 |
1 files changed, 82 insertions, 64 deletions
diff --git a/src/com/android/launcher3/DropTargetBar.java b/src/com/android/launcher3/DropTargetBar.java index 494aae45a..d78043d88 100644 --- a/src/com/android/launcher3/DropTargetBar.java +++ b/src/com/android/launcher3/DropTargetBar.java @@ -17,6 +17,9 @@ package com.android.launcher3; import static com.android.launcher3.AlphaUpdateListener.updateVisibility; +import static com.android.launcher3.ButtonDropTarget.TOOLTIP_DEFAULT; +import static com.android.launcher3.ButtonDropTarget.TOOLTIP_LEFT; +import static com.android.launcher3.ButtonDropTarget.TOOLTIP_RIGHT; import static com.android.launcher3.compat.AccessibilityManagerCompat.isAccessibilityEnabled; import android.animation.TimeInterpolator; @@ -26,22 +29,18 @@ import android.util.AttributeSet; import android.view.Gravity; import android.view.View; import android.view.ViewDebug; -import android.view.ViewGroup; import android.view.ViewPropertyAnimator; import android.widget.FrameLayout; -import android.widget.LinearLayout; import com.android.launcher3.anim.Interpolators; import com.android.launcher3.dragndrop.DragController; import com.android.launcher3.dragndrop.DragController.DragListener; import com.android.launcher3.dragndrop.DragOptions; -import java.util.ArrayList; - /* * The top bar containing various drop targets: Delete/App Info/Uninstall. */ -public class DropTargetBar extends LinearLayout +public class DropTargetBar extends FrameLayout implements DragListener, Insettable { protected static final int DEFAULT_DRAG_FADE_DURATION = 175; @@ -59,6 +58,8 @@ public class DropTargetBar extends LinearLayout private ButtonDropTarget[] mDropTargets; private ViewPropertyAnimator mCurrentAnimation; + private boolean mIsVertical = true; + public DropTargetBar(Context context, AttributeSet attrs) { super(context, attrs); } @@ -70,25 +71,30 @@ public class DropTargetBar extends LinearLayout @Override protected void onFinishInflate() { super.onFinishInflate(); - - // Initialize with hidden state - setAlpha(0f); + mDropTargets = new ButtonDropTarget[getChildCount()]; + for (int i = 0; i < mDropTargets.length; i++) { + mDropTargets[i] = (ButtonDropTarget) getChildAt(i); + mDropTargets[i].setDropTargetBar(this); + } } @Override public void setInsets(Rect insets) { FrameLayout.LayoutParams lp = (FrameLayout.LayoutParams) getLayoutParams(); DeviceProfile grid = Launcher.getLauncher(getContext()).getDeviceProfile(); + mIsVertical = grid.isVerticalBarLayout(); lp.leftMargin = insets.left; lp.topMargin = insets.top; lp.bottomMargin = insets.bottom; lp.rightMargin = insets.right; + int tooltipLocation = TOOLTIP_DEFAULT; if (grid.isVerticalBarLayout()) { lp.width = grid.dropTargetBarSizePx; lp.height = grid.availableHeightPx - 2 * grid.edgeMarginPx; lp.gravity = insets.left > insets.right ? Gravity.RIGHT : Gravity.LEFT; + tooltipLocation = insets.left > insets.right ? TOOLTIP_LEFT : TOOLTIP_RIGHT; } else { int gap; if (grid.isTablet) { @@ -107,83 +113,95 @@ public class DropTargetBar extends LinearLayout lp.height = grid.dropTargetBarSizePx; } setLayoutParams(lp); + for (ButtonDropTarget button : mDropTargets) { + button.setToolTipLocation(tooltipLocation); + } } public void setup(DragController dragController) { dragController.addDragListener(this); - ArrayList<ButtonDropTarget> outList = new ArrayList<>(); - findDropTargets(this, outList); - - mDropTargets = new ButtonDropTarget[outList.size()]; for (int i = 0; i < mDropTargets.length; i++) { - mDropTargets[i] = outList.get(i); - mDropTargets[i].setDropTargetBar(this); dragController.addDragListener(mDropTargets[i]); dragController.addDropTarget(mDropTargets[i]); } } - private static void findDropTargets(View view, ArrayList<ButtonDropTarget> outTargets) { - if (view instanceof ButtonDropTarget) { - outTargets.add((ButtonDropTarget) view); - } else if (view instanceof ViewGroup) { - ViewGroup vg = (ViewGroup) view; - for (int i = vg.getChildCount() - 1; i >= 0; i--) { - findDropTargets(vg.getChildAt(i), outTargets); - } - } - } - @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { - super.onMeasure(widthMeasureSpec, heightMeasureSpec); + int width = MeasureSpec.getSize(widthMeasureSpec); + int height = MeasureSpec.getSize(heightMeasureSpec); + + if (mIsVertical) { + int widthSpec = MeasureSpec.makeMeasureSpec(width, MeasureSpec.EXACTLY); + int heightSpec = MeasureSpec.makeMeasureSpec(height, MeasureSpec.AT_MOST); + + for (ButtonDropTarget button : mDropTargets) { + if (button.getVisibility() != GONE) { + button.setTextVisible(false); + button.measure(widthSpec, heightSpec); + } + } + } else { + int visibleCount = getVisibleButtonsCount(); + int availableWidth = width / visibleCount; + boolean textVisible = true; + for (ButtonDropTarget buttons : mDropTargets) { + if (buttons.getVisibility() != GONE) { + textVisible = textVisible && !buttons.isTextTruncated(availableWidth); + } + } - boolean hideText = hideTextHelper(false /* shouldUpdateText */, false /* no-op */); - if (hideTextHelper(true /* shouldUpdateText */, hideText)) { - // Text has changed, so we need to re-measure. - super.onMeasure(widthMeasureSpec, heightMeasureSpec); + int widthSpec = MeasureSpec.makeMeasureSpec(availableWidth, MeasureSpec.AT_MOST); + int heightSpec = MeasureSpec.makeMeasureSpec(height, MeasureSpec.EXACTLY); + for (ButtonDropTarget button : mDropTargets) { + if (button.getVisibility() != GONE) { + button.setTextVisible(textVisible); + button.measure(widthSpec, heightSpec); + } + } } + setMeasuredDimension(width, height); } - /** - * Helper method that iterates through the children and returns whether any of the visible - * {@link ButtonDropTarget} has truncated text. - * - * @param shouldUpdateText If True, updates the text of all children. - * @param hideText If True and {@param shouldUpdateText} is True, clears the text of all - * children; otherwise it sets the original text value. - * - * - * @return If shouldUpdateText is True, returns whether any of the children updated their text. - * Else, returns whether any of the children have truncated their text. - */ - private boolean hideTextHelper(boolean shouldUpdateText, boolean hideText) { - boolean result = false; - View visibleView; - ButtonDropTarget dropTarget; - for (int i = getChildCount() - 1; i >= 0; --i) { - if (getChildAt(i) instanceof ButtonDropTarget) { - visibleView = dropTarget = (ButtonDropTarget) getChildAt(i); - } else if (getChildAt(i) instanceof ViewGroup) { - // The Drop Target is wrapped in a FrameLayout. - visibleView = getChildAt(i); - dropTarget = (ButtonDropTarget) ((ViewGroup) visibleView).getChildAt(0); - } else { - // Ignore other views. - continue; + @Override + protected void onLayout(boolean changed, int left, int top, int right, int bottom) { + if (mIsVertical) { + int gap = getResources().getDimensionPixelSize(R.dimen.drop_target_vertical_gap); + int start = gap; + int end; + + for (ButtonDropTarget button : mDropTargets) { + if (button.getVisibility() != GONE) { + end = start + button.getMeasuredHeight(); + button.layout(0, start, button.getMeasuredWidth(), end); + start = end + gap; + } } - - if (visibleView.getVisibility() == View.VISIBLE) { - if (shouldUpdateText) { - result |= dropTarget.updateText(hideText); - } else if (dropTarget.isTextTruncated()) { - result = true; - break; + } else { + int visibleCount = getVisibleButtonsCount(); + int frameSize = (right - left) / visibleCount; + + int start = frameSize / 2; + int halfWidth; + for (ButtonDropTarget button : mDropTargets) { + if (button.getVisibility() != GONE) { + halfWidth = button.getMeasuredWidth() / 2; + button.layout(start - halfWidth, 0, + start + halfWidth, button.getMeasuredHeight()); + start = start + frameSize; } } } + } - return result; + private int getVisibleButtonsCount() { + int visibleCount = 0; + for (ButtonDropTarget buttons : mDropTargets) { + if (buttons.getVisibility() != GONE) { + visibleCount++; + } + } + return visibleCount; } private void animateToVisibility(boolean isVisible) { |