From 22c73e1b07c5b0a91e7c9f608855e651f49fea3e Mon Sep 17 00:00:00 2001 From: Winson Chung Date: Thu, 2 Dec 2010 17:49:28 -0800 Subject: Fix for missing AllApps icons. Change-Id: Ic6c7cc3e55790d9fca1eb260bc9220442e5a9176 --- src/com/android/launcher2/CacheableTextView.java | 32 +++++++++++++++++++----- 1 file changed, 26 insertions(+), 6 deletions(-) (limited to 'src/com/android') diff --git a/src/com/android/launcher2/CacheableTextView.java b/src/com/android/launcher2/CacheableTextView.java index eba29ec0f..50da7cd34 100644 --- a/src/com/android/launcher2/CacheableTextView.java +++ b/src/com/android/launcher2/CacheableTextView.java @@ -18,9 +18,10 @@ package com.android.launcher2; import android.content.Context; import android.graphics.Bitmap; +import android.graphics.Bitmap.Config; import android.graphics.Canvas; import android.graphics.Paint; -import android.graphics.Bitmap.Config; +import android.graphics.Rect; import android.text.Layout; import android.util.AttributeSet; import android.widget.TextView; @@ -66,7 +67,13 @@ public class CacheableTextView extends TextView { } public void buildAndEnableCache() { - if (getLayout() == null) { + // Defers building the cache until the next draw to allow measuring + // and laying out. + buildAndEnableCache(false); + } + + public void buildAndEnableCache(boolean isImmediate) { + if (getLayout() == null || !isImmediate) { mWaitingToGenerateCache = true; return; } @@ -94,8 +101,20 @@ public class CacheableTextView extends TextView { int height = (int) (textCacheBottom - mTextCacheTop); if (width != 0 && height != 0) { - mCache = Bitmap.createBitmap(width, height, Config.ARGB_8888); - mCacheCanvas.setBitmap(mCache); + if (mCache != null) { + if (mCache.getWidth() != width || mCache.getHeight() != height) { + mCache.recycle(); + mCache = null; + } + } + if (mCache == null) { + mCache = Bitmap.createBitmap(width, height, Config.ARGB_8888); + mCacheCanvas.setBitmap(mCache); + } else { + mCacheCanvas.drawColor(0x00000000); + } + + mCacheCanvas.save(); mCacheCanvas.translate(-mTextCacheLeft, -mTextCacheTop); mIsBuildingCache = true; @@ -103,6 +122,7 @@ public class CacheableTextView extends TextView { draw(mCacheCanvas); setAlpha(prevAlpha); mIsBuildingCache = false; + mCacheCanvas.restore(); // A hack-- we set the text to be one space (we don't make it empty just to avoid any // potential issues with text measurement, like line height, etc.) so that the text view @@ -114,10 +134,10 @@ public class CacheableTextView extends TextView { public void draw(Canvas canvas) { if (mWaitingToGenerateCache && !mIsBuildingCache) { - buildAndEnableCache(); + buildAndEnableCache(true); mWaitingToGenerateCache = false; } - if (mCache != null) { + if (mCache != null && !mIsBuildingCache) { canvas.drawBitmap(mCache, mTextCacheLeft - mTextCacheScrollX + mScrollX, mTextCacheTop, mCachePaint); } -- cgit v1.2.3