summaryrefslogtreecommitdiffstats
path: root/src/com/android
diff options
context:
space:
mode:
authorcretin45 <cretin45@gmail.com>2015-12-10 15:39:19 -0800
committerTom Powell <zifnab@zifnab06.net>2017-03-26 15:52:42 -0700
commitd70912bc43e81c9cbd5cc7259ab438818ddd6b1e (patch)
treefe10eed6fb173f50c946f331a5c1c7cf018b7796 /src/com/android
parentbdd001df8de0e4b2134e7ba6626053549141d566 (diff)
downloadandroid_packages_apps_Trebuchet-d70912bc43e81c9cbd5cc7259ab438818ddd6b1e.tar.gz
android_packages_apps_Trebuchet-d70912bc43e81c9cbd5cc7259ab438818ddd6b1e.tar.bz2
android_packages_apps_Trebuchet-d70912bc43e81c9cbd5cc7259ab438818ddd6b1e.zip
Trebuchet: Add scrubber to widget view
Change-Id: I68711e95ed31a962b47e995e979e32de37570b44
Diffstat (limited to 'src/com/android')
-rw-r--r--src/com/android/launcher3/Launcher.java13
-rw-r--r--src/com/android/launcher3/LauncherStateTransitionAnimation.java6
-rw-r--r--src/com/android/launcher3/list/SettingsPinnedHeaderAdapter.java1
-rw-r--r--src/com/android/launcher3/widget/WidgetsContainerView.java52
-rw-r--r--src/com/android/launcher3/widget/WidgetsRecyclerView.java44
5 files changed, 114 insertions, 2 deletions
diff --git a/src/com/android/launcher3/Launcher.java b/src/com/android/launcher3/Launcher.java
index 729b9949f..84e5b5161 100644
--- a/src/com/android/launcher3/Launcher.java
+++ b/src/com/android/launcher3/Launcher.java
@@ -1873,6 +1873,19 @@ public class Launcher extends Activity
mAppsView.reset();
}
+ public void reloadWidgetView() {
+ WidgetsModel model = mWidgetsView.getWidgets();
+ mDragLayer.removeView(mWidgetsView);
+ mWidgetsView = (WidgetsContainerView)LayoutInflater
+ .from(this).inflate(R.layout.widgets_view, mDragLayer, false);
+ mDragLayer.addView(mWidgetsView, mDragLayer.getChildCount() - 2);
+ mWidgetsView.setVisibility(View.INVISIBLE);
+ if (model != null) {
+ mWidgetsView.addWidgets(model);
+ }
+ mWidgetsView.reset();
+ }
+
/**
* Replaces currently added fragments in the launcher layout with a
* {@link DynamicGridSizeFragment}.
diff --git a/src/com/android/launcher3/LauncherStateTransitionAnimation.java b/src/com/android/launcher3/LauncherStateTransitionAnimation.java
index cdde8c13f..a0fa61d08 100644
--- a/src/com/android/launcher3/LauncherStateTransitionAnimation.java
+++ b/src/com/android/launcher3/LauncherStateTransitionAnimation.java
@@ -168,6 +168,11 @@ public class LauncherStateTransitionAnimation {
public float getMaterialRevealViewFinalAlpha(View revealView) {
return 0.3f;
}
+
+ @Override
+ void onTransitionComplete() {
+ toView.setScrubberVisibility(View.VISIBLE);
+ }
};
mCurrentAnimation = startAnimationToOverlay(fromWorkspaceState,
Workspace.State.OVERVIEW_HIDDEN, buttonView, toView, toView.getContentView(),
@@ -453,6 +458,7 @@ public class LauncherStateTransitionAnimation {
final Workspace.State toWorkspaceState, final int toWorkspacePage,
final boolean animated, final Runnable onCompleteRunnable) {
final WidgetsContainerView widgetsView = mLauncher.getWidgetsView();
+ widgetsView.setScrubberVisibility(View.INVISIBLE);
PrivateTransitionCallbacks cb = new PrivateTransitionCallbacks() {
@Override
float getMaterialRevealViewFinalAlpha(View revealView) {
diff --git a/src/com/android/launcher3/list/SettingsPinnedHeaderAdapter.java b/src/com/android/launcher3/list/SettingsPinnedHeaderAdapter.java
index 505b6b4ed..f1c0cd87c 100644
--- a/src/com/android/launcher3/list/SettingsPinnedHeaderAdapter.java
+++ b/src/com/android/launcher3/list/SettingsPinnedHeaderAdapter.java
@@ -277,6 +277,7 @@ public class SettingsPinnedHeaderAdapter extends PinnedHeaderListAdapter {
SettingsProvider.SETTINGS_UI_USE_HORIZONTAL_SCRUBBER,
R.bool.preferences_interface_use_horizontal_scrubber_default);
mLauncher.reloadAppDrawer();
+ mLauncher.reloadWidgetView();
break;
}
break;
diff --git a/src/com/android/launcher3/widget/WidgetsContainerView.java b/src/com/android/launcher3/widget/WidgetsContainerView.java
index 268e26ebb..8bc6d5909 100644
--- a/src/com/android/launcher3/widget/WidgetsContainerView.java
+++ b/src/com/android/launcher3/widget/WidgetsContainerView.java
@@ -115,6 +115,19 @@ public class WidgetsContainerView extends BaseContainerView
});
mPadding.set(getPaddingLeft(), getPaddingTop(), getPaddingRight(),
getPaddingBottom());
+ setScroller();
+ updateBackgroundAndPaddings();
+ }
+
+ public void reset() {
+ updateScrubber();
+ updateBackgroundAndPaddings();
+ }
+
+ private void updateScrubber() {
+ if (useScrubber()) {
+ mScrubber.updateSections();
+ }
}
//
@@ -125,6 +138,12 @@ public class WidgetsContainerView extends BaseContainerView
return mView;
}
+ public void setScrubberVisibility(int visibility) {
+ if (mScrubberContainerView != null) {
+ mScrubberContainerView.setVisibility(visibility);
+ }
+ }
+
public View getRevealView() {
// TODO(hyunyoungs): temporarily use apps view transition.
return findViewById(R.id.widgets_reveal_view);
@@ -337,6 +356,7 @@ public class WidgetsContainerView extends BaseContainerView
@Override
protected void onUpdateBackgroundAndPaddings(Rect searchBarBounds, Rect padding) {
+ boolean isRtl = Utilities.isRtl(getResources());
// Apply the top-bottom padding to the content itself so that the launcher transition is
// clipped correctly
mContent.setPadding(0, padding.top, 0, padding.bottom);
@@ -350,6 +370,30 @@ public class WidgetsContainerView extends BaseContainerView
mView.setBackground(background);
getRevealView().setBackground(background.getConstantState().newDrawable());
mView.updateBackgroundPadding(bgPadding);
+
+ int startInset = mView.getMaxScrollbarWidth();
+ int topBottomPadding = getPaddingTop();
+ final boolean useScubber = useScrubber();
+ if (isRtl) {
+ mView.setPadding(padding.left + mView.getMaxScrollbarWidth(),
+ topBottomPadding, padding.right + startInset, useScubber ?
+ mScrubberHeight + topBottomPadding : topBottomPadding);
+ if (useScubber) {
+ mScrubberContainerView
+ .setPadding(padding.left,
+ 0, padding.right, 0);
+ }
+ } else {
+ mView.setPadding(padding.left + startInset, topBottomPadding,
+ padding.right + mView.getMaxScrollbarWidth(),
+ useScubber ? mScrubberHeight + topBottomPadding : topBottomPadding);
+ if (useScubber) {
+ mScrubberContainerView.setPadding(padding.left, 0,
+ padding.right, 0);
+ mScrubberContainerView.setEnabled(true);
+ mScrubberContainerView.bringToFront();
+ }
+ }
}
/**
@@ -359,6 +403,14 @@ public class WidgetsContainerView extends BaseContainerView
mView.setWidgets(model);
mAdapter.setWidgetsModel(model);
mAdapter.notifyDataSetChanged();
+ updateScrubber();
+ }
+
+ public WidgetsModel getWidgets() {
+ if (mView != null) {
+ return mView.getWidgets();
+ }
+ return null;
}
private WidgetPreviewLoader getWidgetPreviewLoader() {
diff --git a/src/com/android/launcher3/widget/WidgetsRecyclerView.java b/src/com/android/launcher3/widget/WidgetsRecyclerView.java
index ac32f154e..6818f3f71 100644
--- a/src/com/android/launcher3/widget/WidgetsRecyclerView.java
+++ b/src/com/android/launcher3/widget/WidgetsRecyclerView.java
@@ -20,13 +20,17 @@ import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.support.v7.widget.LinearLayoutManager;
+import android.text.TextUtils;
import android.util.AttributeSet;
+import android.util.Log;
import android.view.View;
import com.android.launcher3.BaseRecyclerView;
import com.android.launcher3.R;
import com.android.launcher3.model.PackageItemInfo;
import com.android.launcher3.model.WidgetsModel;
+import java.util.ArrayList;
+
/**
* The widgets recycler view.
*/
@@ -70,7 +74,11 @@ public class WidgetsRecyclerView extends BaseRecyclerView {
public void setWidgets(WidgetsModel widgets) {
mWidgets = widgets;
}
-
+
+ public WidgetsModel getWidgets() {
+ return mWidgets;
+ }
+
/**
* We need to override the draw to ensure that we don't draw the overscroll effect beyond the
* background bounds.
@@ -146,12 +154,44 @@ public class WidgetsRecyclerView extends BaseRecyclerView {
@Override
public String scrollToSection(String sectionName) {
+ // Skip early if widgets are not bound.
+ if (mWidgets == null) {
+ return "";
+ }
+
+ // Skip early if there are no widgets.
+ int rowCount = mWidgets.getPackageSize();
+ if (rowCount == 0) {
+ return "";
+ }
+ for (int i = 0; i < rowCount; i++) {
+ PackageItemInfo packageItemInfo = mWidgets.getPackageItemInfo(i);
+ if (packageItemInfo != null && !TextUtils.isEmpty(packageItemInfo.titleSectionName) &&
+ packageItemInfo.titleSectionName.equals(sectionName)) {
+ LinearLayoutManager layoutManager = ((LinearLayoutManager) getLayoutManager());
+ layoutManager.smoothScrollToPosition(this, null, i);
+ return packageItemInfo.titleSectionName;
+ }
+ }
return null;
}
@Override
public String[] getSectionNames() {
- return new String[0];
+ if (mWidgets == null) {
+ return new String[0];
+ }
+ final int N = mWidgets.getPackageSize();
+ ArrayList<String> sections = new ArrayList<>();
+ String lastLetter = null;
+ for (int i = 0; i < N; i++) {
+ final String titleSectionName = mWidgets.getPackageItemInfo(i).titleSectionName;
+ if (!TextUtils.isEmpty(titleSectionName) && !titleSectionName.equals(lastLetter)) {
+ lastLetter = titleSectionName;
+ sections.add(titleSectionName);
+ }
+ }
+ return sections.toArray(new String[sections.size()]);
}
/**