Android WebView Touch事件及相关问题处理
如有转载,请声明出处: 时之沙: http://blog.csdn.net/t12x3456
继上一篇 Android WebView常见问题及解决方案汇总 中归纳了一些处理webview的常见问题,这次要说的是webview中的touch事件:
有时候在开发中,我们需要对webview加入触摸事件的处理,比如加入滑动效果或者类似于阅读中的翻页效果,这时候我们就需要重写webview中的onTouch方法:
public class MyWebView extends WebView{ public MyWebView(Context context) { super(context); } @Override public boolean onTouchEvent(MotionEvent evt) { switch (evt.getAction()){ case MotionEvent.ACTION_DOWN: //do something...... break; case MotionEvent.ACTION_MOVE: //do something...... break; case MotionEvent.ACTION_UP: //do something...... break;} return false;} }
这里要注意的是,返回值要为false,将此事件继续向下传递.否则会引起 超链接不起作用的问题.
将onTouch()事件中的返回值改为false之后,有时候仍然还是不会触发onTouch()事件,这是为什么呢.经过逐行代码的分析,终于找到了问题的根源:
主要是因为做了如下设置:
webView.getSettings().setBuiltInZoomControls(true);
该设置让webview控件可以支持缩放,而这个缩放设置,同样会响应onTouch事件的,所以会覆盖掉我们自己设置的onTouhc监听,引起了事件的冲突.
怎么办呢,如果需要设置webview大小的话,不是用webview的setting支持,而是调用 webView.setInitialScale()函数来设置webview的大小
具体的数值可以这样处理:
1.如果webview需要固定大小,可根据分辨率及webview位置综合计算页面大小初始比例.当然一般遇到页面大小固定的话,还是在H5页面中进行适配处理最好
2.如果就是需要对webview进行缩放,则需要给用户提供一个缩放按钮,然后自己控制每次缩放的数值,然后调用 webView.setInitialScale(),数值大小根据需求而定,若无要求可参照webview本身支持的缩放大小数值.