react native 项目 和android 项目的整合

前提是要将环境搭配 好搭建开发环境

参考了一下 官网的东西嵌入到现有原生应用坑还是比较多的 可能是没有  写将 已有的react native 项目 和已有的android 项目整合吧

在RN项目根目录中 运行 npm install 命令 下载 node_modules 文件夹 如果有了就不需要 运行了

如果后面报错的话可以 删除 node_modules 文件夹 再在RN项目根目录中 运行 npm install  命令 试试

1. 将RN项目根目录下面android文件夹下面的 文件都删除

2.将你android项目根目录下面的文件复制 RN项目根目录下面android文件夹下

3. 将android app build.gradle 文件的        minSdkVersion  最低修改到minSdkVersion 16

4 在项目的 build.gradle 文件添加  maven {

            // All of React Native (JS, Android binaries) is installed from npm

            url "$rootDir/../node_modules/react-native/android"

        }

记住要在 allprojects  中 如下:

allprojects {

    repositories {

        google()

        jcenter()

//有多个的的话用

maven {

            // All of React Native (JS, Android binaries) is installed from np

          xxxxxxxxxx

        }

maven {

            // All of React Native (JS, Android binaries) is installed from npm

// 这个你要看一下 了有说 要去掉../ 根据你的项目来 我的项目添加了

            url "$rootDir/../node_modules/react-native/android"

        }

    }

}

5.在 App项目 的 build.gradle 文件中添加如下代码:

dependencies {

    compile 'com.android.support:appcompat-v7:23.0.1'

    ...

//如果报错 就改成RN 项目下package.json 文件中"react-native": "xxxx",的xxx 版本号

      implementation 'com.facebook.react:react-native:+'// From node_modules

}

要指定特定的 React Native 版本,可以用具体的版本号替换 “+”,当然前提是你从 npm 里下载的是这个版本。

6. 在app build.gradle 文件

apply plugin: 'com.android.application' 这一行下面 

    ....

android {

    compileSdkVersion 26

    .............

上面

添加

如:

apply plugin: 'com.android.application'

//以下从添加的内容

project.ext.react = [

        entryFile: "index.js"

]

apply from: "../../node_modules/react-native/react.gradle"

/**

* Set this to true to create two separate APKs instead of one:

*  - An APK that only works on ARM devices

*  - An APK that only works on x86 devices

* The advantage is the size of the APK is reduced by about 4MB.

* Upload all the APKs to the Play Store and people will download

* the correct one based on the CPU architecture of their device.

*/

def enableSeparateBuildPerCPUArchitecture = false

/**

* Run Proguard to shrink the Java bytecode in release builds.

*/

def enableProguardInReleaseBuilds = false

//以上是添加的内容

android {

    compileSdkVersion 26

    .............

7. 先执行 react-native link 这个命令是将 RN项目中的插件mode  连接到你的android中  然后在右边的 Gradle 窗口中 选中根目录 可能是“android ” 右键 Refresh 刷新 然后修改程序 入口

public class MainApplication extends Application implements ReactApplication {

public final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {

        @Override

        public boolean getUseDeveloperSupport() {

            return BuildConfig.DEBUG;

        }

        @Override

        protected List<ReactPackage> getPackages() {

            return Arrays.<ReactPackage>asList(

                    new RNDeviceInfo(),/*这些是 执行react-native link  命令 连接上的插件 还有原生程序 和RN交互的ativity 中的  mReactInstanceManager = ReactInstanceManager.builder(). .addPackages(Arrays.<ReactPackage>asList(

                        new RNDeviceInfo(),

                        new SvgPackage(),

                        new PickerViewPackage(),

                        new RNReactNativeDocViewerPackage(),

                        new MainReactPackage()

                ))要添加 不然会报 插件加载报错*/

                    new SvgPackage(),//同上

                    new PickerViewPackage(),//同上

                    new RNReactNativeDocViewerPackage(),//同上

                    new MainReactPackage()//这个不需要的

            );

        }

        @Override

        protected String getJSMainModuleName() {

            return "index";

        }

    };

    @Override

    public ReactNativeHost getReactNativeHost() {

        return mReactNativeHost;

    }

public void onCreate() {

..............................

}

查看 在app build.gradle 文件中 有没有 连接的插件

dependencies {

compile project(':react-native-svg')

compile project(':react-native-picker')

compile project(':react-native-doc-viewer')

compile project(':react-native-device-info')

.......

}

查看 settings.gradle 文件下有没有

include ':react-native-svg'

project(':react-native-svg').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-svg/android')

include ':react-native-picker'

project(':react-native-picker').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-picker/android')

include ':react-native-doc-viewer'

project(':react-native-doc-viewer').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-doc-viewer/android')

include ':react-native-device-info'

project(':react-native-device-info').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-device-info/android')

这个表示 你的插件 link (连接到) android 项目了

8. 原生和RN的交互  入口ReactActivity 写一个事件跳转 到 ReactActivity

public class ReactActivity extends Activity implements DefaultHardwareBackBtnHandler {

    private ReactRootView mReactRootView;

    private ReactInstanceManager mReactInstanceManager;

    public static int OVERLAY_PERMISSION_REQ_CODE=1258;

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        mReactRootView = new ReactRootView(this);

        mReactInstanceManager = ReactInstanceManager.builder()

                .setApplication(getApplication())

                .setBundleAssetName("index.android.bundle")

                .setJSMainModulePath("index")

//                .setJSMainModuleName("index")

//                .addPackage(new MainReactPackage())

//这里要特别注意  这里是官网的坑 必须和你程序入口MainApplication 中引入的 插件保持一致 否则 插件加载报错

                .addPackages(Arrays.<ReactPackage>asList(

                        new RNDeviceInfo(),

                        new SvgPackage(),

                        new PickerViewPackage(),

                        new RNReactNativeDocViewerPackage(),

                        new MainReactPackage()

//

                ))

                .setUseDeveloperSupport(BuildConfig.DEBUG)

                .setInitialLifecycleState(LifecycleState.RESUMED)

                .build();

        // 注意这里的MyReactNativeApp必须对应“index.js”中的

        // “AppRegistry.registerComponent()”的第一个参数

        mReactRootView.startReactApplication(mReactInstanceManager, "AwesomeProject", null);

        setContentView(mReactRootView);

    }

    @Override

    public void invokeDefaultOnBackPressed() {

        super.onBackPressed();

    }

    @Override

    protected void onPause() {

        super.onPause();

        if (mReactInstanceManager != null) {

            mReactInstanceManager.onHostPause();

        }

    }

    @Override

    protected void onResume() {

        super.onResume();

        if (mReactInstanceManager != null) {

            mReactInstanceManager.onHostResume(this, this);

        }

    }

    @Override

    public void onBackPressed() {

        if (mReactInstanceManager != null) {

            mReactInstanceManager.onBackPressed();

        } else {

            super.onBackPressed();

        }

    }

    @Override

    protected void onActivityResult(int requestCode, int resultCode, Intent data) {

        if (requestCode == OVERLAY_PERMISSION_REQ_CODE) {

            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {

                if (!Settings.canDrawOverlays(this)) {

                    // SYSTEM_ALERT_WINDOW permission not granted...

                }

            }

        }

    }

    @Override

    public boolean onKeyUp(int keyCode, KeyEvent event) {

        if (keyCode == KeyEvent.KEYCODE_MENU && mReactInstanceManager != null) {

            mReactInstanceManager.showDevOptionsDialog();

            return true;

        }

        return super.onKeyUp(keyCode, event);

    }

}

9.在清单文件 androidMainfest.xml 中

添加

  <!-- 访问internet权限 -->    <!--用于访问网络,网络定位需要上网-->

    <uses-permission android:name="android.permission.INTERNET" />

    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> <!--reatc--><!-- 用于开启 debug 版本的应用在6.0 系统上 层叠窗口权限 -->

    <uses-permission android:name="android.permission.SYSTEM_OVERLAY_WINDOW" /> <!--reatc-->

<!--react  摇一摇菜单 -->

        <activity android:name="com.facebook.react.devsupport.DevSettingsActivity" />

        <!--react  RN和原生交互的Activity -->

        <activity

            android:configChanges="fontScale"

            android:name="xxxx.xxx.xxx.ReactActivity"

            android:screenOrientation="portrait"

            android:windowSoftInputMode="adjustUnspecified|stateHidden" />

10 然后 在你RN项目 根目录下在文件路径框中 输入 cmd 回车  运行npm starr 命令 有时

11. 再开一个 cmd 窗口 运行查看你 真机设备

查看连接设备

adb devices

保证只有一个设备连接的情况下 连接本地服务器

adb reverse tcp:8081 tcp:8081

接着可以点击 事件了

我是用Android studio 运行的

忘记了 如果用命令运行需要在RN项目下的

package.json文件中

"scripts": {

    ........,

"bundle-android": "react-native bundle --entry-file index.js --platform android --dev false --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res/"

  }

需要手动在app/src/main/ 目录下创建assets文件夹

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