(十二)React Native跳转到android原生界面Activity

前端之家收集整理的这篇文章主要介绍了(十二)React Native跳转到android原生界面Activity前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

该篇文章实现方法其实和之前的第八篇-React Native实现调用android原生java方法并实现广播的发送和接受,方法类似,只不过调用原生方法里的动作不同,一个是启动servicer,一个是启动activity。所以本篇不多讲直接先看效果

一、用AS打开项目目录的android项目,并添加一个activity,该activity中未添加任何逻辑操作:

  1. package com.myreduxproject;
  2.  
  3. import android.support.v7.app.AppCompatActivity;
  4. import android.os.Bundle;
  5.  
  6. public class UserInfoActivity extends AppCompatActivity {
  7.  
  8. @Override
  9. protected void onCreate(Bundle savedInstanceState) {
  10. super.onCreate(savedInstanceState);
  11. setContentView(R.layout.activity_user_info);
  12. }
  13. }

二、添加MyIntentModule类,并继承ReactContextBaseJavaModule实现其方法和构造函数。在该类中添加方法,注意:方法头要加@ReactMethod

  1. package com.myreduxproject;
  2.  
  3. import android.app.Activity;
  4. import android.content.Intent;
  5.  
  6. import com.facebook.react.bridge.JSApplicationIllegalArgumentException;
  7. import com.facebook.react.bridge.ReactApplicationContext;
  8. import com.facebook.react.bridge.ReactContextBaseJavaModule;
  9. import com.facebook.react.bridge.ReactMethod;
  10.  
  11. /** * Created by Administrator on 2017/5/22. */
  12.  
  13. public class MyIntentModule extends ReactContextBaseJavaModule {
  14.  
  15. public MyIntentModule(ReactApplicationContext reactContext) {
  16. super(reactContext);
  17. }
  18.  
  19. @Override
  20. public String getName() {
  21. return "IntentMoudle";
  22. }
  23.  
  24. @ReactMethod
  25. public void startActivityFromJS(String name,String params){
  26. try{
  27. Activity currentActivity = getCurrentActivity();
  28. if(null!=currentActivity){
  29. Class toActivity = Class.forName(name);
  30. Intent intent = new Intent(currentActivity,toActivity);
  31. intent.putExtra("params",params);
  32. currentActivity.startActivity(intent);
  33. }
  34. }catch(Exception e){
  35. throw new JSApplicationIllegalArgumentException(
  36. "不能打开Activity : "+e.getMessage());
  37. }
  38. }
  39. //注意:记住getName方法中的命名名称,JS中调用需要
  40. //注意:startActivityFromJS方法添加RN注解(@ReactMethod),否则该方法将不被添加到RN中
  41. }

三、添加MyReactPackage类,实现ReactPackage接口里的方法,在重写方法createNativeModules里注册上一步添加的模块:

  1. package com.myreduxproject;
  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.Arrays;
  10. import java.util.Collections;
  11. import java.util.List;
  12.  
  13. /** * Created by Administrator on 2017/5/22. */
  14.  
  15. public class MyReactPackage implements ReactPackage {
  16. @Override
  17. public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {
  18. return Arrays.<NativeModule>asList(new MyIntentModule(reactContext));
  19. }
  20.  
  21. @Override
  22. public List<Class<? extends JavaScriptModule>> createJSModules() {
  23. return Collections.emptyList();
  24. }
  25.  
  26. @Override
  27. public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
  28. return Collections.emptyList();
  29. }
  30. }

四、接着在MainApplication中的getPackages方法注册到ReactPackage中:

  1. @Override
  2. protected List<ReactPackage> getPackages() {
  3. return Arrays.<ReactPackage>asList(
  4. new MainReactPackage(),**new MyReactPackage(),**
  5. new BaiduMapPackage(getApplicationContext())
  6. );
  7. }

五、接下来的工作便是RN的代码,首先引入NativeModules

  1. import {NativeModules} from 'react-native';

然后通过NativeModules调用我们创建的类中的方法

  1. NativeModules
  2. .IntentMoudle
  3. .startActivityFromJS("com.myreduxproject.UserInfoActivity",null);

猜你在找的React相关文章