diff options
author | John Reck <jreck@google.com> | 2011-10-07 16:00:12 -0700 |
---|---|---|
committer | John Reck <jreck@google.com> | 2011-10-07 19:21:47 -0700 |
commit | 9c5004e6d5645cdf32fff3a3f04817a307b84dd6 (patch) | |
tree | 2fa369a23802c025ad79afcdd5cb5a0c933fb3c3 /src/com | |
parent | 983dae2d94c2b90f471138471955875f438670c4 (diff) | |
download | packages_apps_Browser-9c5004e6d5645cdf32fff3a3f04817a307b84dd6.zip packages_apps_Browser-9c5004e6d5645cdf32fff3a3f04817a307b84dd6.tar.gz packages_apps_Browser-9c5004e6d5645cdf32fff3a3f04817a307b84dd6.tar.bz2 |
Improve tab switcher open perf
Bug: 5379115
Change-Id: I5e5bfcfead4c54deb49af94de6f6526bd2710567
Diffstat (limited to 'src/com')
-rw-r--r-- | src/com/android/browser/BaseUi.java | 5 | ||||
-rw-r--r-- | src/com/android/browser/NavScreen.java | 4 | ||||
-rw-r--r-- | src/com/android/browser/PhoneUi.java | 46 | ||||
-rw-r--r-- | src/com/android/browser/Tab.java | 9 |
4 files changed, 49 insertions, 15 deletions
diff --git a/src/com/android/browser/BaseUi.java b/src/com/android/browser/BaseUi.java index ed21b20..26f90b6 100644 --- a/src/com/android/browser/BaseUi.java +++ b/src/com/android/browser/BaseUi.java @@ -801,16 +801,19 @@ public abstract class BaseUi implements UI { mHandler.sendMessageDelayed(msg, duration); } - private Handler mHandler = new Handler() { + protected Handler mHandler = new Handler() { @Override public void handleMessage(Message msg) { if (msg.what == MSG_HIDE_TITLEBAR) { suggestHideTitleBar(); } + BaseUi.this.handleMessage(msg); } }; + protected void handleMessage(Message msg) {} + @Override public void showWeb(boolean animate) { mUiController.hideCustomView(); diff --git a/src/com/android/browser/NavScreen.java b/src/com/android/browser/NavScreen.java index 1626183..45b1dcc 100644 --- a/src/com/android/browser/NavScreen.java +++ b/src/com/android/browser/NavScreen.java @@ -109,6 +109,10 @@ public class NavScreen extends RelativeLayout } } + public void refreshAdapter() { + mAdapter.notifyDataSetChanged(); + } + private void init() { LayoutInflater.from(mContext).inflate(R.layout.nav_screen, this); setContentDescription(mContext.getResources().getString( diff --git a/src/com/android/browser/PhoneUi.java b/src/com/android/browser/PhoneUi.java index 906a246..0e2710d 100644 --- a/src/com/android/browser/PhoneUi.java +++ b/src/com/android/browser/PhoneUi.java @@ -25,6 +25,7 @@ import android.content.Context; import android.graphics.Bitmap; import android.graphics.Canvas; import android.graphics.Matrix; +import android.os.Message; import android.util.Log; import android.util.TypedValue; import android.view.ActionMode; @@ -48,6 +49,7 @@ import com.android.browser.UrlInputView.StateListener; public class PhoneUi extends BaseUi { private static final String LOGTAG = "PhoneUi"; + private static final int MSG_INIT_NAVSCREEN = 100; private PieControlPhone mPieControl; private NavScreen mNavScreen; @@ -127,6 +129,26 @@ public class PhoneUi extends BaseUi { } } } + if (mNavScreen == null && getTitleBar().getHeight() > 0) { + mHandler.sendEmptyMessage(MSG_INIT_NAVSCREEN); + } + } + + @Override + protected void handleMessage(Message msg) { + super.handleMessage(msg); + if (msg.what == MSG_INIT_NAVSCREEN) { + if (mNavScreen == null) { + mNavScreen = new NavScreen(mActivity, mUiController, this); + mCustomViewContainer.addView(mNavScreen, COVER_SCREEN_PARAMS); + mNavScreen.setVisibility(View.GONE); + } + if (mAnimScreen == null) { + mAnimScreen = new AnimScreen(mActivity); + // initialize bitmaps + mAnimScreen.set(getTitleBar(), getWebView()); + } + } } @Override @@ -293,6 +315,7 @@ public class PhoneUi extends BaseUi { } else { mNavScreen.setVisibility(View.VISIBLE); mNavScreen.setAlpha(1f); + mNavScreen.refreshAdapter(); } mActiveTab.capture(); if (mAnimScreen == null) { @@ -403,18 +426,15 @@ public class PhoneUi extends BaseUi { int fromBottom = fromTop + height; float scaleFactor = mContentView.getWidth() / (float) width; int toBottom = toTop + (int) (height * scaleFactor); - ObjectAnimator l1 = ObjectAnimator.ofInt(mAnimScreen.mContent, "left", - fromLeft, fromLeft); - ObjectAnimator t1 = ObjectAnimator.ofInt(mAnimScreen.mContent, "top", - fromTop, fromTop); - ObjectAnimator r1 = ObjectAnimator.ofInt(mAnimScreen.mContent, "right", - fromRight, fromRight); - ObjectAnimator b1 = ObjectAnimator.ofInt(mAnimScreen.mContent, "bottom", - fromBottom, fromBottom); + mAnimScreen.mContent.setLeft(fromLeft); + mAnimScreen.mContent.setTop(fromTop); + mAnimScreen.mContent.setRight(fromRight); + mAnimScreen.mContent.setBottom(fromBottom); + mAnimScreen.setScaleFactor(1f); AnimatorSet set1 = new AnimatorSet(); ObjectAnimator fade2 = ObjectAnimator.ofFloat(mAnimScreen.mMain, "alpha", 0f, 1f); ObjectAnimator fade1 = ObjectAnimator.ofFloat(mNavScreen, "alpha", 1f, 0f); - set1.playTogether(l1, t1, r1, b1, fade1, fade2); + set1.playTogether(fade1, fade2); set1.setDuration(100); AnimatorSet set2 = new AnimatorSet(); ObjectAnimator l = ObjectAnimator.ofInt(mAnimScreen.mContent, "left", @@ -492,16 +512,16 @@ public class PhoneUi extends BaseUi { public void set(TitleBar tbar, WebView web) { if (mTitleBarBitmap == null || mTitleBarBitmap.getWidth() != tbar.getWidth() - || mTitleBarBitmap.getHeight() != tbar.getHeight()) { + || mTitleBarBitmap.getHeight() != tbar.getEmbeddedHeight()) { mTitleBarBitmap = Bitmap.createBitmap(tbar.getWidth(), - tbar.getHeight(), Bitmap.Config.RGB_565); + tbar.getEmbeddedHeight(), Bitmap.Config.RGB_565); } Canvas c = new Canvas(mTitleBarBitmap); tbar.draw(c); c.setBitmap(null); mTitle.setImageBitmap(mTitleBarBitmap); mTitle.setVisibility(View.VISIBLE); - int h = web.getHeight() - tbar.getHeight(); + int h = web.getHeight() - tbar.getEmbeddedHeight(); if (mContentBitmap == null || mContentBitmap.getWidth() != web.getWidth() || mContentBitmap.getHeight() != h) { @@ -511,7 +531,7 @@ public class PhoneUi extends BaseUi { c.setBitmap(mContentBitmap); int tx = web.getScrollX(); int ty = web.getScrollY(); - c.translate(-tx, -ty - tbar.getHeight()); + c.translate(-tx, -ty - tbar.getEmbeddedHeight()); web.draw(c); c.setBitmap(null); mContent.setImageBitmap(mContentBitmap); diff --git a/src/com/android/browser/Tab.java b/src/com/android/browser/Tab.java index f2aa529..839280e 100644 --- a/src/com/android/browser/Tab.java +++ b/src/com/android/browser/Tab.java @@ -2181,13 +2181,20 @@ class Tab implements PictureListener { } } + private static final ThreadLocal<ByteBuffer> sBuffer = new ThreadLocal<ByteBuffer>(); + private byte[] getCaptureBlob() { synchronized (Tab.this) { if (mCapture == null) { return null; } - ByteBuffer buffer = ByteBuffer.allocate(mCapture.getByteCount()); + ByteBuffer buffer = sBuffer.get(); + if (buffer == null || buffer.limit() < mCapture.getByteCount()) { + buffer = ByteBuffer.allocate(mCapture.getByteCount()); + sBuffer.set(buffer); + } mCapture.copyPixelsToBuffer(buffer); + buffer.rewind(); return buffer.array(); } } |