am 5ff24d5d: DO NOT MERGE

Merge commit '5ff24d5da414db4e8c2ebe98f40976e7be62b72d' into eclair-plus-aosp

* commit '5ff24d5da414db4e8c2ebe98f40976e7be62b72d':
  DO NOT MERGE
This commit is contained in:
Grace Kloba
2010-01-22 13:17:52 -08:00
committed by Android Git Automerger

View File

@@ -536,10 +536,8 @@ public class WebView extends AbsoluteLayout
static int DEFAULT_SCALE_PERCENT; static int DEFAULT_SCALE_PERCENT;
private float mDefaultScale; private float mDefaultScale;
// set to true temporarily during ScaleGesture triggered zoom // set to true temporarily while the zoom control is being dragged
private boolean mPreviewZoomOnly = false; private boolean mPreviewZoomOnly = false;
// extra scale during zoom preview
private float mPreviewExtraZoomScale = 1.0f;
// computed scale and inverse, from mZoomWidth. // computed scale and inverse, from mZoomWidth.
private float mActualScale; private float mActualScale;
@@ -2812,9 +2810,7 @@ public class WebView extends AbsoluteLayout
nativeRecordButtons(hasFocus() && hasWindowFocus(), nativeRecordButtons(hasFocus() && hasWindowFocus(),
mTouchMode == TOUCH_SHORTPRESS_START_MODE mTouchMode == TOUCH_SHORTPRESS_START_MODE
|| mTrackballDown || mGotCenterDown, false); || mTrackballDown || mGotCenterDown, false);
// use the DKGRAY as background when drawing zoom preview drawCoreAndCursorRing(canvas, mBackgroundColor, mDrawCursorRing);
drawCoreAndCursorRing(canvas, mPreviewZoomOnly ? Color.DKGRAY
: mBackgroundColor, mDrawCursorRing);
} }
@Override @Override
@@ -2824,12 +2820,6 @@ public class WebView extends AbsoluteLayout
return; return;
} }
int saveCount = canvas.save(); int saveCount = canvas.save();
if (mPreviewZoomOnly) {
// scale after canvas.save() so that the child, like titlebar, will
// not be scaled.
canvas.scale(mPreviewExtraZoomScale, mPreviewExtraZoomScale,
mZoomCenterX + mScrollX, mZoomCenterY + mScrollY);
}
if (mTitleBar != null) { if (mTitleBar != null) {
canvas.translate(0, (int) mTitleBar.getHeight()); canvas.translate(0, (int) mTitleBar.getHeight());
} }
@@ -2838,8 +2828,8 @@ public class WebView extends AbsoluteLayout
} }
canvas.restoreToCount(saveCount); canvas.restoreToCount(saveCount);
// Now draw the shadow, skip if it is in zoom preview mode. // Now draw the shadow.
if ((mTitleBar != null && !mPreviewZoomOnly)) { if (mTitleBar != null) {
int y = mScrollY + getVisibleTitleHeight(); int y = mScrollY + getVisibleTitleHeight();
int height = (int) (5f * getContext().getResources() int height = (int) (5f * getContext().getResources()
.getDisplayMetrics().density); .getDisplayMetrics().density);
@@ -3744,8 +3734,6 @@ public class WebView extends AbsoluteLayout
private class ScaleDetectorListener implements private class ScaleDetectorListener implements
ScaleGestureDetector.OnScaleGestureListener { ScaleGestureDetector.OnScaleGestureListener {
float mStartX, mStartY;
public boolean onScaleBegin(ScaleGestureDetector detector) { public boolean onScaleBegin(ScaleGestureDetector detector) {
// cancel the single touch handling // cancel the single touch handling
cancelTouch(); cancelTouch();
@@ -3759,9 +3747,6 @@ public class WebView extends AbsoluteLayout
if (inEditingMode() && nativeFocusCandidateIsPassword()) { if (inEditingMode() && nativeFocusCandidateIsPassword()) {
mWebTextView.setInPassword(false); mWebTextView.setInPassword(false);
} }
mPreviewExtraZoomScale = 1.0f;
mStartX = detector.getFocusX();
mStartY = detector.getFocusY();
return true; return true;
} }
@@ -3770,12 +3755,13 @@ public class WebView extends AbsoluteLayout
mPreviewZoomOnly = false; mPreviewZoomOnly = false;
mAnchorX = viewToContentX((int) mZoomCenterX + mScrollX); mAnchorX = viewToContentX((int) mZoomCenterX + mScrollX);
mAnchorY = viewToContentY((int) mZoomCenterY + mScrollY); mAnchorY = viewToContentY((int) mZoomCenterY + mScrollY);
float scale = mPreviewExtraZoomScale * mActualScale;
// don't reflow when zoom in; when zoom out, do reflow if the // don't reflow when zoom in; when zoom out, do reflow if the
// new scale is almost minimum scale; // new scale is almost minimum scale;
boolean reflowNow = (scale - mMinZoomScale <= 0.01f) boolean reflowNow = (mActualScale - mMinZoomScale <= 0.01f)
|| ((scale <= 0.8 * mTextWrapScale)); || ((mActualScale <= 0.8 * mTextWrapScale));
setNewZoomScale(scale, reflowNow, false); // force zoom after mPreviewZoomOnly is set to false so that the
// new view size will be passed to the WebKit
setNewZoomScale(mActualScale, reflowNow, true);
// call invalidate() to draw without zoom filter // call invalidate() to draw without zoom filter
invalidate(); invalidate();
} }
@@ -3792,34 +3778,19 @@ public class WebView extends AbsoluteLayout
} }
public boolean onScale(ScaleGestureDetector detector) { public boolean onScale(ScaleGestureDetector detector) {
float currScale = mPreviewExtraZoomScale * mActualScale;
float scale = (float) (Math.round(detector.getScaleFactor() float scale = (float) (Math.round(detector.getScaleFactor()
* currScale * 100) / 100.0); * mActualScale * 100) / 100.0);
// limit the scale change per step if (Math.abs(scale - mActualScale) >= PREVIEW_SCALE_INCREMENT) {
if (scale > currScale) {
scale = Math.min(scale, currScale * 1.25f);
} else {
// the preview scale can be 80% of mMinZoomScale for feedback
scale = Math.max(Math.max(scale, currScale * 0.8f),
mMinZoomScale * 0.8f);
}
if (Math.abs(scale - currScale) >= PREVIEW_SCALE_INCREMENT) {
mPreviewZoomOnly = true; mPreviewZoomOnly = true;
// FIXME: mZoomCenterX/Y need to be relative to mActualScale. // limit the scale change per step
// Ideally the focusX/Y should be a fixed point. But currently if (scale > mActualScale) {
// it just returns the center of the two pointers. If only one scale = Math.min(scale, mActualScale * 1.25f);
// pointer is moving, the center is shifting. Currently we only
// adjust it for zoom in case to get better result.
if (mPreviewExtraZoomScale > 1.0f) {
mZoomCenterX = mStartX - (mStartX - detector.getFocusX())
/ mPreviewExtraZoomScale;
mZoomCenterY = mStartY - (mStartY - detector.getFocusY())
/ mPreviewExtraZoomScale;
} else { } else {
mZoomCenterX = detector.getFocusX(); scale = Math.max(scale, mActualScale * 0.8f);
mZoomCenterY = detector.getFocusY();
} }
mPreviewExtraZoomScale = scale / mActualScale; mZoomCenterX = detector.getFocusX();
mZoomCenterY = detector.getFocusY();
setNewZoomScale(scale, false, false);
invalidate(); invalidate();
return true; return true;
} }
@@ -4000,7 +3971,8 @@ public class WebView extends AbsoluteLayout
// FIXME: we may consider to give WebKit an option to handle multi-touch // FIXME: we may consider to give WebKit an option to handle multi-touch
// events later. // events later.
if (mSupportMultiTouch && ev.getPointerCount() > 1) { if (mSupportMultiTouch && mMinZoomScale < mMaxZoomScale
&& ev.getPointerCount() > 1) {
mScaleDetector.onTouchEvent(ev); mScaleDetector.onTouchEvent(ev);
if (mScaleDetector.isInProgress()) { if (mScaleDetector.isInProgress()) {
mLastTouchTime = eventTime; mLastTouchTime = eventTime;