Skip to content

lucaszhu2zgf/mp-progress

Repository files navigation

mp-progress

专注于在小程序中实现圆环形进度条的工具

why

小程序目前有很多第三方ui组件,基本都是以组件的形式引入使用,如果项目风格比较贴近第三方,那么这些成套的三方组件库是比较方便,不过如果只是使用三方ui库某几个组件的话,安装一个非常大的库则不太合理。

mp-progress目标文件体积小于7KB,方便的js调用方式和原生的canvas标签写法,非常适用于希望保留高度控制权的项目。

安装

$ npm install mp-progress --save

基础库要求

根据文档要求,支持 2.7.0 及以上的基础库版本,使用最新基础库效果最佳

微信原生小程序

使用微信原生小程序的方式引入npm包需要有额外的配置,具体可以查看 https://developers.weixin.qq.com/community/develop/article/doc/0008aecec4c9601e750be048d51c13

组件方式的调用(简单易用)

在对应页面引入组件,初始化data并在wxml中使用组件

由于组件实现差异,该方式在wepy中不适用

{
  "navigationBarTitleText": "首页",
  "usingComponents": {
    "mpProgress": "mp-progress/dist/component/mp-progress"
  }
}
...
// 参数使用方式相同,canvasSize默认是400*400
data = {
  config: {
    canvasSize: {
      width: 400,
      height: 400
    },
    percent: 100,
    barStyle: [{width: 20, fillStyle: '#f0f0f0'}, {width: 20, animate: true, fillStyle: [{position: 0, color: '#56B37F'}, {position: 1, color: '#c0e674'}]}],
    needDot: true,
    dotStyle: [{r: 20, fillStyle: '#ffffff', shadow: 'rgba(0,0,0,.15)'}, {r: 10, fillStyle: '#56B37F'}]
  },
  percentage: 10
}
...
<mpProgress config="{{config}}" percentage="{{percentage}}"></mpProgress>

该方式遵从双向绑定数据的原则,当页面改变percentage,mp-progress会自动更新视图

API方式调用(适合需要在mp-progress上层构建新组件的需求)

该方式适用于wepy,但必须在onReady回调函数里面进行初始化

传入的单位是rpx,即如果canvas宽度为400rpx,则传入400,后续会自动计算真实尺寸

import MpProgress from 'mp-progress';
...
// 初始化
// 注意:在wepy中必须在onReady里调用
const mprogress = new MpProgress({
  target: this,
  canvasId: 'progress',
  canvasSize: {width: 400, height: 400},
  barStyle: [{width: 12, fillStyle: '#f0f0f0'}, {width: 12, fillStyle: [{position: 0, color: '#56B37F'}, {position: 1, color: '#c0e674'}]}]
});

// 开始绘制进度,60代表60%
mprogress.draw(60);

...
<canvas class="canvas" type="2d" id="progress"></canvas>

显示模式

效果 解析
正常模式 正常模式(默认)
百分比模式 百分比模式(只需要按需求传入percent即可,相见参数说明)

参数说明

参数名 数据类型 必要参数 解析 示列
target Object 页面上下文 this
canvasId String 页面canvas的id progress
canvasSize Object canvas画布的大小,对应单位是rpx,只需要传入数字即可 {width: 200, height: 300}
percent Number 默认按照360度去计算和显示圆环,如果传入80%则会自动根据canvas尺寸贴底画出最大半圆弧,有效值在50%~100% 100
barStyle Array 圆弧进度样式,按照数组元素的位置顺序渲染,一般第一个元素配置是铺满整个圆弧的底色,第二个元素配置是按照进度百分比渲染圆弧。fillStyle可以是是普通颜色和渐变颜色,使用渐变颜色是需要按照数组的格式传入各个点的位置和颜色信息 [{width: 12, fillStyle: '#f0f0f0'}, {width: 12, animate: true, fillStyle: [{position: 0, color: '#56B37F'}, {position: 1, color: '#c0e674'}]}]
needDot Boolean 是否需要显示进度点 false
dotStyle Array 进度点样式配置,最多支持两种样式叠加,为保证进度点的清晰显示第一个点默认添加阴影。如果第一个进度点直径比进度条更大时,为了保证在画布内完整显示进度点,绘制的进度条圆圈必须减少对应的差值,其中shadow是可选的配置,shadow的值是(0, 0, r/2, shadow) dotStyle: [{r: 24, fillStyle: '#fff', shadow: 'rgba(0,0,0,.15)'}, {r: 10, fillStyle: '#56B37F'}]

绘制函数说明

考虑到进度条在一个页面可能多次更新,所以当组件实例化完成之后,需要手动调用draw方法去画图

参数名 数据类型 必要参数 解析
percentage Number 圆弧百分比,比如传入的是60,只会逆时针渲染剩余的60%圆弧

其他说明

  • 如何设置弧线端点样式

    可以在barStyle中任何一个参数项增加lineCap参数,例如:barStyle: [{width: 12, lineCap: 'round', fillStyle: '#56B37F'}],lineCap有效值可以查看文档

  • 必须在2.7.0版本以上的SDK运行

    组件已经采用微信最新的同层渲染方法,该方法要求SDK版本不低于2.7.0

  • dotStyle

    如果dotStyle包含shadow的话,为了保证shadow在圆环的所有都可以完整展示,会自动缩减进度条的半径

  • 进度动画

    目前动画只在barStyle最后一个元素的定义中起作用,每一帧的动画为总动画的2%

  • 文字展示效果

    正常模式

    实现代码可以参考:

    <view class="garage-status">
      <canvas class="canvas" type="2d" id="progress"></canvas>
      <view class="status-ctn">
        <view class="status-count">127/127</view>
        <view class="desc-text">适用车位剩余</view>
      </view>
    </view>
    
  • 问题反馈

    问题反馈