博客
关于我
React Native制作圆形加载条
阅读量:159 次
发布时间:2019-02-28

本文共 1621 字,大约阅读时间需要 5 分钟。

最近需求需要一个显示百分比的加载条。然而去搜索了很久,没能发现比较满意的组件,只好自己解决了。对于大多数前端而言,这个并不是特别难的任务,可能思路众多,但面对React Native却有点相形见绌。解决这样的问题,我们还是得回到前端本身,看看有什么可以嫁接的方案。

前端常规制作进度条方法

前端实现相对容易。我们可以用Canvas绘制圆,也可以用SVG绘制。SVG主要是通过<circle>元素进行绘制。我们先绘制第一个圆作为底色。接下来绘制一个带有色彩的圆(注意不要填充颜色fill="none")。需要了解两个关键属性:

  • stroke-dasharray:用于控制路径绘制中的虚线和间距。例如,圆的周长。
  • stroke-dashoffset:用于指定距离虚线绘制的起点。

如果我们知道了这个,圆的周长可以通过公式计算:CircleLength = R * 2 * Math.PI。百分比偏移量为PercentOffset = -CircleLength * yourPercent。然后将这个第二个圆赋予到style中:style="stroke-dashoffset: -93.9336; stroke-dasharray: 375.734;"

SVG相对来说还算是比较易用的解决方案。

使用 CSS渐变

还有一个更加直接的方法,就是利用 CSS3中的linear-gradient。例如:

background-image: linear-gradient(90deg, transparent 50%, #16a085 50%);

这样我们可以通过设置旋转的角度和间隔来实现渐变效果。代码示例如下:

.circle1 {  position: relative;  width: 110px;  height: 110px;  border-radius: 100%;  background-color: #eee;  background-image: linear-gradient(90deg, transparent 50%, #16a085 50%);}

使用 CSS Transform

如果要用Transform,可以采用以下方案。通过设置transform-origin,我们可以绕指定点旋转元素。代码示例如下:

.left-wrap {  overflow: hidden;  position: absolute;  left: 0;  top: 0;  width: 50%;  height: 100%;}.left-wrap .loader {  position: absolute;  left: 100%;  top: 0;  width: 100%;  height: 100%;  border-radius: 1000px;  background-color: #333;  transform-origin: 0 50% 0;}

React Native实现方案

在React Native中实现百分比加载条可以借助现有的组件。例如,可以使用react-native-percentage-circle。安装命令如下:

npm i react-native-percentage-circle --save

然后在代码中使用:

import PercentageCircle from 'react-native-percentage-circle';

示例代码如下:

参数说明

  • color:颜色字符串,例如'#000'
  • percent:百分比数,例如30
  • radius:圆的半径,例如20

当然,除了以上参数,你还可以根据需求自定义其他属性。如有建议或改进,欢迎提PR,共同完善这个组件。

转载地址:http://gyod.baihongyu.com/

你可能感兴趣的文章
Objective-C实现基于 LIFO的堆栈算法(附完整源码)
查看>>
Objective-C实现基于 LinkedList 的添加两个数字的解决方案算法(附完整源码)
查看>>
Objective-C实现基于事件对象实现线程同步(附完整源码)
查看>>
Objective-C实现基于文件流拷贝文件(附完整源码)
查看>>
Objective-C实现基于模板的双向链表(附完整源码)
查看>>
Objective-C实现基本二叉树算法(附完整源码)
查看>>
Objective-C实现备忘录模式(附完整源码)
查看>>
Objective-C实现复制粘贴文本功能(附完整源码)
查看>>
Objective-C实现复数类+-x%(附完整源码)
查看>>
Objective-C实现多组输入(附完整源码)
查看>>
Objective-C实现大根堆(附完整源码)
查看>>
Objective-C实现子集总和算法(附完整源码)
查看>>
Objective-C实现字符串boyer moore search博耶摩尔搜索算法(附完整源码)
查看>>
Objective-C实现字符串IP地址转DWORD地址(附完整源码)
查看>>
Objective-C实现字符串jaro winkler算法(附完整源码)
查看>>
Objective-C实现字符串manacher马拉车算法(附完整源码)
查看>>
Objective-C实现字符串wildcard pattern matching通配符模式匹配算法(附完整源码)
查看>>
Objective-C实现字符串word patterns单词模式算法(附完整源码)
查看>>
Objective-C实现字符串Z 函数或 Z 算法(附完整源码)
查看>>
Objective-C实现字符串加解密(附完整源码)
查看>>