提供tbs预览, 全内嵌 实现预览。 只支持android,Android的才这么麻烦,ios没这么麻烦 0.0.可以使用webview_flutter: ^0.3.15+1,加载ios端的。
感谢 https://github.com/VenusCao/x5_webview_flutter 提供的思路,本插件只是对这个项目的 修改。增加以下功能:
- 提供是否需要下载的方法(比如xls pdf网页,x5不支持在线打开,需要我们下载到本地,通过TbsReaderView 来加载本地文件)
- 加载本地文件的视图 也是内嵌到flutter中的。总体思路仅仅是把webview,其他视图加入到FrameLayout 容器中,getView 返回容器。通过_controller 来显示不同的view而已。
- 第三方打开;加载本地文件会提供一个返回值,用来判断,如果无法加载,则通过第三方打开。
FlutterTbs.init().then((isOK) {
print(isOK ? "X5内核成功加载" : "X5内核加载失败");
});
X5WebView(
url: widget.url,
javaScriptEnabled: true,
onWebViewCreated: (control) {
_controller = control;
},
onNeedDownload: _needDownload, //是否需要下载。x5无法在线打开的,都会走这个回调
onProgressChanged: (progress) {
print("webview加载进度------$progress");
this.progress = progress;
setState(() {});
},
onPageFinished: _onPageFinish, //加载完成时
);
_controller.replaceFilePath(filePath).then((value) {
print("--test native path-- $value"); //value : true/false (字符串0.0)
if (value != "true") { //本地文件无法打开,则需要通过第三方打开,
isCanOpen = false;
openWithThirdFilePath = appDocPath;
}
setState(() {
isPageFinished = true;
isLoading = false;
});
});
FlutterTbs.openFileWithThird(openWithThirdFilePath);
- 进行下载前,或者打开本地文件,切记申请存储权限,不然会预览失败
- 打包相关。这两种操作,可以确保x5初始化成功 debug包,通过命令行
flutter build apk --debug --target-platform=android-arm
flutter run --use-application-binary=build/app/outputs/apk/debug/app-debug.apk
release 包:
ndk{abiFilters 'armeabi-v7a'}