您的位置:首页 > 移动开发

Android WebView Touch事件及相关问题处理

2013-12-26 09:04 1211 查看
如有转载,请声明出处: 时之沙: 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本身支持的缩放大小数值.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: