现在的位置: 首页 > 综合 > 正文

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

2014年02月12日 ⁄ 综合 ⁄ 共 1088字 ⁄ 字号 评论关闭

如有转载,请声明出处: 时之沙: 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本身支持的缩放大小数值.

抱歉!评论已关闭.