ReactNative Android

1.Mac系統(tǒng),Android-Studo2.2.3,ReactNative0.40
2.必須要先成功運(yùn)行HelloWorld工程,node_modules和package.json

3.創(chuàng)建安裝項(xiàng)目名稱'LaiHH',選中最低兼容16,android 4.1版本,創(chuàng)建一個(gè)Empty Activity空項(xiàng)目

4.對(duì)應(yīng)目錄結(jié)構(gòu)如下

Paste_Image.png

5.build.gradle加上代碼

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.2.3'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
        //原生Android集成ReactNative需要增加
        maven {
            // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
            url "$rootDir/../node_modules/react-native/android"
        }
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

6.build.gradle加上代碼(2個(gè)文件不一樣的,對(duì)應(yīng)的加上)

apply plugin: 'com.android.application'
android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "com.example.laihuihuang.laihh"
        minSdkVersion 16
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
//    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
//        exclude group: 'com.android.support', module: 'support-annotations'
//    })
    compile 'com.android.support:appcompat-v7:25.1.0'
    testCompile 'junit:junit:4.12'


    compile 'com.facebook.react:react-native:+'//ReactNative組件
    compile project(':react-native-image-picker')//相冊(cè)選擇
    compile project(':react-native-image-crop-picker')//相冊(cè)選中
    compile project(':react-native-smart-pull-to-refresh-listview')//下拉刷新
    compile project(':react-native-picker')//選擇器
//    compile project(':imagepickerModule')
//    compile 'com.nostra13.universalimageloader:universal-image-loader:1.9.3'  //optional
//    compile 'com.github.bumptech.glide:glide:3.6.1'   //optional
//    compile 'com.squareup.picasso:picasso:2.4.0'   //optional
}

7.settings.gradle加上自己常用的第三方組件

rootProject.name = 'LaiHH'
include ':react-native-image-picker'
project(':react-native-image-picker').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-image-picker/android')
include ':react-native-image-crop-picker'
project(':react-native-image-crop-picker').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-image-crop-picker/android')
include ':react-native-smart-pull-to-refresh-listview'
project(':react-native-smart-pull-to-refresh-listview').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-smart-pull-to-refresh-listview/android')
include ':react-native-picker'
project(':react-native-picker').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-picker/android')


//include ':imagepickerModule'
//project(':imagepickerModule').projectDir = new File(rootProject.projectDir, '../node_modules/imagepickerModule')

include ':app'

8.創(chuàng)建全局對(duì)象MainApplication

package com.example.laihuihuang.laihh;

import android.app.Application;
import android.util.Log;

import com.imagepicker.ImagePickerPackage;//相冊(cè)選擇
import com.beefe.picker.PickerViewPackage;//選擇器
import com.reactnative.ivpusic.imagepicker.PickerPackage;//相冊(cè)多選
import com.reactnativecomponent.swiperefreshlayout.RCTSwipeRefreshLayoutPackage;//下拉刷新

import com.facebook.react.ReactApplication;
import com.facebook.react.ReactInstanceManager;
import com.facebook.react.ReactNativeHost;
import com.facebook.react.ReactPackage;
import com.facebook.react.shell.MainReactPackage;
import com.facebook.soloader.SoLoader;

import java.util.Arrays;
import java.util.List;
public class MainApplication extends Application implements ReactApplication {
  private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
    @Override
    protected boolean getUseDeveloperSupport() {
      return BuildConfig.DEBUG;
    }
    @Override
    protected List<ReactPackage> getPackages() {
      return Arrays.<ReactPackage>asList(
          new MainReactPackage(),
            new PickerPackage(),//單選
            new RCTSwipeRefreshLayoutPackage(),//下拉刷新
            new PickerViewPackage(),  //選中數(shù)字
               new ImagePickerPackage() //相冊(cè)
      );
    }
  };
  @Override
  public ReactNativeHost getReactNativeHost() {
    return mReactNativeHost;
  }
  @Override
  public void onCreate() {
    super.onCreate();
    SoLoader.init(this, /* native exopackage */ false);
  }
}

9.創(chuàng)建RNActivity

package com.example.laihuihuang.laihh;

import android.os.Bundle;
import android.content.Context;
import android.support.v7.app.AppCompatActivity;
import android.widget.RelativeLayout;
import android.view.KeyEvent;

import com.facebook.react.ReactActivity;
import com.facebook.react.ReactInstanceManager;
import com.facebook.react.ReactRootView;
import com.facebook.react.common.LifecycleState;
import com.facebook.react.shell.MainReactPackage;

import com.imagepicker.ImagePickerPackage;
import com.beefe.picker.*;
import com.reactnative.ivpusic.imagepicker.*;
import com.reactnativecomponent.swiperefreshlayout.*;

public class RNActivity extends ReactActivity {
    private ReactRootView mReactRootView;
    private ReactInstanceManager mReactInstanceManager;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

//        mReactRootView = new ReactRootView(this);
//        mReactInstanceManager = ReactInstanceManager.builder()
//                .setApplication(getApplication())
//                .setBundleAssetName("index.android.bundle")
//                .setJSMainModuleName("index.android")
//                .addPackage(new MainReactPackage())
//                .addPackage(new PickerViewPackage())
//                .addPackage(new ImagePickerPackage())
//                .addPackage(new RCTSwipeRefreshLayoutPackage())
//                .addPackage(new PickerPackage())
//                .setUseDeveloperSupport(BuildConfig.DEBUG)
//                .setInitialLifecycleState(LifecycleState.RESUMED)
//                        //.setUseOldBridge(true) // uncomment this line if your app crashes
//                .build();
//        mReactRootView.startReactApplication(mReactInstanceManager, "LaiHH", null);//這里名字要對(duì)應(yīng)你的項(xiàng)目
//        setContentView(mReactRootView);
    }

    @Override
    protected String getMainComponentName() {
        return "LaiHH"; // 你的項(xiàng)目的名字
    }
    
}

10.編輯activity_rn.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:id="@+id/test_r"
    tools:context="com.example.laihuihuang.laihh.RNActivity">



    <com.facebook.react.ReactRootView
        android:id="@+id/test_js"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
      />


</RelativeLayout>

11.增加權(quán)限以及設(shè)置全局對(duì)象 android:name=".MainApplication"

   <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.laihuihuang.laihh">


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

    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.CAMERA" />

    
    <application
        android:name=".MainApplication"  
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".RNActivity"/>
    </application>

</manifest>

12.編輯activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.laihuihuang.laihh.MainActivity">

    <Button
        android:text="點(diǎn)擊我跳轉(zhuǎn)到ReactNative"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:layout_centerHorizontal="true"
        android:id="@+id/button" />
</RelativeLayout>

13.編輯MainActivity

package com.example.laihuihuang.laihh;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Button;
import android.content.Intent;
import android.view.View;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        Button button = (Button) findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(MainActivity.this, RNActivity.class);//傳入上下文,和要跳轉(zhuǎn)的界面
                startActivity(intent);
            }
        });

    }
}

14.最好clean下功能.重新編譯下工程,啟動(dòng)服務(wù)器運(yùn)行

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市逗载,隨后出現(xiàn)的幾起案子忘衍,更是在濱河造成了極大的恐慌烦味,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,332評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件芋忿,死亡現(xiàn)場離奇詭異照捡,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,508評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來刽锤,“玉大人镊尺,你說我怎么就攤上這事〔⑺迹” “怎么了庐氮?”我有些...
    開封第一講書人閱讀 157,812評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長族奢。 經(jīng)常有香客問我乓序,道長原献,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,607評(píng)論 1 284
  • 正文 為了忘掉前任音婶,我火速辦了婚禮,結(jié)果婚禮上莱坎,老公的妹妹穿的比我還像新娘衣式。我一直安慰自己,他們只是感情好檐什,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,728評(píng)論 6 386
  • 文/花漫 我一把揭開白布碴卧。 她就那樣靜靜地躺著,像睡著了一般乃正。 火紅的嫁衣襯著肌膚如雪住册。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,919評(píng)論 1 290
  • 那天瓮具,我揣著相機(jī)與錄音荧飞,去河邊找鬼。 笑死搭综,一個(gè)胖子當(dāng)著我的面吹牛垢箕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播兑巾,決...
    沈念sama閱讀 39,071評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼条获,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了蒋歌?” 一聲冷哼從身側(cè)響起帅掘,我...
    開封第一講書人閱讀 37,802評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎堂油,沒想到半個(gè)月后修档,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,256評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡府框,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,576評(píng)論 2 327
  • 正文 我和宋清朗相戀三年吱窝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,712評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡院峡,死狀恐怖兴使,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情照激,我是刑警寧澤发魄,帶...
    沈念sama閱讀 34,389評(píng)論 4 332
  • 正文 年R本政府宣布,位于F島的核電站俩垃,受9級(jí)特大地震影響励幼,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜口柳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,032評(píng)論 3 316
  • 文/蒙蒙 一苹粟、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧啄清,春花似錦六水、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至荣茫,卻和暖如春想帅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背啡莉。 一陣腳步聲響...
    開封第一講書人閱讀 32,026評(píng)論 1 266
  • 我被黑心中介騙來泰國打工港准, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人咧欣。 一個(gè)月前我還...
    沈念sama閱讀 46,473評(píng)論 2 360
  • 正文 我出身青樓浅缸,卻偏偏與公主長得像,于是被迫代替她去往敵國和親魄咕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子衩椒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,606評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容