已有Android工程 集成React Native 的那些事

2017年2月27日,天气晴,我永远记得这天,我心潮澎湃,因为终于把优谈TOP 集成了React Native,从去年开始,公司陆陆续续的集成和学习React Native,通过demo的形式,写了不少组件和API,也能和后端调通,也多次,多个人尝试把优谈TOP集成React Native,但是每次都是失败的,因为缺少经验,不能直接通过错误判断原因,只能通过Google查找各种资料,慢慢解决,下面记录了我们,优谈TOP 原生 集成React Native 的那些事。也许也是你的那些事?

常规思路:

通过百度搜索 已有Android工程集成ReactNative 出现一大堆教程,大部分教程都是通过在原来的基础上增加React Native的支持,比如这个:《Android之原生项目集成React Native》 ,这也是官方推荐的集成方式,我也推荐这个,只是我这样,一直报错,有一个启动 MainaAtivity的错,一直过不去,所以我就换一种思路。。。

在React Native基础上增加原生

开始通过官方文档安装和初始化React Native项目。

创建和运行React Native 项目

react-native init UtanTop

cd UtanTop

react-native run-android

如果没有错,再继续。如果有错,说明你环境都没有安装好,哈哈。请参考环境安装文档

恭喜你,第一步搞定了。接下来,巨坑的地方要来了。

把原生的 build.gradle 文件先集成进去

这一步比较简单,就是把gradle相关文件复制替换就可以了,你想的好简单哈。。。

我建议:

首先把原项目的gradle相关文件复制到新建的React Native项目,不要破坏原来的React Native项目的配置

如果原生项目里有Module,先不要把Module导入,为了保险,把最简单的导入。

修改Root 目录下的build.gradle

allprojects {
    repositories {
        mavenLocal()
        jcenter()
        maven {
            url "http://192.168.1.205:8081/repository/utancenter/"
        }
        maven {
            // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
            url "$rootDir/../node_modules/react-native/android"
        }

    }
}

如果有其他maven仓库直接这么写就可以了。

配置app目录下的build.gradle
buildTypes {


//        release {
//            // 不显示Log
//            buildConfigField "boolean", "LOG_DEBUG", "false"
//
//            minifyEnabled enableProguardInReleaseBuilds
//            zipAlignEnabled true
//            shrinkResources true
//            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-project.txt'
//            signingConfig signingConfigs.release
//
//            applicationVariants.all { variant ->
//                variant.outputs.each { output ->
//                    def outputFile = output.outputFile
//                    if (outputFile != null && outputFile.name.endsWith('.apk')) {
//
//                        //if ("woman".equals(WOMAN)){
//                        //  def fileName = "WomanTop_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk"
//                        //output.outputFile = new File(outputFile.parent+File.separator+"v"+defaultConfig.versionName, fileName)
//                        //} else {
//                        def fileName = "UtanTop_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk"
//                        output.outputFile = new File(outputFile.parent + File.separator + "v" + defaultConfig.versionName, fileName)
//                        //}
//
//
//                    }
//                }
//            }
//        }

        release {
            minifyEnabled enableProguardInReleaseBuilds
            proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
        }
    }

贴这个的意思就是先把打渠道包的去掉,使用React Native生成的配置,之后打渠道包在说,记得把下面几段也要先注释掉。


//    // 多渠道打包
//    productFlavors {

//        T1 {}
//        T2 {}
//        T3 {}
//
//    }
//
//    productFlavors.all { flavor ->
//        flavor.manifestPlaceholders = [CHANNEL_VALUE: name]
//    }


如果集成友盟的多渠道包,还需要在AndroidManifest.xml中注释掉。

 <meta-data
            android:name="UMENG_APPKEY"
            android:value="${UMENG_APPKEY}" />

在这个时候我们还没集成源码,再执行:

react-native run-android

如果编译通过,恭喜你,如果没有过那是正常的,因为还有一个坑。

我的报错信息是


* What went wrong:
Execution failed for task ':app:packageAllDebugClassesForMultiDex'.
> java.util.zip.ZipException: duplicate entry: bolts/AggregateException.class

是因为导入了重复的条目。

可能是在某些某些gradle版本才有吧。。。

我的解决方法:

    compile('com.facebook.fresco:fresco:0.10.0') {
        exclude group: 'com.parse.bolts',
                module: 'bolts-android'
    }

    compile ('com.facebook.fresco:animated-gif:0.10.0'){
        exclude group: 'com.parse.bolts',
                module: 'bolts-android'
    }

这时候再执行:

react-native run-android

现在问题应该不大了,按道理可以运行起来了,反正我的运行起来了,但是还没有加入源码。。。

现在就把java res libs assets 目录下的文件和 AndroidManifest.xml 复制到React Native项目中。

MainApplication 集成你原生项目的Application

一般项目都会自定一个Application

public class MainApplication extends UtanToutiaoApp implements ReactApplication {

  private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
    @Override
    public boolean getUseDeveloperSupport() {
      return BuildConfig.DEBUG;
    }

    @Override
    protected List<ReactPackage> getPackages() {
      return Arrays.<ReactPackage>asList(
          new MainReactPackage()
      );
    }
  };

  @Override
  public ReactNativeHost getReactNativeHost() {
    return mReactNativeHost;
  }

  @Override
  public void onCreate() {
    super.onCreate();
    SoLoader.init(this, /* native exopackage */ false);
  }
}

注意:不要把MainActivity MainApplication ,文件覆盖了。

再执行:

react-native run-android

应该可以成功了,如果默认启动的是MainActivity,那展示的就是React Native 界面,如果默认不是MainActivity,那就通过下面的方式启动。


Intent i = new Intent(context, MainReactActivity.class);
    
context.startActivity(i);

到这里我反正就ok了,不知道你ok了没?

如果不OK ,请留言,一起探讨。。

还有我在学习和使用React Native 之后也会贴出来供大伙参考。。请关注 quanke

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,059评论 25 707
  • 英语太烂,菜鸟水平,如有不妥之处,请各位大神指正 工作原理 React Native应用程序由JavaScript...
    Juice_gg阅读 3,735评论 0 4
  • 当时遇见他的时候,我还有喜欢的人,因为在一起玩儿,ktv里他打听我的名字,结果他死党跟他说我已经有对象了,让他别想...
    远惘阅读 275评论 0 0
  • 门前、窗外有条欢快的小溪, 一年四季总以一样的节奏 欢快的奔腾着。 你寂寞时, 它会在那里陪着你。 在你开心时, ...
    Anand02阅读 196评论 0 2
  • 以”支付宝”为代表的第三方支付在互联网时代专注于电商支付,以免费转账等业务便利性带来了大量的用户。对于银行的线下支...
    木夜溯阅读 31,570评论 0 4