summaryrefslogtreecommitdiffstats
path: root/core/java/android/view
diff options
context:
space:
mode:
authorDianne Hackborn <>2009-03-31 18:00:36 -0700
committerThe Android Open Source Project <initial-contribution@android.com>2009-03-31 18:00:36 -0700
commit958b9adc086f126dcd757d29f0d7f443ae9064b2 (patch)
tree92b228051319ae7a1c33fb19a90da29009f074a7 /core/java/android/view
parentd928d6837dee4df30b06529164326722075da063 (diff)
downloadframeworks_base-958b9adc086f126dcd757d29f0d7f443ae9064b2.zip
frameworks_base-958b9adc086f126dcd757d29f0d7f443ae9064b2.tar.gz
frameworks_base-958b9adc086f126dcd757d29f0d7f443ae9064b2.tar.bz2
AI 143899: am: CL 143896 Fix issue #1748954 and #1737952:
#1748954 (New status bar fades into all white background): FrameLayout wasn't updating its foreground drawable when its padding changed, which would happen as the status bar is shown and hidden. To fix this I also ended up fixing a problem in the view debug stuff where we couldn't get a bitmap for a view that is the full screen size because it is too big... actually I just went ahead and added another function to snapshot the view hierarchy which works a lot better for us anyway. #1737952 (Home screen icons overlap with the notification bar after exiting any camera app): Originally I punted this because it only happened in rare situations, but now that home is always portrait it happens a lot more so it is more important to fix. This involved a few things to clean up hiding/showing the status bar: - We now determine when to hide and show it during layout, which allows us to do this at the time it is actually needed rather than during animation after we can actually catch it for the initial display of a window. This required tweaking the layout API so the policy can request a second layout pass if needed. - When doing layout, we are now much more aggressive about skipping the layout of windows. Basically anything that we know will be hidden in the near future is ignored for layout, so that it doesn't glitch as it is transfered out of the screen. The theory being that it is better to leave it as it was originally placed while we are transitioning it out, than to switch it to something slightly more correct. Original author: hackbod Merged from: //branches/cupcake/... Automated import of CL 143899
Diffstat (limited to 'core/java/android/view')
-rw-r--r--core/java/android/view/View.java58
-rw-r--r--core/java/android/view/ViewDebug.java33
-rw-r--r--core/java/android/view/WindowManagerPolicy.java5
3 files changed, 73 insertions, 23 deletions
diff --git a/core/java/android/view/View.java b/core/java/android/view/View.java
index 9f4143c..8a65219 100644
--- a/core/java/android/view/View.java
+++ b/core/java/android/view/View.java
@@ -5535,7 +5535,7 @@ public class View implements Drawable.Callback, KeyEvent.Callback {
(mBGDrawable != null && mBGDrawable.getOpacity() == PixelFormat.OPAQUE);
if (width <= 0 || height <= 0 ||
- (width * height * (opaque ? 2 : 4) >= // Projected bitmap size in bytes
+ (width * height * (opaque ? 2 : 4) > // Projected bitmap size in bytes
ViewConfiguration.get(mContext).getScaledMaximumDrawingCacheSize())) {
destroyDrawingCache();
return;
@@ -5632,6 +5632,62 @@ public class View implements Drawable.Callback, KeyEvent.Callback {
}
/**
+ * Create a snapshot of the view into a bitmap. We should probably make
+ * some form of this public, but should think about the API.
+ */
+ /*package*/ Bitmap createSnapshot(Bitmap.Config quality, int backgroundColor) {
+ final int width = mRight - mLeft;
+ final int height = mBottom - mTop;
+
+ Bitmap bitmap = Bitmap.createBitmap(width, height, quality);
+ if (bitmap == null) {
+ throw new OutOfMemoryError();
+ }
+
+ Canvas canvas;
+ final AttachInfo attachInfo = mAttachInfo;
+ if (attachInfo != null) {
+ canvas = attachInfo.mCanvas;
+ if (canvas == null) {
+ canvas = new Canvas();
+ }
+ canvas.setBitmap(bitmap);
+ // Temporarily clobber the cached Canvas in case one of our children
+ // is also using a drawing cache. Without this, the children would
+ // steal the canvas by attaching their own bitmap to it and bad, bad
+ // things would happen (invisible views, corrupted drawings, etc.)
+ attachInfo.mCanvas = null;
+ } else {
+ // This case should hopefully never or seldom happen
+ canvas = new Canvas(bitmap);
+ }
+
+ if ((backgroundColor&0xff000000) != 0) {
+ bitmap.eraseColor(backgroundColor);
+ }
+
+ computeScroll();
+ final int restoreCount = canvas.save();
+ canvas.translate(-mScrollX, -mScrollY);
+
+ // Fast path for layouts with no backgrounds
+ if ((mPrivateFlags & SKIP_DRAW) == SKIP_DRAW) {
+ dispatchDraw(canvas);
+ } else {
+ draw(canvas);
+ }
+
+ canvas.restoreToCount(restoreCount);
+
+ if (attachInfo != null) {
+ // Restore the cached Canvas for our siblings
+ attachInfo.mCanvas = canvas;
+ }
+
+ return bitmap;
+ }
+
+ /**
* Indicates whether this View is currently in edit mode. A View is usually
* in edit mode when displayed within a developer tool. For instance, if
* this View is being drawn by a visual user interface builder, this method
diff --git a/core/java/android/view/ViewDebug.java b/core/java/android/view/ViewDebug.java
index f604bc5..c1e9ed8 100644
--- a/core/java/android/view/ViewDebug.java
+++ b/core/java/android/view/ViewDebug.java
@@ -741,22 +741,18 @@ public class ViewDebug {
final CountDownLatch latch = new CountDownLatch(1);
final Bitmap[] cache = new Bitmap[1];
- final boolean hasCache = captureView.isDrawingCacheEnabled();
- final boolean willNotCache = captureView.willNotCacheDrawing();
-
- if (willNotCache) {
- // TODO: Should happen on the UI thread
- captureView.setWillNotCacheDrawing(false);
- }
-
root.post(new Runnable() {
public void run() {
try {
- if (!hasCache) {
- captureView.buildDrawingCache();
+ cache[0] = captureView.createSnapshot(
+ Bitmap.Config.ARGB_8888, 0);
+ } catch (OutOfMemoryError e) {
+ try {
+ cache[0] = captureView.createSnapshot(
+ Bitmap.Config.ARGB_4444, 0);
+ } catch (OutOfMemoryError e2) {
+ Log.w("View", "Out of memory for bitmap");
}
-
- cache[0] = captureView.getDrawingCache();
} finally {
latch.countDown();
}
@@ -776,20 +772,15 @@ public class ViewDebug {
if (out != null) {
out.close();
}
+ cache[0].recycle();
}
+ } else {
+ Log.w("View", "Failed to create capture bitmap!");
+ clientStream.close();
}
} catch (InterruptedException e) {
Log.w("View", "Could not complete the capture of the view " + captureView);
Thread.currentThread().interrupt();
- } finally {
- if (willNotCache) {
- // TODO: Should happen on the UI thread
- captureView.setWillNotCacheDrawing(true);
- }
- if (!hasCache) {
- // TODO: Should happen on the UI thread
- captureView.destroyDrawingCache();
- }
}
}
}
diff --git a/core/java/android/view/WindowManagerPolicy.java b/core/java/android/view/WindowManagerPolicy.java
index 220869c..1371932 100644
--- a/core/java/android/view/WindowManagerPolicy.java
+++ b/core/java/android/view/WindowManagerPolicy.java
@@ -580,8 +580,11 @@ public interface WindowManagerPolicy {
* Called when layout of the windows is finished. After this function has
* returned, all windows given to layoutWindow() <em>must</em> have had a
* frame assigned.
+ *
+ * @return Return true if layout state may have changed (so that another
+ * layout will be performed).
*/
- public void finishLayoutLw();
+ public boolean finishLayoutLw();
/**
* Called when animation of the windows is about to start.