diff options
| author | Teng-Hui Zhu <ztenghui@google.com> | 2010-12-08 09:12:10 -0800 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2010-12-08 09:12:10 -0800 |
| commit | c948d07b2a0f2bfdbe999bc1baa2ee4b2de513e6 (patch) | |
| tree | 182352696bd2c1567bb77d04e399a4b18da75068 | |
| parent | f69583cde5e4e8c3337c2196f8102f987ef9ea61 (diff) | |
| parent | 5513337a4c812a6ffaed07edcf654c8bf921ad89 (diff) | |
| download | frameworks_base-c948d07b2a0f2bfdbe999bc1baa2ee4b2de513e6.zip frameworks_base-c948d07b2a0f2bfdbe999bc1baa2ee4b2de513e6.tar.gz frameworks_base-c948d07b2a0f2bfdbe999bc1baa2ee4b2de513e6.tar.bz2 | |
Merge "Webview listen to Scroll event to update the viewport"
| -rw-r--r-- | core/java/android/webkit/WebView.java | 37 |
1 files changed, 30 insertions, 7 deletions
diff --git a/core/java/android/webkit/WebView.java b/core/java/android/webkit/WebView.java index 050141f..c6cf918 100644 --- a/core/java/android/webkit/WebView.java +++ b/core/java/android/webkit/WebView.java @@ -322,8 +322,19 @@ public class WebView extends AbsoluteLayout } } + private class InnerScrollChangedListener implements ViewTreeObserver.OnScrollChangedListener { + public void onScrollChanged() { + if (isShown()) { + setGLRectViewport(); + } + } + } + // The listener to capture global layout change event. - private InnerGlobalLayoutListener mListener = null; + private InnerGlobalLayoutListener mGlobalLayoutListener = null; + + // The listener to capture scroll event. + private InnerScrollChangedListener mScrollChangedListener = null; // if AUTO_REDRAW_HACK is true, then the CALL key will toggle redrawing // the screen all-the-time. Good for profiling our drawing code @@ -4746,9 +4757,15 @@ public class WebView extends AbsoluteLayout super.onAttachedToWindow(); if (hasWindowFocus()) setActive(true); final ViewTreeObserver treeObserver = getViewTreeObserver(); - if (treeObserver != null && mListener == null) { - mListener = new InnerGlobalLayoutListener(); - treeObserver.addOnGlobalLayoutListener(mListener); + if (treeObserver != null) { + if (mGlobalLayoutListener == null) { + mGlobalLayoutListener = new InnerGlobalLayoutListener(); + treeObserver.addOnGlobalLayoutListener(mGlobalLayoutListener); + } + if (mScrollChangedListener == null) { + mScrollChangedListener = new InnerScrollChangedListener(); + treeObserver.addOnScrollChangedListener(mScrollChangedListener); + } } } @@ -4759,9 +4776,15 @@ public class WebView extends AbsoluteLayout if (hasWindowFocus()) setActive(false); final ViewTreeObserver treeObserver = getViewTreeObserver(); - if (treeObserver != null && mListener != null) { - treeObserver.removeGlobalOnLayoutListener(mListener); - mListener = null; + if (treeObserver != null) { + if (mGlobalLayoutListener != null) { + treeObserver.removeGlobalOnLayoutListener(mGlobalLayoutListener); + mGlobalLayoutListener = null; + } + if (mScrollChangedListener != null) { + treeObserver.removeOnScrollChangedListener(mScrollChangedListener); + mScrollChangedListener = null; + } } super.onDetachedFromWindow(); |
