summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--res/values-land/strings.xml7
-rw-r--r--res/values-large/strings.xml7
-rw-r--r--res/values/strings.xml2
-rw-r--r--src/com/android/launcher2/AppsCustomizePagedView.java20
-rw-r--r--src/com/android/launcher2/DeleteDropTarget.java9
-rw-r--r--src/com/android/launcher2/InfoDropTarget.java21
-rw-r--r--src/com/android/launcher2/SearchDropTargetBar.java65
-rw-r--r--src/com/android/launcher2/Workspace.java11
8 files changed, 100 insertions, 42 deletions
diff --git a/res/values-land/strings.xml b/res/values-land/strings.xml
index bbe8ff21f..ec4c7e706 100644
--- a/res/values-land/strings.xml
+++ b/res/values-land/strings.xml
@@ -20,11 +20,4 @@
<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
<!-- Manifest configuration. -->
<skip />
-
- <!-- Label for delete drop target. [CHAR_LIMIT=30] -->
- <string name="delete_target_label"></string>
- <!-- Label for uninstall drop target. [CHAR_LIMIT=30]-->
- <string name="delete_target_uninstall_label"></string>
- <!-- Label for the info icon. [CHAR_LIMIT=30] -->
- <string name="info_target_label"></string>
</resources>
diff --git a/res/values-large/strings.xml b/res/values-large/strings.xml
index 3fe8af0c3..75a22a2c5 100644
--- a/res/values-large/strings.xml
+++ b/res/values-large/strings.xml
@@ -26,11 +26,4 @@
<!-- Negative button text for the wallpaper selection dialog [CHAR_LIMIT=40]-->
<string name="wallpaper_cancel">Cancel</string>
-
- <!-- Label for delete drop target. [CHAR_LIMIT=30] -->
- <string name="delete_target_label">Remove</string>
- <!-- Label for uninstall drop target. [CHAR_LIMIT=30]-->
- <string name="delete_target_uninstall_label">Uninstall</string>
- <!-- Label for the info icon. [CHAR_LIMIT=30] -->
- <string name="info_target_label">Manage</string>
</resources> \ No newline at end of file
diff --git a/res/values/strings.xml b/res/values/strings.xml
index 0ad1a46f2..95f711c30 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -168,7 +168,7 @@
<!-- Label for uninstall drop target. [CHAR_LIMIT=30]-->
<string name="delete_target_uninstall_label">Uninstall</string>
<!-- Label for the info icon. [CHAR_LIMIT=30] -->
- <string name="info_target_label">Manage</string>
+ <string name="info_target_label">App info</string>
<!-- Accessibility: Search button -->
<string name="accessibility_search_button">Search</string>
diff --git a/src/com/android/launcher2/AppsCustomizePagedView.java b/src/com/android/launcher2/AppsCustomizePagedView.java
index 5b4f15062..c27e3759d 100644
--- a/src/com/android/launcher2/AppsCustomizePagedView.java
+++ b/src/com/android/launcher2/AppsCustomizePagedView.java
@@ -508,15 +508,17 @@ public class AppsCustomizePagedView extends PagedViewWithDraggableItems implemen
}
private void renderDrawableToBitmap(Drawable d, Bitmap bitmap, int x, int y, int w, int h,
float scaleX, float scaleY) {
- Canvas c = new Canvas();
- if (bitmap != null) c.setBitmap(bitmap);
- c.save();
- c.scale(scaleX, scaleY);
- Rect oldBounds = d.copyBounds();
- d.setBounds(x, y, x + w, y + h);
- d.draw(c);
- d.setBounds(oldBounds); // Restore the bounds
- c.restore();
+ if (bitmap != null) {
+ Canvas c = new Canvas();
+ c.setBitmap(bitmap);
+ c.save();
+ c.scale(scaleX, scaleY);
+ Rect oldBounds = d.copyBounds();
+ d.setBounds(x, y, x + w, y + h);
+ d.draw(c);
+ d.setBounds(oldBounds); // Restore the bounds
+ c.restore();
+ }
}
private FastBitmapDrawable getShortcutPreview(ResolveInfo info, int cellWidth, int cellHeight) {
// Return the cached version if necessary
diff --git a/src/com/android/launcher2/DeleteDropTarget.java b/src/com/android/launcher2/DeleteDropTarget.java
index 5b3fd1e16..a30c03e66 100644
--- a/src/com/android/launcher2/DeleteDropTarget.java
+++ b/src/com/android/launcher2/DeleteDropTarget.java
@@ -18,6 +18,7 @@ package com.android.launcher2;
import android.animation.ObjectAnimator;
import android.content.Context;
+import android.content.res.Configuration;
import android.content.res.Resources;
import android.graphics.Color;
import android.graphics.PorterDuff;
@@ -56,6 +57,14 @@ public class DeleteDropTarget extends ButtonDropTarget {
mHoverColor, PorterDuff.Mode.SRC_ATOP));
setBackgroundColor(mHoverColor);
getBackground().setAlpha(0);
+
+ // Remove the text in the Phone UI in landscape
+ int orientation = getResources().getConfiguration().orientation;
+ if (orientation == Configuration.ORIENTATION_LANDSCAPE) {
+ if (!LauncherApplication.isScreenLarge()) {
+ mText.setText("");
+ }
+ }
}
private boolean isAllAppsApplication(DragSource source, Object info) {
diff --git a/src/com/android/launcher2/InfoDropTarget.java b/src/com/android/launcher2/InfoDropTarget.java
index 7e6b700df..76a6bf926 100644
--- a/src/com/android/launcher2/InfoDropTarget.java
+++ b/src/com/android/launcher2/InfoDropTarget.java
@@ -19,17 +19,20 @@ package com.android.launcher2;
import android.animation.ObjectAnimator;
import android.content.ComponentName;
import android.content.Context;
+import android.content.res.Configuration;
import android.content.res.Resources;
import android.graphics.Color;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffColorFilter;
import android.util.AttributeSet;
import android.view.View;
+import android.widget.TextView;
import com.android.launcher.R;
public class InfoDropTarget extends ButtonDropTarget {
+ private TextView mText;
private int mHoverColor = 0xFF0000FF;
public InfoDropTarget(Context context, AttributeSet attrs) {
@@ -44,6 +47,8 @@ public class InfoDropTarget extends ButtonDropTarget {
protected void onFinishInflate() {
super.onFinishInflate();
+ mText = (TextView) findViewById(R.id.info_target_text);
+
// Get the hover color
Resources r = getResources();
mHoverColor = r.getColor(R.color.info_target_hover_tint);
@@ -51,11 +56,18 @@ public class InfoDropTarget extends ButtonDropTarget {
mHoverColor, PorterDuff.Mode.SRC_ATOP));
setBackgroundColor(mHoverColor);
getBackground().setAlpha(0);
+
+ // Remove the text in the Phone UI in landscape
+ int orientation = getResources().getConfiguration().orientation;
+ if (orientation == Configuration.ORIENTATION_LANDSCAPE) {
+ if (!LauncherApplication.isScreenLarge()) {
+ mText.setText("");
+ }
+ }
}
- private boolean isApplication(Object info) {
- if (info instanceof ApplicationInfo) return true;
- return (((ItemInfo) info).itemType == LauncherSettings.Favorites.ITEM_TYPE_APPLICATION);
+ private boolean isAllAppsApplication(DragSource source, Object info) {
+ return (source instanceof AppsCustomizePagedView) && (info instanceof ApplicationInfo);
}
@Override
@@ -77,11 +89,10 @@ public class InfoDropTarget extends ButtonDropTarget {
@Override
public void onDragStart(DragSource source, Object info, int dragAction) {
- ItemInfo item = (ItemInfo) info;
boolean isVisible = true;
// If we are dragging a widget or shortcut, hide the info target
- if (!isApplication(info)) {
+ if (!isAllAppsApplication(source, info)) {
isVisible = false;
}
diff --git a/src/com/android/launcher2/SearchDropTargetBar.java b/src/com/android/launcher2/SearchDropTargetBar.java
index d00e2103f..943bd00bd 100644
--- a/src/com/android/launcher2/SearchDropTargetBar.java
+++ b/src/com/android/launcher2/SearchDropTargetBar.java
@@ -16,6 +16,9 @@
package com.android.launcher2;
+import android.animation.Animator;
+import android.animation.AnimatorListenerAdapter;
+import android.animation.ObjectAnimator;
import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
@@ -32,6 +35,11 @@ public class SearchDropTargetBar extends FrameLayout implements DragController.D
private static final int sTransitionInDuration = 275;
private static final int sTransitionOutDuration = 100;
+ private ObjectAnimator mDropTargetBarFadeInAnim;
+ private ObjectAnimator mDropTargetBarFadeOutAnim;
+ private ObjectAnimator mQSBSearchBarFadeInAnim;
+ private ObjectAnimator mQSBSearchBarFadeOutAnim;
+
private boolean mIsSearchBarHidden;
private View mQSBSearchBar;
private View mDropTargetBar;
@@ -66,23 +74,68 @@ public class SearchDropTargetBar extends FrameLayout implements DragController.D
mDropTargetBar = findViewById(R.id.drag_target_bar);
mInfoDropTarget = (ButtonDropTarget) mDropTargetBar.findViewById(R.id.info_target);
mDeleteDropTarget = (ButtonDropTarget) mDropTargetBar.findViewById(R.id.delete_target);
+
+ // Create the various fade animations
+ mDropTargetBarFadeInAnim = ObjectAnimator.ofFloat(mDropTargetBar, "alpha", 1f);
+ mDropTargetBarFadeInAnim.setDuration(sTransitionInDuration);
+ mDropTargetBarFadeInAnim.addListener(new AnimatorListenerAdapter() {
+ @Override
+ public void onAnimationStart(Animator animation) {
+ mDropTargetBar.setVisibility(View.VISIBLE);
+ }
+ });
+ mDropTargetBarFadeOutAnim = ObjectAnimator.ofFloat(mDropTargetBar, "alpha", 0f);
+ mDropTargetBarFadeOutAnim.setDuration(sTransitionOutDuration);
+ mDropTargetBarFadeOutAnim.addListener(new AnimatorListenerAdapter() {
+ @Override
+ public void onAnimationEnd(Animator animation) {
+ mDropTargetBar.setVisibility(View.GONE);
+ }
+ });
+ mQSBSearchBarFadeInAnim = ObjectAnimator.ofFloat(mQSBSearchBar, "alpha", 1f);
+ mQSBSearchBarFadeInAnim.setDuration(sTransitionInDuration);
+ mQSBSearchBarFadeInAnim.addListener(new AnimatorListenerAdapter() {
+ @Override
+ public void onAnimationStart(Animator animation) {
+ mQSBSearchBar.setVisibility(View.VISIBLE);
+ }
+ });
+ mQSBSearchBarFadeOutAnim = ObjectAnimator.ofFloat(mQSBSearchBar, "alpha", 0f);
+ mQSBSearchBarFadeOutAnim.setDuration(sTransitionOutDuration);
+ mQSBSearchBarFadeOutAnim.addListener(new AnimatorListenerAdapter() {
+ @Override
+ public void onAnimationEnd(Animator animation) {
+ mQSBSearchBar.setVisibility(View.GONE);
+ }
+ });
+ }
+
+ private void cancelAnimations() {
+ mDropTargetBarFadeInAnim.cancel();
+ mDropTargetBarFadeOutAnim.cancel();
+ mQSBSearchBarFadeInAnim.cancel();
+ mQSBSearchBarFadeOutAnim.cancel();
}
/*
* Shows and hides the search bar.
*/
public void showSearchBar(boolean animated) {
+ cancelAnimations();
if (animated) {
- mQSBSearchBar.animate().alpha(1f).setDuration(sTransitionInDuration);
+ mQSBSearchBarFadeInAnim.start();
} else {
+ mQSBSearchBar.setVisibility(View.VISIBLE);
mQSBSearchBar.setAlpha(1f);
}
mIsSearchBarHidden = false;
}
public void hideSearchBar(boolean animated) {
+ cancelAnimations();
if (animated) {
- mQSBSearchBar.animate().alpha(0f).setDuration(sTransitionOutDuration);
+ mQSBSearchBarFadeOutAnim.start();
} else {
+ mQSBSearchBar.setVisibility(View.GONE);
mQSBSearchBar.setAlpha(0f);
}
mIsSearchBarHidden = true;
@@ -104,18 +157,18 @@ public class SearchDropTargetBar extends FrameLayout implements DragController.D
@Override
public void onDragStart(DragSource source, Object info, int dragAction) {
// Animate out the QSB search bar, and animate in the drop target bar
- mDropTargetBar.animate().alpha(1f).setDuration(sTransitionInDuration);
+ mDropTargetBarFadeInAnim.start();
if (!mIsSearchBarHidden) {
- mQSBSearchBar.animate().alpha(0f).setDuration(sTransitionOutDuration);
+ mQSBSearchBarFadeOutAnim.start();
}
}
@Override
public void onDragEnd() {
// Restore the QSB search bar, and animate out the drop target bar
- mDropTargetBar.animate().alpha(0f).setDuration(sTransitionOutDuration);
+ mDropTargetBarFadeOutAnim.start();
if (!mIsSearchBarHidden) {
- mQSBSearchBar.animate().alpha(1f).setDuration(sTransitionInDuration);
+ mQSBSearchBarFadeInAnim.start();
}
}
}
diff --git a/src/com/android/launcher2/Workspace.java b/src/com/android/launcher2/Workspace.java
index 1048fd570..7165865e3 100644
--- a/src/com/android/launcher2/Workspace.java
+++ b/src/com/android/launcher2/Workspace.java
@@ -735,13 +735,10 @@ public class Workspace extends SmoothPagedView
protected void setWallpaperDimension() {
Display display = mLauncher.getWindowManager().getDefaultDisplay();
- Point displaySize = new Point();
- display.getSize(displaySize);
- if (LauncherApplication.isScreenLarge()) {
- displaySize.y += (int) getResources().getDimension(R.dimen.status_bar_height);
- }
- final int maxDim = Math.max(displaySize.x, displaySize.y);
- final int minDim = Math.min(displaySize.x, displaySize.y);
+ DisplayMetrics displayMetrics = new DisplayMetrics();
+ display.getRealMetrics(displayMetrics);
+ final int maxDim = Math.max(displayMetrics.widthPixels, displayMetrics.heightPixels);
+ final int minDim = Math.min(displayMetrics.widthPixels, displayMetrics.heightPixels);
// We need to ensure that there is enough extra space in the wallpaper for the intended
// parallax effects