mirror of
https://github.com/LawnchairLauncher/lawnchair.git
synced 2026-02-19 18:58:19 +00:00
resolve merge conflicts of 3826bab27e to ub-launcher3-calgary.
Change-Id: I14ff2d67de4ba97628bdf651602724f9f4989173
This commit is contained in:
@@ -17,34 +17,40 @@
|
||||
package com.android.launcher3;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.res.TypedArray;
|
||||
import android.graphics.Rect;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.graphics.drawable.InsetDrawable;
|
||||
import android.util.AttributeSet;
|
||||
import android.util.Log;
|
||||
import android.widget.LinearLayout;
|
||||
import android.view.View;
|
||||
import android.widget.FrameLayout;
|
||||
|
||||
import com.android.launcher3.config.ProviderConfig;
|
||||
|
||||
/**
|
||||
* A base container view, which supports resizing.
|
||||
*/
|
||||
public abstract class BaseContainerView extends LinearLayout implements Insettable {
|
||||
public abstract class BaseContainerView extends FrameLayout implements Insettable {
|
||||
|
||||
private final static String TAG = "BaseContainerView";
|
||||
|
||||
// The window insets
|
||||
private Rect mInsets = new Rect();
|
||||
private final Rect mInsets = new Rect();
|
||||
// The bounds of the search bar. Only the left, top, right are used to inset the
|
||||
// search bar and the height is determined by the measurement of the layout
|
||||
private Rect mFixedSearchBarBounds = new Rect();
|
||||
// The computed bounds of the search bar
|
||||
private Rect mSearchBarBounds = new Rect();
|
||||
private final Rect mFixedSearchBarBounds = new Rect();
|
||||
// The computed bounds of the container
|
||||
protected Rect mContentBounds = new Rect();
|
||||
protected final Rect mContentBounds = new Rect();
|
||||
// The computed padding to apply to the container to achieve the container bounds
|
||||
private Rect mContentPadding = new Rect();
|
||||
private final Rect mContentPadding = new Rect();
|
||||
// The inset to apply to the edges and between the search bar and the container
|
||||
private int mContainerBoundsInset;
|
||||
private boolean mHasSearchBar;
|
||||
private final int mContainerBoundsInset;
|
||||
|
||||
private final Drawable mRevealDrawable;
|
||||
|
||||
private View mRevealView;
|
||||
private View mContent;
|
||||
|
||||
public BaseContainerView(Context context) {
|
||||
this(context, null);
|
||||
@@ -57,6 +63,19 @@ public abstract class BaseContainerView extends LinearLayout implements Insettab
|
||||
public BaseContainerView(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||
super(context, attrs, defStyleAttr);
|
||||
mContainerBoundsInset = getResources().getDimensionPixelSize(R.dimen.container_bounds_inset);
|
||||
|
||||
TypedArray a = context.obtainStyledAttributes(attrs,
|
||||
R.styleable.BaseContainerView, defStyleAttr, 0);
|
||||
mRevealDrawable = a.getDrawable(R.styleable.BaseContainerView_revealBackground);
|
||||
a.recycle();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onFinishInflate() {
|
||||
super.onFinishInflate();
|
||||
|
||||
mContent = findViewById(R.id.main_content);
|
||||
mRevealView = findViewById(R.id.reveal_view);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -65,10 +84,6 @@ public abstract class BaseContainerView extends LinearLayout implements Insettab
|
||||
updateBackgroundAndPaddings();
|
||||
}
|
||||
|
||||
protected void setHasSearchBar() {
|
||||
mHasSearchBar = true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the search bar bounds for this container view to match.
|
||||
*/
|
||||
@@ -94,47 +109,48 @@ public abstract class BaseContainerView extends LinearLayout implements Insettab
|
||||
*/
|
||||
protected void updateBackgroundAndPaddings() {
|
||||
Rect padding;
|
||||
Rect searchBarBounds = new Rect();
|
||||
if (!isValidSearchBarBounds(mFixedSearchBarBounds)) {
|
||||
// Use the default bounds
|
||||
padding = new Rect(mInsets.left + mContainerBoundsInset,
|
||||
(mHasSearchBar ? 0 : (mInsets.top + mContainerBoundsInset)),
|
||||
mInsets.right + mContainerBoundsInset,
|
||||
mInsets.bottom + mContainerBoundsInset);
|
||||
|
||||
// Special case -- we have the search bar, but no specific bounds, so just give it
|
||||
// the inset bounds without a height.
|
||||
searchBarBounds.set(mInsets.left + mContainerBoundsInset,
|
||||
if (isValidSearchBarBounds(mFixedSearchBarBounds)) {
|
||||
padding = new Rect(
|
||||
mFixedSearchBarBounds.left,
|
||||
mInsets.top + mContainerBoundsInset,
|
||||
getMeasuredWidth() - (mInsets.right + mContainerBoundsInset), 0);
|
||||
} else {
|
||||
// Use the search bounds, if there is a search bar, the bounds will contain
|
||||
// the offsets for the insets so we can ignore that
|
||||
padding = new Rect(mFixedSearchBarBounds.left,
|
||||
(mHasSearchBar ? 0 : (mInsets.top + mContainerBoundsInset)),
|
||||
getMeasuredWidth() - mFixedSearchBarBounds.right,
|
||||
mInsets.bottom + mContainerBoundsInset);
|
||||
|
||||
// Use the search bounds
|
||||
searchBarBounds.set(mFixedSearchBarBounds);
|
||||
mInsets.bottom + mContainerBoundsInset
|
||||
);
|
||||
} else {
|
||||
padding = new Rect(
|
||||
mInsets.left + mContainerBoundsInset,
|
||||
mInsets.top + mContainerBoundsInset,
|
||||
mInsets.right + mContainerBoundsInset,
|
||||
mInsets.bottom + mContainerBoundsInset
|
||||
);
|
||||
}
|
||||
|
||||
// If either the computed container padding has changed, or the computed search bar bounds
|
||||
// has changed, then notify the container
|
||||
if (!padding.equals(mContentPadding) || !searchBarBounds.equals(mSearchBarBounds)) {
|
||||
// The container padding changed, notify the container.
|
||||
if (!padding.equals(mContentPadding)) {
|
||||
mContentPadding.set(padding);
|
||||
mContentBounds.set(padding.left, padding.top,
|
||||
getMeasuredWidth() - padding.right,
|
||||
getMeasuredHeight() - padding.bottom);
|
||||
mSearchBarBounds.set(searchBarBounds);
|
||||
onUpdateBackgroundAndPaddings(mSearchBarBounds, padding);
|
||||
onUpdateBackgroundAndPaddings(padding);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* To be implemented by container views to update themselves when the bounds changes.
|
||||
*/
|
||||
protected abstract void onUpdateBackgroundAndPaddings(Rect searchBarBounds, Rect padding);
|
||||
private void onUpdateBackgroundAndPaddings(Rect padding) {
|
||||
// Apply the top-bottom padding to itself so that the launcher transition is
|
||||
// clipped correctly
|
||||
setPadding(0, padding.top, 0, padding.bottom);
|
||||
|
||||
InsetDrawable background = new InsetDrawable(mRevealDrawable,
|
||||
padding.left, 0, padding.right, 0);
|
||||
mRevealView.setBackground(background.getConstantState().newDrawable());
|
||||
mContent.setBackground(background);
|
||||
|
||||
Rect bgPadding = new Rect();
|
||||
background.getPadding(bgPadding);
|
||||
onUpdateBgPadding(padding, bgPadding);
|
||||
}
|
||||
|
||||
protected abstract void onUpdateBgPadding(Rect padding, Rect bgPadding);
|
||||
|
||||
/**
|
||||
* Returns whether the search bar bounds we got are considered valid.
|
||||
@@ -144,4 +160,12 @@ public abstract class BaseContainerView extends LinearLayout implements Insettab
|
||||
searchBarBounds.right <= getMeasuredWidth() &&
|
||||
searchBarBounds.bottom <= getMeasuredHeight();
|
||||
}
|
||||
|
||||
public final View getContentView() {
|
||||
return mContent;
|
||||
}
|
||||
|
||||
public final View getRevealView() {
|
||||
return mRevealView;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user