Merge "Implements the new subscript proactive suggestions style" into ub-launcher3-qt-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
c8dc2ecb4a
@@ -0,0 +1,7 @@
|
|||||||
|
<com.android.quickstep.hints.ProactiveHintsContainer
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center_horizontal|bottom"
|
||||||
|
android:gravity="center_horizontal">
|
||||||
|
</com.android.quickstep.hints.ProactiveHintsContainer>
|
||||||
+18
@@ -31,6 +31,7 @@ import com.android.launcher3.LauncherState;
|
|||||||
import com.android.launcher3.LauncherStateManager.AnimationConfig;
|
import com.android.launcher3.LauncherStateManager.AnimationConfig;
|
||||||
import com.android.launcher3.anim.AnimatorSetBuilder;
|
import com.android.launcher3.anim.AnimatorSetBuilder;
|
||||||
import com.android.launcher3.anim.PropertySetter;
|
import com.android.launcher3.anim.PropertySetter;
|
||||||
|
import com.android.quickstep.hints.ProactiveHintsContainer;
|
||||||
import com.android.quickstep.views.ClearAllButton;
|
import com.android.quickstep.views.ClearAllButton;
|
||||||
import com.android.quickstep.views.LauncherRecentsView;
|
import com.android.quickstep.views.LauncherRecentsView;
|
||||||
import com.android.quickstep.views.RecentsView;
|
import com.android.quickstep.views.RecentsView;
|
||||||
@@ -53,6 +54,14 @@ public final class RecentsViewStateController extends
|
|||||||
if (state.overviewUi) {
|
if (state.overviewUi) {
|
||||||
mRecentsView.updateEmptyMessage();
|
mRecentsView.updateEmptyMessage();
|
||||||
mRecentsView.resetTaskVisuals();
|
mRecentsView.resetTaskVisuals();
|
||||||
|
mRecentsView.setHintVisibility(1f);
|
||||||
|
} else {
|
||||||
|
mRecentsView.setHintVisibility(0f);
|
||||||
|
ProactiveHintsContainer
|
||||||
|
proactiveHintsContainer = mRecentsView.getProactiveHintsContainer();
|
||||||
|
if (proactiveHintsContainer != null) {
|
||||||
|
proactiveHintsContainer.removeAllViews();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
setAlphas(PropertySetter.NO_ANIM_PROPERTY_SETTER, state.getVisibleElements(mLauncher));
|
setAlphas(PropertySetter.NO_ANIM_PROPERTY_SETTER, state.getVisibleElements(mLauncher));
|
||||||
}
|
}
|
||||||
@@ -64,6 +73,14 @@ public final class RecentsViewStateController extends
|
|||||||
|
|
||||||
if (!toState.overviewUi) {
|
if (!toState.overviewUi) {
|
||||||
builder.addOnFinishRunnable(mRecentsView::resetTaskVisuals);
|
builder.addOnFinishRunnable(mRecentsView::resetTaskVisuals);
|
||||||
|
mRecentsView.setHintVisibility(0f);
|
||||||
|
builder.addOnFinishRunnable(() -> {
|
||||||
|
ProactiveHintsContainer
|
||||||
|
proactiveHintsContainer = mRecentsView.getProactiveHintsContainer();
|
||||||
|
if (proactiveHintsContainer != null) {
|
||||||
|
proactiveHintsContainer.removeAllViews();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (toState.overviewUi) {
|
if (toState.overviewUi) {
|
||||||
@@ -75,6 +92,7 @@ public final class RecentsViewStateController extends
|
|||||||
updateAnim.setDuration(config.duration);
|
updateAnim.setDuration(config.duration);
|
||||||
builder.play(updateAnim);
|
builder.play(updateAnim);
|
||||||
mRecentsView.updateEmptyMessage();
|
mRecentsView.updateEmptyMessage();
|
||||||
|
builder.addOnFinishRunnable(() -> mRecentsView.setHintVisibility(1f));
|
||||||
}
|
}
|
||||||
|
|
||||||
setAlphas(config.getPropertySetter(builder), toState.getVisibleElements(mLauncher));
|
setAlphas(config.getPropertySetter(builder), toState.getVisibleElements(mLauncher));
|
||||||
|
|||||||
+55
@@ -0,0 +1,55 @@
|
|||||||
|
package com.android.quickstep.hints;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.util.FloatProperty;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.FrameLayout;
|
||||||
|
|
||||||
|
public class ProactiveHintsContainer extends FrameLayout {
|
||||||
|
|
||||||
|
public static final FloatProperty<ProactiveHintsContainer> HINT_VISIBILITY =
|
||||||
|
new FloatProperty<ProactiveHintsContainer>("hint_visibility") {
|
||||||
|
@Override
|
||||||
|
public void setValue(ProactiveHintsContainer proactiveHintsContainer, float v) {
|
||||||
|
proactiveHintsContainer.setHintVisibility(v);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Float get(ProactiveHintsContainer proactiveHintsContainer) {
|
||||||
|
return proactiveHintsContainer.mHintVisibility;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private float mHintVisibility;
|
||||||
|
|
||||||
|
public ProactiveHintsContainer(Context context) {
|
||||||
|
super(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProactiveHintsContainer(Context context, AttributeSet attrs) {
|
||||||
|
super(context, attrs);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProactiveHintsContainer(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
|
super(context, attrs, defStyleAttr);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProactiveHintsContainer(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
|
||||||
|
super(context, attrs, defStyleAttr, defStyleRes);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setView(View v) {
|
||||||
|
removeAllViews();
|
||||||
|
addView(v);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHintVisibility(float v) {
|
||||||
|
if (v == 1) {
|
||||||
|
setVisibility(VISIBLE);
|
||||||
|
} else {
|
||||||
|
setVisibility(GONE);
|
||||||
|
}
|
||||||
|
mHintVisibility = v;
|
||||||
|
}
|
||||||
|
}
|
||||||
+64
@@ -34,6 +34,8 @@ import android.os.Build;
|
|||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
import com.android.launcher3.DeviceProfile;
|
import com.android.launcher3.DeviceProfile;
|
||||||
import com.android.launcher3.Launcher;
|
import com.android.launcher3.Launcher;
|
||||||
import com.android.launcher3.LauncherState;
|
import com.android.launcher3.LauncherState;
|
||||||
@@ -41,8 +43,11 @@ import com.android.launcher3.R;
|
|||||||
import com.android.launcher3.anim.Interpolators;
|
import com.android.launcher3.anim.Interpolators;
|
||||||
import com.android.launcher3.appprediction.PredictionUiStateManager;
|
import com.android.launcher3.appprediction.PredictionUiStateManager;
|
||||||
import com.android.launcher3.appprediction.PredictionUiStateManager.Client;
|
import com.android.launcher3.appprediction.PredictionUiStateManager.Client;
|
||||||
|
import com.android.launcher3.util.PendingAnimation;
|
||||||
|
import com.android.launcher3.views.BaseDragLayer;
|
||||||
import com.android.launcher3.views.ScrimView;
|
import com.android.launcher3.views.ScrimView;
|
||||||
import com.android.quickstep.SysUINavigationMode;
|
import com.android.quickstep.SysUINavigationMode;
|
||||||
|
import com.android.quickstep.hints.ProactiveHintsContainer;
|
||||||
import com.android.quickstep.util.ClipAnimationHelper;
|
import com.android.quickstep.util.ClipAnimationHelper;
|
||||||
import com.android.quickstep.util.ClipAnimationHelper.TransformParams;
|
import com.android.quickstep.util.ClipAnimationHelper.TransformParams;
|
||||||
import com.android.quickstep.util.LayoutUtils;
|
import com.android.quickstep.util.LayoutUtils;
|
||||||
@@ -54,6 +59,8 @@ import com.android.quickstep.util.LayoutUtils;
|
|||||||
public class LauncherRecentsView extends RecentsView<Launcher> {
|
public class LauncherRecentsView extends RecentsView<Launcher> {
|
||||||
|
|
||||||
private final TransformParams mTransformParams = new TransformParams();
|
private final TransformParams mTransformParams = new TransformParams();
|
||||||
|
private final int mChipOverhang;
|
||||||
|
@Nullable private ProactiveHintsContainer mProactiveHintsContainer;
|
||||||
|
|
||||||
public LauncherRecentsView(Context context) {
|
public LauncherRecentsView(Context context) {
|
||||||
this(context, null);
|
this(context, null);
|
||||||
@@ -66,6 +73,16 @@ public class LauncherRecentsView extends RecentsView<Launcher> {
|
|||||||
public LauncherRecentsView(Context context, AttributeSet attrs, int defStyleAttr) {
|
public LauncherRecentsView(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
super(context, attrs, defStyleAttr);
|
super(context, attrs, defStyleAttr);
|
||||||
setContentAlpha(0);
|
setContentAlpha(0);
|
||||||
|
mChipOverhang = (int) context.getResources().getDimension(R.dimen.chip_hint_overhang);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onAttachedToWindow() {
|
||||||
|
super.onAttachedToWindow();
|
||||||
|
View hintContainer = mActivity.findViewById(R.id.hints);
|
||||||
|
mProactiveHintsContainer =
|
||||||
|
hintContainer instanceof ProactiveHintsContainer
|
||||||
|
? (ProactiveHintsContainer) hintContainer : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -84,6 +101,11 @@ public class LauncherRecentsView extends RecentsView<Launcher> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
public ProactiveHintsContainer getProactiveHintsContainer() {
|
||||||
|
return mProactiveHintsContainer;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void draw(Canvas canvas) {
|
public void draw(Canvas canvas) {
|
||||||
maybeDrawEmptyMessage(canvas);
|
maybeDrawEmptyMessage(canvas);
|
||||||
@@ -137,6 +159,48 @@ public class LauncherRecentsView extends RecentsView<Launcher> {
|
|||||||
@Override
|
@Override
|
||||||
protected void getTaskSize(DeviceProfile dp, Rect outRect) {
|
protected void getTaskSize(DeviceProfile dp, Rect outRect) {
|
||||||
LayoutUtils.calculateLauncherTaskSize(getContext(), dp, outRect);
|
LayoutUtils.calculateLauncherTaskSize(getContext(), dp, outRect);
|
||||||
|
if (mProactiveHintsContainer != null) {
|
||||||
|
BaseDragLayer.LayoutParams params = (BaseDragLayer.LayoutParams) mProactiveHintsContainer.getLayoutParams();
|
||||||
|
params.bottomMargin = getHeight() - outRect.bottom - mChipOverhang;
|
||||||
|
params.width = outRect.width();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PendingAnimation createTaskLauncherAnimation(TaskView tv, long duration) {
|
||||||
|
PendingAnimation anim = super.createTaskLauncherAnimation(tv, duration);
|
||||||
|
|
||||||
|
if (mProactiveHintsContainer != null) {
|
||||||
|
anim.anim.play(ObjectAnimator.ofFloat(
|
||||||
|
mProactiveHintsContainer, ProactiveHintsContainer.HINT_VISIBILITY, 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
return anim;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PendingAnimation createTaskDismissAnimation(TaskView taskView, boolean animateTaskView,
|
||||||
|
boolean shouldRemoveTask, long duration) {
|
||||||
|
PendingAnimation anim = super.createTaskDismissAnimation(taskView, animateTaskView,
|
||||||
|
shouldRemoveTask, duration);
|
||||||
|
|
||||||
|
if (mProactiveHintsContainer != null) {
|
||||||
|
anim.anim.play(ObjectAnimator.ofFloat(
|
||||||
|
mProactiveHintsContainer, ProactiveHintsContainer.HINT_VISIBILITY, 0));
|
||||||
|
anim.addEndListener(onEndListener -> {
|
||||||
|
if (!onEndListener.isSuccess) {
|
||||||
|
mProactiveHintsContainer.setHintVisibility(1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return anim;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHintVisibility(float v) {
|
||||||
|
if (mProactiveHintsContainer != null) {
|
||||||
|
mProactiveHintsContainer.setHintVisibility(v);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -48,6 +48,11 @@
|
|||||||
layout="@layout/overview_panel"
|
layout="@layout/overview_panel"
|
||||||
android:visibility="gone" />
|
android:visibility="gone" />
|
||||||
|
|
||||||
|
<include
|
||||||
|
android:id="@+id/hints"
|
||||||
|
layout="@layout/proactive_hints_container"
|
||||||
|
android:visibility="gone"/>
|
||||||
|
|
||||||
<!-- Keep these behind the workspace so that they are not visible when
|
<!-- Keep these behind the workspace so that they are not visible when
|
||||||
we go into AllApps -->
|
we go into AllApps -->
|
||||||
<com.android.launcher3.pageindicators.WorkspacePageIndicator
|
<com.android.launcher3.pageindicators.WorkspacePageIndicator
|
||||||
|
|||||||
@@ -0,0 +1,20 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright (C) 2016 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
|
<Space
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="0dp" />
|
||||||
@@ -235,6 +235,7 @@
|
|||||||
<!-- Hints -->
|
<!-- Hints -->
|
||||||
<dimen name="chip_hint_height">26dp</dimen>
|
<dimen name="chip_hint_height">26dp</dimen>
|
||||||
<dimen name="chip_hint_bottom_margin">194dp</dimen>
|
<dimen name="chip_hint_bottom_margin">194dp</dimen>
|
||||||
|
<dimen name="chip_hint_overhang">15dp</dimen>
|
||||||
|
|
||||||
<!-- Theming related -->
|
<!-- Theming related -->
|
||||||
<dimen name="default_dialog_corner_radius">8dp</dimen>
|
<dimen name="default_dialog_corner_radius">8dp</dimen>
|
||||||
|
|||||||
Reference in New Issue
Block a user