crosswalk代替webview
来源:互联网 发布:京都旅游攻略 知乎 编辑:程序博客网 时间:2024/05/22 13:47
五步整合crosswalk内核浏览h5变高性能APP.
crosswalk介绍就不提了。我这里提供5个步骤整合到android项目中去。
开发环境: Android Studio
1.build.gradle Module配制
repositories { maven { url 'https://download.01.org/crosswalk/releases/crosswalk/android/maven2'}}dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'org.xwalk:xwalk_core_library:23.53.589.4'}
2.manifest.xml文件
需要注意:android:hardwareAccelerated="true" 为硬件加速
<!--需要权限--><uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /><application android:hardwareAccelerated="true" android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme" > <activity android:name=".MainActivity" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity></application>
3.布局文件
<?xml version="1.0" encoding="utf-8"?><android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.dowell.myapplication.MainActivity"> <org.xwalk.core.XWalkView android:id="@+id/xwalkWebView" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="#000000" app:layout_constraintLeft_toLeftOf="parent"/></android.support.constraint.ConstraintLayout>
4.java代码
setContentView(R.layout.activity_main);xwalkWebView=(XWalkView)findViewById(R.id.xwalkWebView);xwalkWebView.load("http://www.baidu.com",null);XWalkSettings settings = xwalkWebView.getSettings();settings.setDomStorageEnabled(true);settings.setCacheMode(WebSettings.LOAD_DEFAULT);settings.setAllowFileAccess(true);settings.setDatabaseEnabled(true);settings.setJavaScriptEnabled(true);//资源加载动作的事件 参考webview的setWebViewClient//xwalkWebView.setResourceClient(new XWalkResourceClient());//界面相关的client 参照WebView setWebChromeClient//xwalkWebView.setUIClient(new MyXWalkUIClient(mXwalkView));//js 交互相关,参照webview的addJavascriptInterface代码//xwalkWebView.addJavascriptInterface(new UMengInterface(), "UMeng");5.屏蔽crosswalk自动响应android返回键的事件。内置带回退效果
@Overridepublic boolean dispatchKeyEvent(KeyEvent event) { if(event.getKeyCode()==KeyEvent.KEYCODE_BACK){ return true; } return super.dispatchKeyEvent(event);}参考:https://github.com/crosswalk-project/crosswalk-test-suite/blob/7b8527f7551548e7225700e78a11b82c371ae137/usecase/usecase-embedding-android-tests/embeddingapi/src/org/xwalk/embedded/api/sample/XWalkViewWithDispatchKeyEvent.java
阅读全文
0 0
- crosswalk代替webview
- Crosswalk--深度定制webview
- crossWalk替换webView集成
- android crosswalk-webview 取代 webview
- 为什么放弃WebView 而 使用 crosswalk!
- CrossWalk webview fragment 高度变低
- WebView的碎片化解决方案:Crosswalk
- 一个轻量世界级的webView--CrossWalk
- android高性能webview之crosswalk
- cordova-plugin-crosswalk-webview 安装出现错误
- CrossWalk
- 放弃WebView,使用Crosswalk做富文本编辑器
- 放弃WebView,使用Crosswalk做富文本编辑器
- android 的导入crosswalk 用xwalkview 替换webview
- 放弃WebView,使用Crosswalk做富文本编辑器
- Crosswalk 开发浅析,忘掉那些Webview的坑
- 放弃WebView,使用Crosswalk做富文本编辑器
- Ionic安装cordova-plugin-crosswalk-webview报错
- adb抓包
- 给constant曾加动效 [UIView animateWithDuration:duration 不起作用解决方案
- mybatis插件安装方法
- Ubuntu下安装完Pycharm创建桌面快捷方式
- kaggle:code 猫狗识别 图像识别TensorFlow图像预处理
- crosswalk代替webview
- android线程管理五(ActivityThread与ApplicationThread)
- 点击popupwindow外部区域,点击事件的响应问题
- static
- AR Camera开发记录(一) -- Rajawali的使用
- [FWT] UOJ#310. 【UNR #2】黎明前的巧克力
- 二叉树的建立与存储,以及遍历方法
- 数据库优化需要注意的三十条
- FS获取KERNEL32基址的三种方法