dcloud离线打包内容分享(第三插件开发、h5到原生,原生到h5)

2024-05-26 17:58

本文主要是介绍dcloud离线打包内容分享(第三插件开发、h5到原生,原生到h5),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

dcloud离线打包(第三插件开发、h5到原生,原生到h5)

dcloud 官方文档,怎么说呢,貌似没有完整的提供离线打包方法,只说了如何开发第三方插件,但是如何开发第三方插件,写的又不是很详细,并且开发出了第三方插件,如何集成到项目里,貌似根本没有写,本人,也是新手,刚好最近用dcloud开发了一个app,有一点经验,所以把一些经验分享出来,希望能帮到大家!
1.离线打包和在线打包,大家要明白一点,在线打包,人家帮你做了什么。举个例子,语音这块,用dcloud(h5)开发,就一行代码就搞定,为什么呢?因为在线打包,人家把原生调用的一些内容已经引进去了,所以,我们不需要考虑原生的,但是离线打包呢?
2.有的同学可能会问,那怎么样把自己开发的第三方插件,也同样用在线打包的方式打包进去呢?那你想象一下,这可能吗?你知道在线打包的规则吗?除非dcloud官方同意你这么做。
        3.所以,想要离线打包,前提还是,怎么把你开发的app(h5),集成到原生的android工程中,用eclipse或者android studio 打包你的app,这一块详见 http://ask.dcloud.net.cn/article/526,写的很详细。
       4.按照教程把你的app集成好了之后,先打包测试一下,看是否操作正常,如果没问题,说明你的app集成就对了!此时你再回过头来看第三方插件开发的内容 http://ask.dcloud.net.cn/article/66,你就大概明白怎么回事了,这样第三方插件也就开发出来了,在插件里面,就是java代码开发的内容了,记住Iwebview ,这个很有用,举个例子,你要打开你自己的activity 窗口 ,只需要这样,
GpsSqlLiteConstant.pWebview = pWebview;
Intent localIntent = new Intent(pWebview.getActivity(), OffineMapActivity.class); 这个具体的用法,自己去看源码。
	5.从h5到原生,到这里,大家应该就会搞了,但是从原生到h5,大家应该还是会遇到,所以,我在这里也给大家说明一下,你可以选择在原生activity中集成h5页面,也可以先返回到h5中,再调用h5的页面,个人建议先回到h5中,再调用,因为我们开发就是在h5的app中开发,这样可以保证,引用到的js或者css,都能识别,不需要为了不兼容问题,再花时间,先给大家上一段代码,activity中引用h5页面,
public class SaveInforActivity extends Activity {IWebview webview = null;@Override
    protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// setContentView(R.layout.activity_save_infor);
        final  FrameLayout rootView = new FrameLayout(this);rootView.getViewTreeObserver().addOnGlobalLayoutListener(new OnGlobalLayoutListener() {@Override
            public void onGlobalLayout() {webview.onRootViewGlobalLayout(rootView);}});// 设置单页面集成的appid
        String appid = "tab_sample_index";// 单页面集成时要加载页面的路径,可以是本地文件路径也可以是网络路径
        String url = "file:///android_asset/apps/xxxx/www/views/task/tab_sample_index.html";webview = SDK.createWebview(this, url, appid, new IWebviewStateListener() {@Override
            public Object onCallBack(int pType, Object pArgs) {switch (pType) {case IWebviewStateListener.ON_WEBVIEW_READY:// 准备完毕之后添加webview到显示父View中,设置排版不显示状态,避免显示webview时,html内容排版错乱问题
                        ((IWebview) pArgs).obtainFrameView().obtainMainView().setVisibility(View.INVISIBLE);SDK.attach(rootView, ((IWebview) pArgs));break;case IWebviewStateListener.ON_PAGE_STARTED:// 首页面开始加载事件
                        break;case IWebviewStateListener.ON_PROGRESS_CHANGED:// 首页面加载进度变化
                        break;case IWebviewStateListener.ON_PAGE_FINISHED:// 页面加载完毕,设置显示webview
                        webview.obtainFrameView().obtainMainView().setVisibility(View.VISIBLE);break;}return null;}});setContentView(rootView);final WebView webviewInstance = webview.obtainWebview();// 监听返回键
        webviewInstance.setOnKeyListener(new OnKeyListener() {@Override
            public boolean onKey(View v, int keyCode, KeyEvent event) {if (keyCode == KeyEvent.KEYCODE_BACK) {if (webviewInstance.canGoBack()) {webviewInstance.goBackOrForward(2);return true;}}return false;}});}@Override
    protected void onDestroy() {super.onDestroy();}@Override
    protected void onPause() {super.onPause();}
}
本人亲测,代码完全可靠,可以显示页面,mui.ready,mui.init都可以执行,但是不太推推荐,个人推荐第二种,直接上代码 
Intent intent = new Intent();
intent.setClass(MainActivity.this, io.dcloud.PandoraEntry.class);
startActivity(intent);
如果想跳转之后,直接调用某个方法,这样操作 
GpsSqlLiteConstant.pWebview.evalJS("test('" + 参数 + "')"); 
GpsSqlLiteConstant.pWebview 这个就是Iwebview,test(),这个是h5中写的js方法,大家可以通过 evalJS()方法,调用到h5中写的任何js方法,test方法如下
 function test(tid){		mui.openWindow({
				url: '../task/tab_sample_index.html',
				id: 'tab_sample_index',
				extras:{
					tid:tid
				}
			});}
至此,我想大家应该就都会了,如果觉得写的还不错,而且帮到了你,请点赞吧,如果有不明白的,请留言!代码的话,请谅解,因为是公司的项目,不方便上传,如果小伙伴有需要部分代码,或者想要一起学习交流的话,请加一下这个QQ群,488505459,一起学习,一起探讨,谢谢!

这篇关于dcloud离线打包内容分享(第三插件开发、h5到原生,原生到h5)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1005178

相关文章

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

linux批量替换文件内容的实现方式

《linux批量替换文件内容的实现方式》本文总结了Linux中批量替换文件内容的几种方法,包括使用sed替换文件夹内所有文件、单个文件内容及逐行字符串,强调使用反引号和绝对路径,并分享个人经验供参考... 目录一、linux批量替换文件内容 二、替换文件内所有匹配的字符串 三、替换每一行中全部str1为st

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核