Rect Native調(diào)用Android原生方法(特別篇)

開發(fā)工具:WebStorm,Android Studio(下文簡稱AS)

開發(fā)React Native項(xiàng)目個(gè)人還是比較推薦WebStorm,它的操作界面以及快捷鍵跟AS如出一轍柔逼,對于Android開發(fā)者來說,使用這款I(lǐng)DE是極好的,哈哈腰湾。

作為一個(gè)剛開始寫技術(shù)文章的新手,謝謝各位的鼓勵(lì)與支持讨越。之所以取名為“特別篇”,其實(shí)主要內(nèi)容不多着逐,就是對以往兩篇文章的內(nèi)容進(jìn)行歸納與總結(jié),本來打算寫關(guān)于Android生命周期組件的文章,但想想還是先把前幾天,欠下的內(nèi)容先補(bǔ)上锥咸,正所謂“打鐵要趁熱”弧轧,免得以后忘了,廢話說到這,開始今天的正文。

前言:

原生應(yīng)用中嵌入RN可以參考React Native官方中文文檔或者參考在Android原生應(yīng)用中嵌入React Native,在RN中調(diào)用Android原生方法可以參考React Native調(diào)用Android原生方法,本篇特別的地方就在于如果在Android原生應(yīng)用中接入RN,RN又要調(diào)用Android原生方法堕仔,用React Native調(diào)用Android原生方法里面的方式注冊并申明模塊的方法是行不通的,那篇文章方法只是適用于原來項(xiàng)目是RN項(xiàng)目。

一.原生應(yīng)用嵌入React Native 步驟:

1.創(chuàng)建RN的項(xiàng)目文件夾,在項(xiàng)目目錄里創(chuàng)建android文件夾你虹,并將原生Android項(xiàng)目代碼拷入/android中绘搞;

2.在RN項(xiàng)目文件夾中,創(chuàng)建一個(gè)名為package.json的文本文件傅物;

3.在RN項(xiàng)目目錄位置打開終端夯辖,運(yùn)行 npm install,安裝RN所需的服務(wù);

4.AS中打開/android中安卓項(xiàng)目董饰,配置對于Maven以及依賴包蒿褂,在AndroidManifest.xml文件中添加Internet權(quán)限,以及需要配置添加的Activity界面卒暂;

具體方法參考:在Android原生應(yīng)用中嵌入React Native

二.RN調(diào)用Android原生方法 步驟:

1.創(chuàng)建模塊:新建Java Class 讓其繼承ReactContextBaseJavaModule并實(shí)現(xiàn)里面的方法啄栓;

2.注冊模塊:新建Java Class 實(shí)現(xiàn)ReactPackage里面的方法【RN官方文檔中有三個(gè)方法,最近發(fā)現(xiàn)只有兩個(gè)了】也祠;

3.然后將第二步創(chuàng)建Java Class加入到MainApplication.java文件的getPackages方法中昙楚;

4.RN中封裝模塊以及調(diào)用;

具體方法參考:React Native調(diào)用Android原生方法

區(qū)別:

原生Android項(xiàng)目引入RN界面诈嘿,在RN界面調(diào)用注冊好Android原生方法,創(chuàng)建以及注冊模塊方法堪旧,參考上文二步驟,但同時(shí)也要在上文步驟一的4方法中奖亚,展示React Native代碼界面的onCreate()方法中,將你創(chuàng)建的注冊模塊【上文二步驟方法2】添加到ReactInstanceManager.builder()中:

        @Override
        protected void onCreate(@Nullable 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 AnExampleReactPackage())
            .setUseDeveloperSupport(BuildConfig.DEBUG)
            .setInitialLifecycleState(LifecycleState.RESUMED)
            .build();

            // 注意這里的MyReactNativeApp必須對應(yīng)“index.android.js”中的
            // “AppRegistry.registerComponent()”的第一個(gè)參數(shù)
            mReactRootView.startReactApplication(mReactInstanceManager, "ReactApp", null);
            
            setContentView(mReactRootView);
        }

注:上文.addPackage(new AnExampleReactPackage())【AnExampleReactPackage()類就是實(shí)現(xiàn)了ReactPackage接口】淳梦,同時(shí)AnExampleReactPackage()類也要加入MainApplication.java的ReactNativeHost中:

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(), new AnExampleReactPackage()
        );
        }
    };
    
    @Override
    public ReactNativeHost getReactNativeHost() {
        return mReactNativeHost;
    }

再AS中運(yùn)行項(xiàng)目,你會發(fā)現(xiàn)AS的日志貓里會有你再RN界面的中打印的log日志【以React Native調(diào)用Android原生方法中注冊的log為例子】

以上內(nèi)容如有不對昔字,歡迎留言指正爆袍,謝謝!W鞴陨囊!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市所坯,隨后出現(xiàn)的幾起案子谆扎,更是在濱河造成了極大的恐慌,老刑警劉巖芹助,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件堂湖,死亡現(xiàn)場離奇詭異闲先,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)无蜂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進(jìn)店門伺糠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人斥季,你說我怎么就攤上這事训桶。” “怎么了酣倾?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵舵揭,是天一觀的道長。 經(jīng)常有香客問我躁锡,道長午绳,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任映之,我火速辦了婚禮拦焚,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘杠输。我一直安慰自己赎败,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布蠢甲。 她就那樣靜靜地躺著僵刮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鹦牛。 梳的紋絲不亂的頭發(fā)上妓笙,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天,我揣著相機(jī)與錄音能岩,去河邊找鬼。 笑死萧福,一個(gè)胖子當(dāng)著我的面吹牛拉鹃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鲫忍,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼膏燕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了悟民?” 一聲冷哼從身側(cè)響起坝辫,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎射亏,沒想到半個(gè)月后近忙,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體竭业,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年及舍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了未辆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,977評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡锯玛,死狀恐怖咐柜,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情攘残,我是刑警寧澤拙友,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站歼郭,受9級特大地震影響遗契,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜实撒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一姊途、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧知态,春花似錦捷兰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至其做,卻和暖如春顶考,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背妖泄。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工驹沿, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蹈胡。 一個(gè)月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓渊季,卻偏偏與公主長得像,于是被迫代替她去往敵國和親罚渐。 傳聞我的和親對象是個(gè)殘疾皇子却汉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評論 2 355

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