今天学习一下react-native-svg,一如既往,在安装该库的时候,就有一大堆坑等你填.

首先,我新建一个rn项目,按照官方说明先导入库

npm install react-native-svg --save

再链接库文件

rnpm link react-native-svg

然后运行,成功报错:

然后我换个姿势入水,我重新新建一个项目,先打开运行起来,再导入三方库和链接link.然后写一些三方库代码,然后刷新界面.

这次报:No component found for view with name "RNSVGRect"

查阅资料,xcode得手动链接,不能直接命令链接(链接不成功),得在xcode里面Add File to ‘project_name’,但是我已经link了,手动导的时候无法添加了...........

然后我再次新建项目,先命令行导入该三方库,再打开xcode手动链接,之后再命令行链接link(链接Android),链接时显示 iOS已经链接过,只链接Android.

然后敲入三方库代码.成功运行.如图:

1.新建rn项目,导入三方库:

npm install react-native-svg --save

2.Xcode打开项目.选中Libraries右键Add Files to "XXX",添加node_modules/react-native-svg/ios/RNSVG.xcodeproj

3.点击项目名,在General中的Linked Frameworks and Libraries中添加libRNSVG.a

4.这里再react-native link react-native-svg会显示

5.运行项目,OK

OK,入门坑已填,现在正式学习react-native-svg的使用.

常用模块:

类型 描述
 Svg  承载绘图区域
 Circle  圆
 Ellipse  椭圆
 G  包裹块(个人认为是为了单纯的层次分明)
 LinearGradient  线性渐变,可以做颜色的线性渐变效果
 RadialGradient   角度渐变,可以做颜色的角度渐变效果
 Line  线条
 Polyline  多段线
 Path  路径,类似的还有ClipPath
 Polygon  多边形
 Rect  矩形
 Symbol   定义个视图模块,其他地方可以随意使用该模块(可以通过id标示)
 Use  可以获取到Symbol视图模块使用(可以通过href找到模块)
 Text  文字信息
 TSpan  多行文字
 TextPath  文字路径
 Defs  个人觉得怎么和G标签一样啊.就像前端中的div一样
 Stop  效果停止位置

属性大致有:

类型 描述
fill 填充颜色
fillOpacity 填充透明度
fillRule 填充规则
stroke 外边框属性,可以定义颜色
strokeWidth 外边框宽度
strokeOpacity 外边框透明度
strokeLinecap  
strokeLinejoin  
strokeDasharray  
strokeDashoffset  
x x
y y
cx  cy  r 定义圆的中心,如果省略了cx和cy,那么圆的中心将被设置为(0,0),r圆的半径
rx  ry 定义水平半径 垂直半径
x1 y1 x2 y2 x1:x轴的开始位置 x2:x轴的结束位置   y1:y轴开始位置 y2:y轴结束位置 (通常用于Line模块)
points 多边形的每个角的x和y坐标.(通常用于Polygon模块,几个角就是几边形) 
rotate 旋转角度
scale 比例
origin 原点
originX 原点x
originY 原点y

下面看下界面显示效果:

1:圆形 Circle

        <Svg
height="100"
width="100"
>
<Circle
cx="50" //中心点x
cy="50" //中心点y
r="45" //半径
stroke="black"  //外边框 颜色  
strokeWidth="2.5" //外边框 宽度
fill="red" //填充颜色
/>
</Svg>

 

2:椭圆 Ellipse

        <Svg
height="100"
width="100"
>
<Ellipse
cx="50" //中点x
cy="50" //中点y
rx="35" //水平半径
ry="45" //垂直半径
stroke="purple" //边框颜色
strokeWidth="3" //边框宽度
fill="yellow" //填充颜色
/>
</Svg>

3:线条Line

        <Svg
height="100"
width="100"
>
<Line
x1="0" //x轴的开始位置
y1="0" //y轴的开始位置
x2="100" //x轴的结束位置
y2="100" //y轴的结束位置
stroke="red" //填充颜色
strokeWidth="2" //填充宽度
/>
</Svg>

4.多边形 Polygon

  <Svg
height="100"
width="100"
>
<Polygon
points="23,4 56,76 12,95 2,23" //多边形的每个角的x和y坐标
fill="red" //填充颜色
stroke="black" //外边框颜色
strokeWidth="2" //外边框宽度
/>
</Svg>

5.多段线 Polyline

        <Svg
height="100"
width="100"
>
<Polyline
points="10,10 40,60 60,70 95,90 23,89" //多段线的各个点
fill="none" //填充颜色 无
stroke="black" //边框色
strokeWidth="3" //边框宽度
/>
</Svg>

6.path属性 下面这一堆看不懂

  • M = moveto
  • L = lineto
  • H = horizontal lineto
  • V = vertical lineto
  • C = curveto
  • S = smooth curveto
  • Q = quadratic Bézier curve
  • T = smooth quadratic Bézier curveto
  • A = elliptical Arc
  • Z = closepath
<Svg
height="100"
width="100"
>
<Path
d="M25 10 L98 65 L70 25 L16 77 L11 30 L0 4 L90 50 L50 10 L11 22 L77 95 L20 25"
fill="none"
stroke="red"
/>
</Svg>

 

7. 文字信息(这个好6)Text

        <Svg
height="60"
width="200"
>
<Text
fill="none"
stroke="purple"
fontSize="20"
fontWeight="bold"
x="100"
y="20"
textAnchor="middle"
>大屌萌妹 RN 6 @</Text>
</Svg>

8.多行文字 TSpan

        <Svg
height="160"
width="200"
>
<Text x="10" y="60" fill="red" fontSize="14">
<TSpan dy="5 10 20" >12345</TSpan>
<TSpan fill="blue" dy="15" dx="0 5 5">
<TSpan>67</TSpan>
</TSpan>
</Text>
</Svg>

9.Symbol  Use

        <Svg
height="300"
width="300"
>
<Symbol id="symbol" viewBox="0 0 150 110" width="100" height="50">
<Circle cx="50" cy="50" r="40" strokeWidth="8" stroke="red" fill="red"/>
<Circle cx="90" cy="60" r="40" strokeWidth="8" stroke="green" fill="white"/>
<Rect x="25" y="5" width="60" height="50" fill="rgb(0,0,255)" strokeWidth="3" stroke="rgb(0,0,0)"/>
</Symbol> <Use
href="#symbol"
x="0"
y="0"
/>
<Use
href="#symbol"
x="0"
y="50"
width="170"
height="78"
/>
<Use
href="#symbol"
x="0"
y="200"
width="170"
height="78"
/>
</Svg>

.......其他模块和属性可以自己试试.

同时,这些模块都可以点击.

  • disabled
  • onPress
  • onPressIn
  • onPressOut
  • onLongPress
  • delayPressIn
  • delayPressOut
  • delayLongPress

另:react-natvie-svg 的介绍

react-native-ART-Sample

react-native-svg的使用的更多相关文章

  1. React Native:使用 JavaScript 构建原生应用

    [转载] 本篇为联合翻译,译者:寸志,范洪春,kmokidd,姜天意 数月前,Facebook 对外宣布了正在开发的 React Native 框架,这个框架允许你使用 JavaScript 开发原生 ...

  2. 深入浅出 React Native:使用 JavaScript 构建原生应用

    深入浅出 React Native:使用 JavaScript 构建原生应用 链接:https://zhuanlan.zhihu.com/p/19996445 原文:Introducing React ...

  3. React Native:使用 JavaScript 构建原生应用 详细剖析

    数月前,Facebook 对外宣布了正在开发的 React Native 框架,这个框架允许你使用 JavaScript 开发原生的 iOS 应用——就在今天,Beta 版的仓库释出了! 基于 Pho ...

  4. [转] 在React Native中使用ART

    http://bbs.reactnative.cn/topic/306/%E5%9C%A8react-native%E4%B8%AD%E4%BD%BF%E7%94%A8art 前半个月捣腾了一下Rea ...

  5. 📝 没 2 年 React Native 开发经验,你都遇不到这些坑

    如果你喜欢我的文章,希望点赞 收藏 评论 三连支持一下,谢谢你,这对我真的很重要! React Native 开发时,如果只是写些简单的页面,基本上按着官方文档 reactnative.dev就能写出 ...

  6. React Native纯干货总结

    随着项目也渐渐到了尾声,之前的项目是mobile开发,采用的是React Native.为即将要开始做RN项目或者已经做过的小伙伴可以参考借鉴,也顺便自己做一下之前项目的总结. 文章比较长,可以选择自 ...

  7. React Native 之 Text的使用

    前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...

  8. React Native环境配置之Windows版本搭建

    接近年底了,回想这一年都做了啥,学习了啥,然后突然发现,这一年买了不少书,看是看了,就没有完整看完的.悲催. 然后,最近项目也不是很紧了,所以抽空学习了H5.自学啃书还是很无趣的,虽然Head Fir ...

  9. 史上最全Windows版本搭建安装React Native环境配置

    史上最全Windows版本搭建安装React Native环境配置 配置过React Native 环境的都知道,在Windows React Native环境配置有很多坑要跳,为了帮助新手快速无误的 ...

  10. 【腾讯Bugly干货分享】React Native项目实战总结

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/577e16a7640ad7b4682c64a7 “8小时内拼工作,8小时外拼成长 ...

随机推荐

  1. Cookie、Session和自定义分页

    一.cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响, ...

  2. Matlab-6:解非线性方程组newton迭代法

    函数文件: function x=newton_Iterative_method(f,n,Initial) x0=Initial; tol=1e-11; x1=x0-Jacobian(f,n,x0)\ ...

  3. 使用js如何设置、获取盒模型的宽和高

    第一种: dom.style.width/height 这种方法只能获取使用内联样式的元素的宽和高. 第二种: dom.currentStyle.width/height 这种方法获取的是浏览器渲染以 ...

  4. Java开源框架知识整理

    1.Spring的了解     Spring是一个轻量级的IOC/DI和AOP容器的开源框架.可以实现Java模块化开发,贯穿表现层,业务层,逻辑层,实现各层之间的解耦合关系.     IOC,控制反 ...

  5. java Arrays.asList方法注意事项

    1. 简介 Arrays.asList()方法可以将数组转化为长度固定的列表. 该方法强调了列表的长度是固定的,因此不能使用list的add和remove方法修改list长度. 2. 示例 impor ...

  6. Visual Studio 向工程中添加文件夹

    将要添加的文件夹拷贝到工程的目标文件夹中. 打开工程,在Solution Explorer中选中“Show All Files”按钮. 然后VS会显示文件夹中包含,但是不在工程中的文件夹. 右键该文件 ...

  7. GDAL——命令使用专题——gdalsrsinfo命令

    GDAL——命令使用专题——gdalsrsinfo命令  前言 GDAL(Geospatial Data Abstraction Library)是一个在X/MIT许可协议下的开源栅格空间数据转换库. ...

  8. 在kali linux上安装VMware tool

    在安全圈的门口徘徊了一年,一直不知道该如何入门,现在决定先从kali 入手.有同样兴趣的伙伴欢迎一起. 但是刚在VMware上安好系统就遇到了一个大麻烦,看了很多书,还有教程但总是遇到这样那样的问题. ...

  9. 数据库SQL优化大总结1之- 百万级数据库优化方案

    转载自:https://blog.csdn.net/wuhuagu_wuhuaguo/article/details/72875054

  10. Servlet(2)

    HttpServlet 简介: Servlet 就是一个普通的java类,是运行在web容器上(tomcat)上的一个java类 用来通过Servlet中的代码,接受Http中浏览器的请求信息,以及对 ...