当前位置: 首页 > news >正文

reactnative 调用原生ui组件

reactnative 调用原生ui组件

在这里插入图片描述

![组件对应关系](https://img-blog.csdnimg.cn/direct/c4351ad7bd38411e9c13087f1059a4b0.png)

1.该样例已textView,介绍。

新建MyTextViewManager 文件,继承SimpleViewManager。import android.graphics.Color;
import android.widget.TextView;import com.facebook.react.uimanager.SimpleViewManager;
import com.facebook.react.uimanager.ThemedReactContext;
import com.facebook.react.uimanager.annotations.ReactProp;public class MyTextViewManager extends SimpleViewManager<TextView> {@Overridepublic String getName() {return "MyTextView";}@Overrideprotected TextView createViewInstance(ThemedReactContext reactContext) {TextView textView = new TextView(reactContext);return textView;}@ReactProp(name="text")public void setText(TextView view,String text){view.setText(text);}@ReactProp(name="textSize")public void setTextSize(TextView view,float fontSize){view.setTextSize(fontSize);}@ReactProp(name="textColor",defaultInt = Color.BLACK)public void setTextColor(TextView view,int textColor){view.setTextColor(textColor);}@ReactProp(name="isAlpha",defaultBoolean = false)public void setTextAlpha(TextView view,boolean isAlpha){if(isAlpha){view.setAlpha(0.5f);}else{}}
}

第二部 桥接文件

import com.facebook.react.ReactPackage;
import com.facebook.react.bridge.JavaScriptModule;
import com.facebook.react.bridge.NativeModule;
import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.uimanager.ViewManager;
import com.gxl.express.apk.ui.CameraPreviewViewManager;
import com.gxl.express.apk.ui.MyCustomViewManager;
import com.gxl.express.apk.ui.MyTextViewManager;
import com.gxl.express.apk.ui.VideoViewManager;
import com.gxl.express.apk.ui.cameraViewManager;import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;public class TestReactPackage implements ReactPackage {@Overridepublic List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {List<NativeModule> modules = new ArrayList<>();modules.add(new OpenNativeModule(reactContext));return modules;}@Overridepublic List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
//        return Collections.emptyList();
//        return Arrays.<ViewManager>asList(new cameraViewManager(reactContext),new MyTextViewManager(),new CameraPreviewViewManager(),new VideoViewManager());return Arrays.<ViewManager>asList( new MyCustomViewManager(),new cameraViewManager(),new MyTextViewManager());}
}

第三步 将桥接文件引入

	@Overrideprotected List<ReactPackage> getPackages() {@SuppressWarnings("UnnecessaryLocalVariable")List<ReactPackage> packages = new PackageList(this).getPackages();// Packages that cannot be autolinked yet can be added manually here, for example:// packages.add(new MyReactNativePackage());
//            packages.add(new MainReactPackage());packages.add( new TestReactPackage());  // 将桥接文件引入return packages;}

第四步 在react native 项目中引入。

import React from 'react';
import { requireNativeComponent } from 'react-native';type Props = {text: String,textSize: Number,textColor:Number,isAlpha:Boolean
}const MyTextView = requireNativeComponent('MyTextView', MyCustomText, {});class MyCustomText extends React.PureComponent<Props> {render() {return <MyTextView {...this.props} />}
}export default MyCustomText;

第5走 引入组件使用

import MyCustomText from './../component/Mytext';<MyCustomTextstyle={{ width: 100, height: 100 }} text="00000"textSize={12}></MyCustomText>
http://www.lryc.cn/news/292312.html

相关文章:

  • 面试手写第五期
  • 【CSS】css选择器和css获取第n个元素(:nth-of-type(n)、:nth-child(n)、first-child和last-child)
  • 解析Excel文件内容,按每列首行元素名打印出某个字符串的统计占比(超详细)
  • qt中遇到[Makfile.Debug:119:debug/app.res.o] Error 1的原因以及解决方法
  • pytorch调用gpu训练的流程以及示例
  • 学习Android的第一天
  • 回归预测 | Matlab实现CPO-LSTM【24年新算法】冠豪猪优化长短期记忆神经网络多变量回归预测
  • Typora导出html文件图片自动转换成base64
  • 『C++成长记』string使用指南
  • 硬件连通性测试:构建数字世界的无形基石
  • mysql的安装与卸载
  • 假期作业 2.2
  • 运维SRE-02 正则表达式、grep
  • 【SpringCloud】使用OpenFeign进行微服务化改造
  • DRV8313和L298N都是电机驱动,一个是驱动三相FOC无刷直流电机的,一个是驱动有刷电机,使stm32控制无刷电机简单入门知识
  • React16源码: React中event事件系统初始化源码实现
  • Qt6入门教程 15:QRadioButton
  • Json序列化和反序列化 笔记
  • 新媒体与传媒行业数据分析实践:从网络爬虫到文本挖掘的综合应用,以“中国文化“为主题
  • Visual Studio使用Git忽略不想上传到远程仓库的文件
  • Nginx简单阐述及安装配置
  • 【遥感入门系列】遥感分类技术之遥感解译
  • 解决:IDEA无法下载源码,Cannot download sources, sources not found for: xxxx
  • 什么是IDE,新手改如何选择IDE?
  • springBoot+Vue汽车销售源码
  • FPS游戏框架漫谈第五天
  • 83.如何设计高可用系统
  • Map和Set讲解
  • PHP集成开发环境 PhpStorm 2023 for mac中文激活版
  • 数学建模 - 线性规划入门:Gurobi + python