React Native 中调用 Android 自定义控件

在 React Native 中调用 Android 自定义控件(也称为"原生 UI 组件")涉及以下核心步骤,需同时处理 Android 原生代码和 JavaScript 封装逻辑。以下是实现流程及关键代码示例:


⚙️ ​1. Android 原生自定义 View 实现

自定义一个继承自 View 的类,并实现其属性和绘制逻辑:

java 复制代码
// GradientColorView.java
public class GradientColorView extends View {
    private GradientDrawable mDrawable;
    private int mStartColor;
    private int mEndColor;

    public GradientColorView(Context context) {
        super(context);
        mDrawable = new GradientDrawable(Orientation.LEFT_RIGHT, null);
    }

    public void setStartColor(int color) {
        mStartColor = color;
        invalidate(); // 触发重绘
    }

    public void setEndColor(int color) {
        mEndColor = color;
        invalidate();
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        mDrawable.setColors(new int[]{mStartColor, mEndColor});
        mDrawable.setBounds(0, 0, getWidth(), getHeight());
        mDrawable.draw(canvas);
    }
}

关键点​:

  • 通过 setStartColor/setEndColor 暴露属性修改接口。
  • 调用 invalidate() 确保属性更新后刷新视图。

🧩 ​2. 创建 ViewManager 管理自定义 View

继承 SimpleViewManager<T> 类,将 Java 方法映射为 RN 属性:

typescript 复制代码
// GradientColorViewManager.java
public class GradientColorViewManager extends SimpleViewManager<GradientColorView> {
    public static final String REACT_CLASS = "RCTGradientColorView";

    @Override
    public String getName() {
        return REACT_CLASS; // JS 端引用此名称
    }

    @Override
    protected GradientColorView createViewInstance(ThemedReactContext context) {
        return new GradientColorView(context);
    }

    @ReactProp(name = "startColor", customType = "Color")
    public void setStartColor(GradientColorView view, @Nullable Integer color) {
        view.setStartColor(color); // 接收 JS 传入的颜色值
    }

    @ReactProp(name = "endColor", customType = "Color")
    public void setEndColor(GradientColorView view, @Nullable Integer color) {
        view.setEndColor(color);
    }
}

关键注解​:

  • @ReactProp:定义 JS 属性名与类型(customType="Color" 自动转换颜色字符串为整数)。
  • 方法需为 public void,首个参数为视图实例。

📝 ​3. 注册 ViewManager 到 ReactPackage

在自定义的 ReactPackage 中将 ViewManager 加入注册列表:

typescript 复制代码
// CustomReactPackage.java
public class CustomReactPackage implements ReactPackage {
    @Override
    public List<ViewManager> createViewManagers(ReactApplicationContext context) {
        return Arrays.<ViewManager>asList(
            new GradientColorViewManager() // 注册自定义 ViewManager
        );
    }

    @Override
    public List<NativeModule> createNativeModules(...) {...} // 若无原生模块,返回空列表
}

集成到 RN ​:

MainApplication.javagetPackages() 中添加此 Package:

arduino 复制代码
.addPackage(new CustomReactPackage()) // 注册自定义包

🌐 ​4. JavaScript 端封装组件

使用 requireNativeComponent 将原生组件映射到 JS:

php 复制代码
// GradientColorView.js
import { requireNativeComponent, ViewPropTypes } from 'react-native';

const NativeGradientColorView = requireNativeComponent('RCTGradientColorView', {
  propTypes: {
    startColor: PropTypes.string, // 颜色字符串(如 "#FF0000")
    endColor: PropTypes.string,
    ...ViewPropTypes // 继承基础 View 属性(如 style)
  }
});

export default NativeGradientColorView;

注意事项​:

  • 名称 'RCTGradientColorView' 需与 ViewManager.getName() 完全一致。
  • 属性类型(如 PropTypes.string)需与 @ReactProp 注解的 Java 类型匹配。

⚡️ ​5. 在 RN 中使用自定义组件

导入封装后的组件并传递属性:

ini 复制代码
import GradientColorView from './GradientColorView';

<GradientColorView
  style={{ width: 200, height: 200 }}
  startColor="#FF0000" // 红色起始
  endColor="#0000FF"   // 蓝色结束
/>

🧪 ​调试常见问题

  1. 属性未生效​:

    • 检查 @ReactPropname 与 JS 属性名是否一致。
    • 确保 Android 的 setColor() 等方法调用了 invalidate()
  2. 类型转换错误​:

    • 颜色需通过 processColor() 转换(若未用 customType="Color")。
  3. 组件未注册​:

    • 确认 ViewManager 已添加到 ReactPackage 并在 getPackages() 加载。

🔚 ​总结流程

graph TD A[Android 自定义 View] --> B[创建 ViewManager 映射属性] B --> C[注册 ViewManager 到 ReactPackage] C --> D[JS 端 requireNativeComponent 封装] D --> E[RN 中使用组件传参]

通过以上步骤,RN 即可调用高性能的 Android 原生 UI 组件,适用于需要复杂绘图、动画或特定平台功能的场景。建议结合 官方文档 和示例代码 进一步调试优化。

相关推荐
robotx2 小时前
安卓线程相关
android
消失的旧时光-19433 小时前
Android 面试高频:JSON 文件、大数据存储与断电安全(从原理到工程实践)
android·面试·json
dalancon4 小时前
VSYNC 信号流程分析 (Android 14)
android
dalancon4 小时前
VSYNC 信号完整流程2
android
dalancon4 小时前
SurfaceFlinger 上帧后 releaseBuffer 完整流程分析
android
用户69371750013845 小时前
不卷AI速度,我卷自己的从容——北京程序员手记
android·前端·人工智能
程序员Android5 小时前
Android 刷新一帧流程trace拆解
android
墨狂之逸才6 小时前
解决 Android/Gradle 编译报错:Comparison method violates its general contract!
android
阿明的小蝴蝶7 小时前
记一次Gradle环境的编译问题与解决
android·前端·gradle
汪海游龙7 小时前
开源项目 Trending AI 招募 Google Play 内测人员(12 名)
android·github