summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDianne Hackborn <hackbod@google.com>2009-08-10 23:21:09 -0700
committerDianne Hackborn <hackbod@google.com>2009-08-10 23:21:09 -0700
commit8f573952b8729b4319043ae0908997ecd2d68951 (patch)
treea3474520544910d90bf68e6807cf292696ed99c2
parentb1b69f53a878ca45a2781bb0d713f3f97d594aa4 (diff)
downloadpackages_apps_trebuchet-8f573952b8729b4319043ae0908997ecd2d68951.zip
packages_apps_trebuchet-8f573952b8729b4319043ae0908997ecd2d68951.tar.gz
packages_apps_trebuchet-8f573952b8729b4319043ae0908997ecd2d68951.tar.bz2
Update to scroll the wallpaper.
-rw-r--r--src/com/android/launcher2/Workspace.java14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/com/android/launcher2/Workspace.java b/src/com/android/launcher2/Workspace.java
index 1ff0c28..bfda303 100644
--- a/src/com/android/launcher2/Workspace.java
+++ b/src/com/android/launcher2/Workspace.java
@@ -16,6 +16,7 @@
package com.android.launcher2;
+import android.app.WallpaperManager;
import android.content.Context;
import android.content.Intent;
import android.content.ComponentName;
@@ -52,6 +53,8 @@ public class Workspace extends ViewGroup implements DropTarget, DragSource, Drag
*/
private static final int SNAP_VELOCITY = 1000;
+ private final WallpaperManager mWallpaperManager;
+
private int mDefaultScreen;
private boolean mFirstLayout = true;
@@ -126,6 +129,8 @@ public class Workspace extends ViewGroup implements DropTarget, DragSource, Drag
public Workspace(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
+ mWallpaperManager = WallpaperManager.getInstance(context);
+
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.Workspace, defStyle, 0);
mDefaultScreen = a.getInt(R.styleable.Workspace_defaultScreen, 1);
a.recycle();
@@ -450,11 +455,18 @@ public class Workspace extends ViewGroup implements DropTarget, DragSource, Drag
}
}
+ private void updateWallpaperOffset() {
+ int scrollRange = getChildAt(getChildCount()-1).getRight()-getWidth();
+ mWallpaperManager.setWallpaperOffsets(getWindowToken(),
+ mScrollX/(float)scrollRange, 0);
+ }
+
@Override
public void computeScroll() {
if (mScroller.computeScrollOffset()) {
mScrollX = mScroller.getCurrX();
mScrollY = mScroller.getCurrY();
+ updateWallpaperOffset();
postInvalidate();
} else if (mNextScreen != INVALID_SCREEN) {
mCurrentScreen = Math.max(0, Math.min(mNextScreen, getChildCount() - 1));
@@ -769,12 +781,14 @@ public class Workspace extends ViewGroup implements DropTarget, DragSource, Drag
if (deltaX < 0) {
if (mScrollX > 0) {
scrollBy(Math.max(-mScrollX, deltaX), 0);
+ updateWallpaperOffset();
}
} else if (deltaX > 0) {
final int availableToScroll = getChildAt(getChildCount() - 1).getRight() -
mScrollX - getWidth();
if (availableToScroll > 0) {
scrollBy(Math.min(availableToScroll, deltaX), 0);
+ updateWallpaperOffset();
}
}
}