加载中...

1.4.3 集成到Android工程


WEEX SDK集成到工程(Integrate to Android)

注:以下文档都是假设您已经具备一定的Android开发经验。

Android 集成有两种方式

  1. 源码依赖:能够快速使用WEEX最新功能,可以根据自己项目的特性进行相关改进。
  2. SDK依赖:WEEX 会在jcenter 定期发布稳定版本。jcenter
    注:国内可能需要翻墙

前期准备

  • 已经安装了JDK version>=1.7 并配置了环境变量
  • 已经安装Android SDK 并配置环境变量。
  • Android SDK version 23 (compileSdkVersion in build.gradle)
  • SDK build tools version 23.0.1 (buildToolsVersion in build.gradle)
  • Android Support Repository >= 17 (for Android Support Library)

快速接入

如果你是尝鲜或者对稳定性要求比较高可以使用依赖SDK的方式。
步骤如下:

  1. 创建Android工程,没有什么要特别说明的,按照你的习惯来。

  2. 修改build.gradle 加入如下基础依赖

    1. compile 'com.android.support:recyclerview-v7:23.1.1'
    2. compile 'com.android.support:support-v4:23.1.1'
    3. compile 'com.android.support:appcompat-v7:23.1.1'
    4. compile 'com.alibaba:fastjson:1.1.46.android'
    5. compile 'com.taobao.android:weex_sdk:0.5.1@aar'

    注:版本可以高不可以低。

代码实现

注:附录中有完整代码地址

  • 实现图片下载接口,初始化时设置。
  1. package com.weex.sample;
  2. import android.widget.ImageView;
  3. import com.taobao.weex.adapter.IWXImgLoaderAdapter;
  4. import com.taobao.weex.common.WXImageStrategy;
  5. import com.taobao.weex.dom.WXImageQuality;
  6. /**
  7. * Created by lixinke on 16/6/1.
  8. */
  9. public class ImageAdapter implements IWXImgLoaderAdapter {
  10. @Override
  11. public void setImage(String url, ImageView view, WXImageQuality quality, WXImageStrategy strategy) {
  12. //实现你自己的图片下载,否则图片无法显示。
  13. }
  14. }
  • 初始化
  1. package com.weex.sample;
  2. import android.app.Application;
  3. import com.taobao.weex.InitConfig;
  4. import com.taobao.weex.WXSDKEngine;
  5. /**
  6. * 注意要在Manifest中设置android:name=".WXApplication"
  7. * 要实现ImageAdapter 否则图片不能下载
  8. * gradle 中一定要添加一些依赖,否则初始化会失败。
  9. * compile 'com.android.support:recyclerview-v7:23.1.1'
  10. * compile 'com.android.support:support-v4:23.1.1'
  11. * compile 'com.android.support:appcompat-v7:23.1.1'
  12. * compile 'com.alibaba:fastjson:1.1.45'
  13. */
  14. public class WXApplication extends Application {
  15. @Override
  16. public void onCreate() {
  17. super.onCreate();
  18. InitConfig config=new InitConfig.Builder().setImgAdapter(new ImageAdapter()).build();
  19. WXSDKEngine.initialize(this,config);
  20. }
  21. }
  • 开始渲染
  1. package com.weex.sample;
  2. import android.os.Bundle;
  3. import android.support.v7.app.AppCompatActivity;
  4. import android.view.View;
  5. import com.taobao.weex.IWXRenderListener;
  6. import com.taobao.weex.WXSDKInstance;
  7. import com.taobao.weex.common.WXRenderStrategy;
  8. import com.taobao.weex.utils.WXFileUtils;
  9. public class MainActivity extends AppCompatActivity implements IWXRenderListener {
  10. WXSDKInstance mWXSDKInstance;
  11. @Override
  12. protected void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.activity_main);
  15. mWXSDKInstance = new WXSDKInstance(this);
  16. mWXSDKInstance.registerRenderListener(this);
  17. /**
  18. * WXSample 可以替换成自定义的字符串,针对埋点有效。
  19. * template 是.we transform 后的 js文件。
  20. * option 可以为空,或者通过option传入 js需要的参数。例如bundle js的地址等。
  21. * jsonInitData 可以为空。
  22. * width 为-1 默认全屏,可以自己定制。
  23. * height =-1 默认全屏,可以自己定制。
  24. */
  25. mWXSDKInstance.render("WXSample", WXFileUtils.loadFileContent("hello.js", this), null, null, -1, -1, WXRenderStrategy.APPEND_ASYNC);
  26. }
  27. @Override
  28. public void onViewCreated(WXSDKInstance instance, View view) {
  29. setContentView(view);
  30. }
  31. @Override
  32. public void onRenderSuccess(WXSDKInstance instance, int width, int height) {
  33. }
  34. @Override
  35. public void onRefreshSuccess(WXSDKInstance instance, int width, int height) {
  36. }
  37. @Override
  38. public void onException(WXSDKInstance instance, String errCode, String msg) {
  39. }
  40. @Override
  41. protected void onResume() {
  42. super.onResume();
  43. if(mWXSDKInstance!=null){
  44. mWXSDKInstance.onActivityResume();
  45. }
  46. }
  47. @Override
  48. protected void onPause() {
  49. super.onPause();
  50. if(mWXSDKInstance!=null){
  51. mWXSDKInstance.onActivityPause();
  52. }
  53. }
  54. @Override
  55. protected void onStop() {
  56. super.onStop();
  57. if(mWXSDKInstance!=null){
  58. mWXSDKInstance.onActivityStop();
  59. }
  60. }
  61. @Override
  62. protected void onDestroy() {
  63. super.onDestroy();
  64. if(mWXSDKInstance!=null){
  65. mWXSDKInstance.onActivityDestroy();
  66. }
  67. }
  68. }

源码依赖(IDE Android Studio)

  1. 下载源码 git clone https://github.com/alibaba/weex
  2. 创建Android 工程。
  3. 通过以下路径引入SDK Module
    File->New-Import Module->选择WEEX SDK Module(weex/android/sdk)->Finish
  4. app 的build.gradle 中添加如下依赖:compile project(':weex_sdk')
  5. 其他设置请参考上面快速接入

附录

WXSample地址
https://github.com/xkli/WXSample.git


还没有评论.