展会信息港展会大全

Android WebView Touch事件及相关问题处理
来源:互联网   发布日期:2015-10-02 21:30:25   浏览:1604次  

导读:继上一篇 Android WebView常见问题及解决方案汇总 中归纳了一些处理webview的常见问题,这次要说的是webview中的touch事件:有时候在开发中,我们需要对webv...

继上一篇 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本身支持的缩放大小数值.

赞助本站

人工智能实验室

相关热词: android开发 教程

AiLab云推荐
推荐内容
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港