精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

React Native中的Android原生模塊

移動開發(fā) Android
當(dāng)使用 React Native 開發(fā) Android 應(yīng)用時,你可能需要使用沒有被 React Native 封裝的模塊。但你可以使用 Java 編寫原生模塊,然后選擇性的暴露公共接口到 React Native。

[[176954]]

當(dāng)使用 React Native 開發(fā) Android 應(yīng)用時,你可能需要使用沒有被 React Native 封裝的模塊。但你可以使用 Java 編寫原生模塊,然后選擇性的暴露公共接口到 React Native。一起來試一下!

我們要寫一個什么東西

在寫這篇文章時,React Native 包含了 ImagePickerIOS 組件,但是在 Android 平臺上卻沒有對應(yīng)的 ImagePicker 組件。我們接下來就要為 Android 構(gòu)建一個簡單的、和 ImagePickerIOS 大致相仿的 ImagePicker。 

編寫一個 React Native 的 Android 原生模塊需要以下步驟:

  1. 創(chuàng)建一個 ReactPackage,把很多模塊(Native 和 Javascript)包含在一起,然后在 MainActivity 中的 getPackages 方法引用。
  2. 創(chuàng)建一個 Java 類,繼承 ReactContextBaseJavaModule 并實現(xiàn)需要的接口,然后注冊到我們的 ReactPackage。
  3. 覆寫上述類的 getName 方法,這個方法會作為 Javascript 的調(diào)用方法名。
  4. 使用 @ReactMethod 注解把需要的公共方法暴露給 Javascript。
  5. ***,在 Javascript 中通過 NativeModules 導(dǎo)入你的模塊。

讓我們一起實踐一下。

創(chuàng)建一個 ReactPackage

啟動 AndroidStudio 并且導(dǎo)航到 MyApp/android/app/src/main/java/com/myapp/MainActivity.java。它應(yīng)該看起來像這樣:

  1. package com.myapp; 
  2.  
  3. import com.facebook.react.ReactActivity; 
  4. import com.facebook.react.ReactPackage; 
  5. import com.facebook.react.shell.MainReactPackage; 
  6.  
  7. import java.util.Arrays; 
  8. import java.util.List; 
  9.  
  10. public class MainActivity extends ReactActivity { 
  11.  
  12.     @Override 
  13.     protected String getMainComponentName() { 
  14.         return "MyApp"
  15.     } 
  16.  
  17.     @Override 
  18.     protected boolean getUseDeveloperSupport() { 
  19.         return BuildConfig.DEBUG; 
  20.     } 
  21.  
  22.     @Override 
  23.     protected List<ReactPackage> getPackages() { 
  24.         return Arrays.<ReactPackage>asList( 
  25.             new MainReactPackage() 
  26.         ); 
  27.     } 
  28.  

我們先來引入一個尚未定義的包:

  1. import com.myapp.imagepicker.*; // import the package 
  2.  
  3. public class MainActivity extends ReactActivity { 
  4.     @Override 
  5.     protected List<ReactPackage> getPackages() { 
  6.         return Arrays.<ReactPackage>asList( 
  7.             new MainReactPackage(), 
  8.             new ImagePickerPackage() // include it in getPackages 
  9.         ); 
  10.     } 
  11.  

現(xiàn)在我們來編寫那個包。我們將會為它創(chuàng)建一個叫 imagepicker 的新目錄并且寫入 ImagePickerPackage:

  1. package com.myapp.imagepicker; 
  2.  
  3. import com.facebook.react.ReactPackage; 
  4. import com.facebook.react.bridge.JavaScriptModule; 
  5. import com.facebook.react.bridge.NativeModule; 
  6. import com.facebook.react.bridge.ReactApplicationContext; 
  7. import com.facebook.react.uimanager.ViewManager; 
  8.  
  9. import java.util.ArrayList; 
  10. import java.util.Collections; 
  11. import java.util.List; 
  12.  
  13. public class ImagePickerPackage implements ReactPackage { 
  14.     @Override 
  15.     public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) { 
  16.         List<NativeModule> modules = new ArrayList<>(); 
  17.  
  18.         modules.add(new ImagePickerModule(reactContext)); 
  19.  
  20.         return modules; 
  21.     } 
  22.  
  23.     @Override 
  24.     public List<Class<? extends JavaScriptModule>> createJSModules() { 
  25.         return Collections.emptyList(); 
  26.     } 
  27.  
  28.     @Override 
  29.     public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) { 
  30.         return Collections.emptyList(); 
  31.     } 
  32.  

現(xiàn)在我們已經(jīng)創(chuàng)建了一個包并且包含進(jìn) MainActivity 中了。

創(chuàng)建一個 ReactContextBaseJavaModule

我們將會以創(chuàng)建 ImagePickerModule 開始,繼承 ReactContextBaseJavaModule。

  1. package com.myapp.imagepicker; 
  2.  
  3. import com.facebook.react.bridge.ReactContextBaseJavaModule; 
  4.  
  5. public class ImagePickerModule extends ReactContextBaseJavaModule { 
  6.     public ImagePickerModule(ReactApplicationContext reactContext) { 
  7.         super(reactContext); 
  8.     } 
  9.  

這是一個好的開始,為了 React Native 能從 NativeModules 找到我們的模塊,我們需要覆寫 getName 方法。

  1. @Override 
  2. public String getName() { 
  3.     return "ImagePicker"
  4.  

我們現(xiàn)在有了一個可以被 JavaScript 代碼導(dǎo)入的 native 模塊,讓它做些有趣的事情吧。

暴露方法

ImagePickerIOS 定義了 openSelectDialog 方法,可以傳遞配置對象、失敗、成功的回調(diào)。讓我們在 ImagePickerModule 中定義一個相似的方法。

  1. import com.facebook.react.bridge.Callback; 
  2. import com.facebook.react.bridge.ReadableMap; 
  3.  
  4. public class ImagePickerModule extends ReactContextBaseJavaModule { 
  5.     @ReactMethod 
  6.     public void openSelectDialog(ReadableMap config, Callback successCallback, Callback cancelCallback) { 
  7.         Activity currentActivity = getCurrentActivity(); 
  8.      
  9.         if (currentActivity == null) { 
  10.             cancelCallback.invoke("Activity doesn't exist"); 
  11.             return
  12.         } 
  13.     } 
  14.  

這里我們從 React Native 中導(dǎo)入了 Callback 和 ReadableMap 來對應(yīng) JavaScript 中的 function 和 object。我們?yōu)檫@個方法加上@ReactMethod 注解,從而使它作為 ImagePicker 的一部分被 JavaScript 引用。

在方法體中我們獲取當(dāng)前的 activity,如果沒有獲取到 activity,就調(diào)用 cancel 的回調(diào)方法。我們現(xiàn)在有了一個可以運(yùn)行的方法,但是它還不能做任何有趣的事情。讓我們用它打開相冊。

  1. public class ImagePickerModule extends ReactContextBaseJavaModule { 
  2.     private static final int PICK_IMAGE = 1; 
  3.  
  4.     private Callback pickerSuccessCallback; 
  5.     private Callback pickerCancelCallback; 
  6.  
  7.     @ReactMethod 
  8.     public void openSelectDialog(ReadableMap config, Callback successCallback, Callback cancelCallback) { 
  9.         Activity currentActivity = getCurrentActivity(); 
  10.  
  11.         if (currentActivity == null) { 
  12.             cancelCallback.invoke("Activity doesn't exist"); 
  13.             return
  14.         } 
  15.  
  16.         pickerSuccessCallback = successCallback; 
  17.         pickerCancelCallback = cancelCallback; 
  18.  
  19.         try { 
  20.             final Intent galleryIntent = new Intent(); 
  21.  
  22.             galleryIntent.setType("image/*"); 
  23.             galleryIntent.setAction(Intent.ACTION_GET_CONTENT); 
  24.  
  25.             final Intent chooserIntent = Intent.createChooser(galleryIntent, "Pick an image"); 
  26.  
  27.             currentActivity.startActivityForResult(chooserIntent, PICK_IMAGE); 
  28.         } catch (Exception e) { 
  29.             cancelCallback.invoke(e); 
  30.         } 
  31.     } 
  32.  

首先,我們設(shè)置了回調(diào),然后,我們創(chuàng)建了一個 Intent 并把它傳遞給 startActivityForResult。***,我們把所有的東西都放在 try/catch 塊中來處理可能發(fā)生的異常。

當(dāng)你調(diào)用 openSelectDialog 時,你應(yīng)該可以看到一個相冊了。然而,當(dāng)你選擇一張圖片時,相冊并不做任何事情。為了能夠處理圖片數(shù)據(jù),我們需要在模塊中處理 activity 的返回值。

首先,我們需要在 react context 中添加 activity event listener:

  1. public class ImagePickerModule extends ReactContextBaseJavaModule implements ActivityEventListener { 
  2.     public ImagePickerModule(ReactApplicationContext reactContext) { 
  3.         super(reactContext); 
  4.         reactContext.addActivityEventListener(this); 
  5.     } 
  6.  

現(xiàn)在我們可以獲取到相冊返回的數(shù)據(jù)了。

  1. @Override 
  2. public void onActivityResult(final int requestCode, final int resultCode, final Intent intent) { 
  3.     if (pickerSuccessCallback != null) { 
  4.         if (resultCode == Activity.RESULT_CANCELED) { 
  5.             pickerCancelCallback.invoke("ImagePicker was cancelled"); 
  6.         } else if (resultCode == Activity.RESULT_OK) { 
  7.             Uri uri = intent.getData(); 
  8.  
  9.             if (uri == null) { 
  10.                 pickerCancelCallback.invoke("No image data found"); 
  11.             } else { 
  12.                 try { 
  13.                     pickerSuccessCallback.invoke(uri); 
  14.                 } catch (Exception e) { 
  15.                     pickerCancelCallback.invoke("No image data found"); 
  16.                 } 
  17.             } 
  18.         } 
  19.     } 
  20.  

在這里我們應(yīng)該可以通過 success callback 獲取到圖片 URI。

  1. NativeModules.ImagePicker.openSelectDialog( 
  2.   {}, // no config yet  
  3.   (uri) => { console.log(uri) },  
  4.   (error) => { console.log(error) } 
  5.  

為了和 ImagePickerIOS 的表現(xiàn)大致相仿,我們可以允許用戶選擇圖片、視頻或者直接打開相機(jī)。這些功能的寫法和上面基本一致,我們將會把它留給讀者作為練習(xí)。

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2018-06-13 16:38:33

React Nativ組件Android

2015-09-22 09:50:36

FacebookAndroid

2017-01-04 10:18:00

React NativScrollViewAndroid

2015-10-10 16:02:36

React NativAndroid

2015-03-30 12:13:23

React NativiOS

2017-06-20 12:48:55

React Nativ自定義模塊Note.js

2016-10-13 19:01:59

React NativUbuntu

2024-07-08 00:00:07

2016-08-12 13:55:06

2023-06-24 17:09:06

React前端

2016-08-12 08:49:46

React NativFacebookNative

2017-09-11 14:35:34

編輯器開發(fā)環(huán)境React

2019-08-19 08:14:52

深度鏈接iOSAndroid

2022-07-28 14:33:32

webviewweb頁面

2017-01-09 16:40:07

React NatiAndroid 開發(fā)

2023-01-29 08:00:00

Instagram濾鏡圖片編輯

2017-03-21 21:37:06

組件UI測試架構(gòu)

2017-03-09 13:29:04

ReactNative JSPatch

2024-02-20 01:53:01

ReactFlutter開發(fā)

2016-08-15 13:34:37

React NativiOSjs入口
點贊
收藏

51CTO技術(shù)棧公眾號

欧美一级视频精品观看| 成人爱爱电影网址| 日韩在线观看你懂的| www.色就是色.com| www欧美xxxx| 91在线视频免费观看| 国产精品中文在线| 久久国产免费观看| 国产中文字幕一区二区三区| 555www色欧美视频| 欧美精品久久久久久久免费| 国产毛片av在线| 国产精品一区二区你懂的| 欧美一区二区三区精品电影| 91麻豆精品久久毛片一级| 白嫩白嫩国产精品| 欧美日韩一区成人| 国产九九九九九| 在线中文资源天堂| 成人不卡免费av| 91免费在线视频网站| 亚洲影院在线播放| 欧美深夜福利| 中文亚洲视频在线| 熟妇高潮精品一区二区三区| 国产精区一区二区| 欧美性大战xxxxx久久久| 18禁裸男晨勃露j毛免费观看 | 日韩视频中午一区| 十八禁视频网站在线观看| 日本三级在线观看网站| 国产精品视频在线看| 久久大香伊蕉在人线观看热2| 91一区二区视频| 久久国产88| 高清欧美性猛交| 校园春色 亚洲| 欧美成人激情| 一区二区三区在线播放欧美| 国产激情第一页| 亚洲网一区二区三区| 欧美日韩激情一区二区三区| 黑森林福利视频导航| 2018av在线| 亚洲午夜精品久久久久久久久| 亚洲一区bb| 三区四区电影在线观看| 日本一区二区在线不卡| 欧美精品二区三区四区免费看视频| a天堂中文在线观看| 久久国产视频网| 国产精品亚洲视频在线观看| 亚洲免费视频二区| 日韩成人一级片| 国产精品吹潮在线观看| 欧美日韩一级黄色片| 久久国产免费| 国产99久久久欧美黑人| www日韩精品| 亚洲精品综合| 57pao成人永久免费视频| 国产午夜福利一区二区| 影音先锋亚洲一区| 91精品国产91| 午夜婷婷在线观看| 日本伊人午夜精品| 国产精品极品美女粉嫩高清在线| 亚洲天堂男人av| 日韩电影在线观看电影| 成人a在线观看| www.av在线.com| 成人毛片在线观看| 久久综合九色综合久99| 成人综合影院| 亚洲欧美中日韩| 欧美精品久久96人妻无码| 99在线播放| 亚洲在线免费播放| 国内性生活视频| 国产成人福利夜色影视| 678五月天丁香亚洲综合网| 色姑娘综合天天| 国内视频在线精品| 亚洲天堂av在线免费| 成人黄色短视频| 影音先锋一区| 国产精品久久不能| 999免费视频| 99精品视频在线观看| 日韩精品大片| а√中文在线8| 欧美日韩免费区域视频在线观看| 亚洲成人av免费看| 欧洲大片精品免费永久看nba| 精品99一区二区三区| 91精品人妻一区二区| 久久免费av| 国内精品400部情侣激情| 欧美日韩a v| 国产传媒久久文化传媒| 日本一区不卡| 啦啦啦中文在线观看日本| 色综合天天综合网国产成人综合天| 岛国毛片在线播放| 国产精品巨作av| 视频在线一区二区| av大片免费在线观看| 美女一区二区视频| 国产美女精品在线观看| 最近高清中文在线字幕在线观看| 亚洲成人自拍偷拍| 一区二区三区欧美精品| 天天做夜夜做人人爱精品 | 男人操女人的视频在线观看欧美| 1卡2卡3卡精品视频| 黄色影院在线播放| 亚洲一区二区在线视频| gogogo高清免费观看在线视频| 精品五月天堂| 久久国产精彩视频| 国内av在线播放| 99久久精品99国产精品| 2021狠狠干| 国产亚洲人成a在线v网站| 亚洲黄色www网站| 欧美黑人精品一区二区不卡| 免费成人小视频| 欧美一区二区三区四区夜夜大片| av资源网在线播放| 精品少妇一区二区三区在线播放| 免费成年人视频在线观看| 丝袜a∨在线一区二区三区不卡| 国产欧美一区二区三区不卡高清| 18加网站在线| 777色狠狠一区二区三区| 2019男人天堂| 日韩av网站在线观看| 日本亚洲导航| 亚洲高清黄色| 亚洲欧美国产精品| 五月天婷婷久久| 91在线精品秘密一区二区| 久久99久久久久久| 这里视频有精品| 欧美高清一级大片| 性生活免费网站| 亚洲一区二区三区精品在线| 妖精视频在线观看| 欧美91精品| 亚洲资源在线看| aaa大片在线观看| 日韩午夜精品电影| 青青草原国产视频| 粉嫩av一区二区三区| 色一情一乱一乱一区91| www.久久草.com| 欧美超级乱淫片喷水| 国产成a人亚洲精v品无码| 亚洲美女在线国产| 亚洲精品中文字幕乱码无线| 久久久久久久久久久妇女| 91亚洲永久免费精品| 成人黄色网址| 精品久久久久久综合日本欧美| 久久久久久久福利| av资源网一区| www黄色在线| 日韩精品一卡| 91久久精品美女高潮| 欧美人与禽猛交乱配| 亚洲国产欧美自拍| 少妇又紧又色又爽又刺激视频| 国产精品视频九色porn| 中文字幕一区二区三区四| 午夜精品偷拍| 久久精品国产精品国产精品污| 中文字幕乱码中文乱码51精品| 在线视频欧美性高潮| 国产精品福利电影| 亚洲va中文字幕| 黑人巨大精品欧美| 久久99久久久欧美国产| 黄色片免费在线观看视频| 偷拍自拍亚洲色图| 国产日韩欧美日韩大片| 性欧美ⅴideo另类hd| 亚洲美女av在线播放| 97久久人国产精品婷婷 | 无码人妻丰满熟妇精品区| 中文字幕巨乱亚洲| 亚洲av无码久久精品色欲| 在线亚洲观看| 国产系列第一页| 欧美大胆视频| 国产精品视频精品| 黑人精品视频| 色偷偷av一区二区三区乱| 亚洲国产一二三区| 欧美亚洲动漫另类| 国产一级淫片免费| 欧美国产日产图区| 国产chinese中国hdxxxx| 日产欧产美韩系列久久99| 黄色一级片黄色| 日本a级不卡| 国产综合欧美在线看| 久久女人天堂| 欧美一区二区三区……| 在线看一级片| 一本色道久久88亚洲综合88| 黑人乱码一区二区三区av| 欧美三级日韩三级| 国产a∨精品一区二区三区仙踪林| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国产精品成人av性教育| 天堂av中文在线| 中文字幕在线观看日韩| 亚洲 欧美 精品| 日韩欧美中文字幕制服| 中文字幕一区二区免费| 欧美性生交大片免费| 欧美久久久久久久久久久久| 国产欧美一区二区三区在线看蜜臀 | 伊人再见免费在线观看高清版| 红桃成人av在线播放| 国产欧美日韩伦理| 网站一区二区| 国产精品自拍网| 香蕉伊大人中文在线观看| 久久久久久国产精品久久| 毛片网站在线免费观看| 一区二区三区天堂av| 日本一区高清| 日韩电影中文字幕在线| 高h震动喷水双性1v1| 日韩欧美亚洲一区二区| 国产露脸国语对白在线| 欧美日韩精品一区二区天天拍小说 | 在线亚洲免费视频| 免费观看日批视频| 色综合久久中文综合久久牛| 久久不卡免费视频| 亚洲va韩国va欧美va精品| 精品无码一区二区三区电影桃花| 一区二区三区高清| 伊人365影院| 亚洲国产精品久久一线不卡| 久久精品视频日本| 午夜精品久久久久久| 日韩美女黄色片| 亚洲成人中文在线| 国产三级av片| 日本韩国一区二区| 色av性av丰满av| 91久久精品网| 亚洲综合一区中| 91精品国产色综合久久久蜜香臀| 国产精品人妻一区二区三区| 91精品国产综合久久香蕉麻豆 | 992tv成人免费观看| 2023国产精品久久久精品双| www.黄色网址.com| 欧美精品1区| 亚洲人精品午夜射精日韩 | 青青青视频在线免费观看| 国产91丝袜在线播放九色| 国产性生活一级片| 盗摄精品av一区二区三区| 中文字幕人妻熟女在线| 国产精品白丝喷水在线观看| 日韩超碰人人爽人人做人人添| 国产另类自拍| 日韩高清影视在线观看| 日本免费一区二区三区| 久久香蕉国产| 久久久久久av无码免费网站下载| 亚洲高清激情| 99精品视频在线看| 久久精品国产色蜜蜜麻豆| 91丨porny丨九色| caoporen国产精品视频| 五月婷六月丁香| 亚洲综合清纯丝袜自拍| 免费看日批视频| 欧美一区国产二区| 亚洲日本香蕉视频| www.久久色.com| 国产美女精品写真福利视频| 国产99久久久欧美黑人 | 蜜桃成人在线视频| 久久精品视频播放| 人成在线免费网站| 国产一区在线播放| 窝窝社区一区二区| 欧美另类videos| 日日夜夜精品视频免费| 久久久无码人妻精品无码| 久久久久高清精品| 久草免费新视频| 欧美天堂一区二区三区| 欧美性受xxxx狂喷水| 日韩中文在线观看| 中文字幕一区久| 96久久精品| 日本女优一区| 日本精品一区在线观看| 国产在线视频一区二区| 在线观看国产精品一区| 亚洲成人1区2区| 国产强伦人妻毛片| 亚洲人午夜色婷婷| 2020国产在线| 亚洲在线视频福利| 小小影院久久| 亚洲高清免费在线观看| 91毛片在线观看| 日本在线视频免费| 日韩一级视频免费观看在线| 成黄免费在线| 国产a∨精品一区二区三区不卡| 黑人久久a级毛片免费观看| 欧美 日韩 国产 在线观看| 首页国产欧美久久| 欧美做受xxxxxⅹ性视频| 亚洲成人一区二区| 国产xxxxxx| 欧美成人在线影院| 亚洲狼人在线| 一本色道久久综合亚洲精品婷婷 | 日本高清不卡的在线| 国产图片一区| 青青青在线观看视频| 国产精品综合网| www.超碰在线观看| 7777精品伊人久久久大香线蕉的| 成年人在线观看网站| 国产成人精品在线| 精品国产一级毛片| 激情综合网俺也去| 日本一区二区视频在线| 波多野结衣视频网址| 国产亚洲欧美日韩精品| 91精品xxx在线观看| 欧美日韩免费高清| 久久综合网络一区二区| 实拍女处破www免费看| 色综合久久久久久久久| 久久伊伊香蕉| 国产精品久久久久久亚洲调教| 精品国产午夜| 亚洲va在线va天堂va偷拍| 亚洲日本电影在线| 精品人妻一区二区三区日产乱码| 欧美黑人国产人伦爽爽爽| 白白在线精品| 久久国产色av免费观看| 欧美国产日产图区| 国产视频第一页| 久久久久久久久久婷婷| 老牛精品亚洲成av人片| 精品中文字幕av| 国产嫩草影院久久久久| 国产精品一级视频| 欧美丰满少妇xxxxx做受| 国产精品色呦| 久久久免费视频网站| 国产欧美一区二区三区沐欲| 一级淫片免费看| 欧美国产日韩中文字幕在线| 日韩有码中文字幕在线| www.超碰com| 亚洲精品国产精华液| 亚洲色图另类小说| 国产精品免费看久久久香蕉| 亚洲精品网址| 菠萝菠萝蜜网站| 欧美午夜免费电影| 色呦呦呦在线观看| 久久久久久欧美精品色一二三四| 全国精品久久少妇| 欧美国产日韩综合| 亚洲日本中文字幕免费在线不卡| 成人51免费| 亚洲人精品午夜射精日韩| 中文字幕欧美激情一区| 亚洲第一页综合| 国产精品大片wwwwww| 女主播福利一区| 国产一二三四五区| 日韩视频123| 欧美日韩女优| 成人免费毛片在线观看| 国产精品污污网站在线观看| 丰满少妇在线观看bd| 国产精品久久久av久久久| 国产精品av久久久久久麻豆网| 国产熟妇久久777777| 日韩一区二区三区视频| 三上悠亚一区二区| 可以看毛片的网址|