React Nativeを初めて使用しましたが、JavaからReact Native JavaScriptメソッドを呼び出すことが可能かどうかを知りたいですか?私は、押されたときにメソッドをトリガーするために使用したい物理的なボタンを備えたニッチデバイスを持っています。JavaScriptメソッドをJava React Nativeから呼び出す
私は次のプラグインを見ましたhttps://github.com/artemyarulin/react-native-evalしかし、Androidの実装は古くなっているようです。
私は周りにはありましたが、React NativeからJavaメソッドを呼び出すリファレンスを見つけることができます。
事前に感謝します。
EDIT
私は以下の@ideによって提案された方法を使用してソリューションを実装しようとしています。ここに私の試みはこれまでのところです:私は私のMainActivityで
:
private String latestBarcode = "";
...
public String getLastestBarcode() {
return this.latestBarcode;
}
public void setLatestBarcode(String barcode) {
this.latestBarcode = barcode;
}
@Override
public void onBarcodeEvent(final BarcodeReadEvent event) {
runOnUiThread(new Runnable(){
@Override
public void run() {
String barcodeData = event.getBarcodeData();
String tstp = event.getTimestamp();
setLatestBarcode(barcodeData);
Log.d("MainActivity", " TEST - barcodeData "+ barcodeData + " tstp : "+ tstp);
}
});
}
...
このコードは、ユーザーが物理的なハードウェアボタンを押すと、デバイスからのバーコード値を取得します。私のカスタムで
が
@ReactMethod
public void latestBarcode(Callback callback) {
final Activity activity = getCurrentActivity();
if(activity != null && activity instanceof MainActivity){
callback.invoke(((MainActivity) activity).getLastestBarcode());
}
else {
callback.invoke("");
}
}
ネイティブモジュールを反応させるのこのメソッドは値をとり、ネイティブを反応させるために、それを公開しています。これは私が値を読み取ることができます動作しますが、私は、ユーザーがそれはすべてその全体に今立っているように私は、ネイティブモジュールを反応させるのであるので、ここでボタンを押したときにメソッドをトリガーする必要があります。
import android.app.Activity;
import android.util.Log;
import com.facebook.react.bridge.NativeModule;
import com.facebook.react.bridge.Callback;
import com.facebook.react.bridge.ReactContextBaseJavaModule;
import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.bridge.ReactContext;
import com.facebook.react.bridge.ReactMethod;
import com.facebook.react.modules.core.DeviceEventManagerModule;
import com.facebook.react.bridge.WritableMap;
import com.facebook.react.bridge.Arguments;
import javax.annotation.Nullable;
// Import MainActivity
import com.myapp.MainActivity;
public class HoneywellCT50Module extends ReactContextBaseJavaModule {
private ReactContext reactContext;
public HoneywellCT50Module(ReactApplicationContext reactContext) {
super(reactContext);
this.reactContext = reactContext;
}
@ReactMethod
public void latestBarcode(Callback callback) {
final Activity activity = getCurrentActivity();
if(activity != null && activity instanceof MainActivity){
WritableMap params = Arguments.createMap(); // <--- Added WritableMap
sendEvent("BarcodeRecieved", params); // <--- Added sendEvent
callback.invoke(((MainActivity) activity).getLastestBarcode());
}
else {
callback.invoke("");
}
}
// Added sendEvent
private void sendEvent(
String eventName,
@Nullable WritableMap params
) {
this.reactContext
.getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
.emit(eventName, params);
}
@Override
public String getName() {
return "HoneywellCT50";
}
}
では、ネイティブリアクト:
// I import DeviceEventEmitter
import { DeviceEventEmitter } from 'react-native'
componentDidMount() {
// Listen for Honeywell Scans
DeviceEventEmitter.addListener('BarcodeRecieved', this.getBarcodeValue)
}
// I want to trigger this method
getBarcodeValue() {
console.log('Event Received')
// This gets the barcode value, works ok
HoneywellCT50.latestBarcode((value) => {
this.setState({ barcode: value })
})
}
上記のコードでは、Java /ビルドエラーなしでプロジェクトを構築できますが、JSエラーは表示されませんが、イベントをトリガーできません。誰もがここから正しい方向に向けるのを助けることができますか?
@ide私はあなたの答えに基づいて解決策を実装しようとしており、上記のコードを追加しました。私がどこに間違っているのか、何か提案がありますか? – mtwallet
JavaからJavaScriptへのイベントの送信は、最新のRNバージョン(少なくとも44と45)のドキュメントでは消え去ってしまったようです。 –