前言:我们项目要求的返回逻辑是,在Xwalkview里面所有的页面点击物理返回键,都会执行双击退出的功能,所以,如果你们项目要求的不是这样的,那么这篇博文对你没什么大的用处,不过可以相互学习下哈!
Crosswalk的好处,我就不在这里赘述了,比原生的WebView的性能不知道提升了多少倍,原生中的不兼容的布局问题,在Crosswalk里面根本不存在(因为我们项目中用到了语音连读的功能,这个功能 在三星某款手机中,还是有问题的),等等很多好处,当然也不是完美的,比如,如果出问题的话,可以参考的资料还是有限的,大家就自己取舍一下吧;
------------------------进入正题------------------------------
1,集成Crosswalk的步骤,我也不说了,网上一大堆,基本上都可以集成成功的,也不是很复杂;
2,集成之后,你就会发现性能真的提升了不止一点点,但是 如果你点击物理返回键,你会发现,他是会不用你写逻辑,而自己去执行网页的跳转的,这一点我觉得Crosswalk做的还是很好的,但是就如我刚才说的,我们的项目要求是无论在Xwalkview里面的哪一个页面,双击物理返回键都得退出的,那么这时候就出现问题了,一般我们会直接去onKeyDown里写一些逻辑,比如:
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
//双击退出的逻辑代码
return true;
}
return super.onKeyDown(keyCode, event);
}
上面这一段代码就是无论在哪一个页面,双击back直接退出的,但是测试的时候 你会发现,现实并不是想象的那样,Xwalkview还是会在你按下返回键的时候执行跳转到上一个页面的方法,这也不是我们要的,所以这个方法不行;
3,第二个方法就有点麻烦,重写Xwalkview的dispatchKeyEvent方法,判断如果是返回的话,直接屏蔽掉,这个方法还是比较靠谱的,接下来就是代码了:
a,需要一个继承自Xwalkview的类,名字叫MyXwalkview
import android.app.Activity;
import android.content.Context;
import android.util.AttributeSet;
import android.view.KeyEvent;
import org.xwalk.core.XWalkView;
public class MyXwalkview extends XWalkView{
public MyXwalkview(Context context) {
super(context);
}
public MyXwalkview(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyXwalkview(Context context, Activity activity) {
super(context, activity);
}
@Override
public boolean dispatchKeyEvent(KeyEvent event) {
if (event.getKeyCode() == KeyEvent.KEYCODE_BACK){
return false;
}
return super.dispatchKeyEvent(event);
}
}
c,然后在你的MainActivity中的onKeyDown方法里这么写:
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK){
exitByDoubleClick();
return true;
}
return super.onKeyDown(keyCode, event);
}