Simplification

pull/212/head
M66B 3 years ago
parent 6a7c61f065
commit f03867f115

@ -298,7 +298,7 @@ public class WebViewEx extends WebView implements DownloadListener, View.OnLongC
private float lastX; private float lastX;
private float lastY; private float lastY;
private Integer lastXoff; private int lastXoff;
@Override @Override
public boolean onTouchEvent(MotionEvent event) { public boolean onTouchEvent(MotionEvent event) {
@ -316,24 +316,18 @@ public class WebViewEx extends WebView implements DownloadListener, View.OnLongC
intercept = (yoff > 0 || dy >= 0) && (yoff < bottom || dy <= 0); intercept = (yoff > 0 || dy >= 0) && (yoff < bottom || dy <= 0);
} }
if (intercept) int xrange = computeHorizontalScrollRange();
lastXoff = computeHorizontalScrollOffset(); int xextend = computeHorizontalScrollExtent();
else { boolean canScrollHorizontal = (xrange > xextend);
int xrange = computeHorizontalScrollRange(); if (canScrollHorizontal) {
int xextend = computeHorizontalScrollExtent(); int right = xrange - xextend;
boolean canScrollHorizontal = (xrange > xextend); int xoff = computeHorizontalScrollOffset();
//Log.i("MMM xrange=" + xrange + " xextend=" + xextend + " can=" + canScrollHorizontal); int ldx = xoff - lastXoff;
if (canScrollHorizontal) { float dx = lastX - event.getX();
int right = xrange - xextend; intercept = (xoff > 0 || dx >= 0) &&
int xoff = computeHorizontalScrollOffset(); (xoff < right || dx <= 0) &&
if (lastXoff == null) (Math.signum(dx) == Math.signum(ldx));
lastXoff = xoff; lastXoff = xoff;
float dx = lastX - event.getX();
intercept = (xoff > 0 || dx >= 0) &&
(xoff < right || dx <= 0) &&
(Math.signum(dx) == Math.signum(xoff - lastXoff));
lastXoff = xoff;
}
} }
} }
getParent().requestDisallowInterceptTouchEvent(intercept || event.getPointerCount() > 1); getParent().requestDisallowInterceptTouchEvent(intercept || event.getPointerCount() > 1);

Loading…
Cancel
Save