wenju
wenju
  • 发布:2016-01-25 16:43
  • 更新:2018-04-02 10:41
  • 阅读:9929

【交流分享】Android集成HTML5+SDK,Runtime方式离线打包,空项目讲解

分类:5+ SDK

上星期分享的一个文章:
【交流分享】Android独立应用方式集成HTML5+SDK,Widget方式离线打包,空项目讲解
http://ask.dcloud.net.cn/article/526
官方概念的东西这里不再讲了,,建议先看上述文章再看本帖;

Runtime集成方式比Widget集成方式简单,区别在于AndroidManifest.xml的配置;两者集成的前面7个步奏都是一样的,我这里就直接拷贝过来了 :

一.准备
1.打开HBuilder,新建-->移动APP-->勾选"Hello mui",项目名叫"HelloMui";(我以官方mui项目来举例了,到时自行改为自己的项目);
2.打开eclipse,打开你的Android项目;(我这里是新建了一个Android项目,名字叫Runtime; 如果你还没配置Android开发环境,则点这里http://jingyan.baidu.com/article/bea41d437a41b6b4c51be6c1.html );

  1. 去官方下载最新的sdk: http://ask.dcloud.net.cn/article/103 解压,里面有个名字叫'SDK'的文件夹

二.拷贝
1.把下载的官方SDK文件夹里的res文件夹拷贝到Android项目的res,合并;注意不要替换你项目的资源,不然你配的图标和写的strings.xml就没了

说明: res里面有NativeUI用到的图片资源: 进度条,对话框,动画样式,照片选择,底部弹出框,logo,启动页等等;http://www.html5plus.org/doc/zh_cn/nativeui.html

2.把SDK\assets中的data文件夹到eclipse项目中的assets

3.在eclipse的assets目录中创建apps; 在apps中创建一个文件夹,名字和你HBuilder的项目名相同;我这里就叫HelloMui; 在HelloMui中创建www文件夹; 把HBuilder项目拷贝到www文件夹下;


注意: apps和www文件夹名字是固定的,结构也是固定的,不然读取不到html

4.修改manifest.json和control.xml中的id为你的项目名;我这里是HelloMui

5.拷贝SDK\libs里面的jar包到eclipse项目下的libs;如图:


说明:
pdr.jar, ui.jar, nineoldandroids-2.4.0.jar是Webview基础包,必须导入
因为HelloMui项目中获取设备信息网络状态,需引入device.jar;
设置了浏览器运行环境,需引入navigatorui.jar(设置了状态栏,创建快捷方式,log输出,设置cookie都需引入此包)
使用了plus.storage,需引入nopermission.jar
最后还需引入universal-image-loader-1.9.0.jar,不然HelloMui运行加载不了首页图

其实在具体的项目中,这些包远远不够的:
比如ajax联网,需引入xhr.jar
全量更新和差量更新,需引入downloader.jar,invocation.jar
原生对话框和底部弹出或者toast,需引入nativeui.jar
设置用户头像,用到拍照,打开相册,需引入camera.jar,gallery.jar
具体请参照: http://ask.dcloud.net.cn/docs/#http://ask.dcloud.net.cn/article/216

6.打开eclipse项目的AndroidManifest.xml,配置权限,具体请参照官方SDK里的Feature-Android.xls文件

<!-- 联网 -->  
    <uses-permission android:name="android.permission.INTERNET" />  
    <!-- 使用存储卡 -->  
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

7.把HBuilder-Integrate\src下的io文件夹,拷贝到eclipse项目的src

-------这里开始,就是和Widget集成方式不一致的地方--------

8.打开AndroidManifest.xml,把<application>标签替换成如下:也是最后一步了O(∩_∩)O~

<application  
        android:allowClearUserData="true"  
        android:icon="@drawable/icon"  
        android:label="@string/app_name"  
        android:largeHeap="true"  
        android:theme="@style/CustomTheme" >  
        <!-- Runtime集成方式基本配置 start-->  
        <activity  
            android:name="io.dcloud.PandoraEntry"  
            android:configChanges="orientation|keyboardHidden"  
            android:label="@string/app_name"  
            android:launchMode="singleTask"  
            android:screenOrientation="user"  
            android:windowSoftInputMode="adjustResize" >  
            <intent-filter>  
                <action android:name="android.intent.action.MAIN" />  

                <category android:name="android.intent.category.LAUNCHER" />  
            </intent-filter>  
        </activity>  
        <activity  
            android:name="io.dcloud.PandoraEntryActivity"  
            android:configChanges="orientation|keyboardHidden|screenSize"  
            android:hardwareAccelerated="true"  
            android:label="5+Debug"  
            android:launchMode="singleTask"  
            android:screenOrientation="user"  
            android:theme="@style/DCloudTheme"  
            android:windowSoftInputMode="adjustResize" >  
        </activity>  

        <service  
            android:name="io.dcloud.adapter.io.MiniServerService"  
            android:exported="true" />  
        <!-- Runtime集成方式基本配置 end-->  
    </application>

搞定运行吧~
附上eclipse源码工程:

2016-01-25 16:43 1 条评论 负责人:无 分享
已邀请:
wenju

wenju (作者) - https://www.mescroll.com -- 精致的下拉刷新和上拉加载组件

这附件源码工程传半天才上去,真是分享东西太花时间了,深圳的天气冷得手哆嗦~(>_<)~~~~

最后说几个注意的小地方:

  1. Android项目创建的时候就改成UTF-8,不然导入的html,js中文乱码
  2. 记得引入universal-image-loader-1.9.0.jar,不然HelloMui运行加载不了首页图
    3.AndroidManifest.xml中,不要指定 android:targetSdkVersion,不然部分Android5.0会闪屏,部分界面显示不了,你可以试试首页列表都加载不出来; 直接就写成<uses-sdk android:minSdkVersion="8" />即可
wanZ

wanZ

支持

小苏

小苏

mark

七彩

七彩

学习了,非常感谢!试一下,我用的是as

zhl

zhl

请问 Runtime方式集成和Widget方式有什么区别?

7***@qq.com

7***@qq.com

按照您分享的步骤操作后,打包是成功了,但是mui的脚本调用不了,不知道是为什么

z***@163.com

z***@163.com

很感谢

GraceLeeau

GraceLeeau - Web前端开发工程师

请问如果是这种需求场景:

  • 原生APP中通过url访问一个Html5+应用;
  • 原生APP代码和H5项目代码不放在一起,分别由不同公司的团队维护;
  • Html5+应用中需使用camera/gallery/audio/device等HTML5 API

那么,可以用什么方案,使得原生APP提供的webview支持H5 应用?提供方案、建议或思路都可以,万分感谢!

9***@163.com

9***@163.com

万分感谢,成功了。

9900

9900

包名能改吗

该问题目前已经被锁定, 无法添加新回复