/**
* @name ProgresCanvas
* @desc 进度条
* @author 方知有
* @taro 3.07
* @date 2020/08/06
*/
import React, { Component } from "react";
import Taro from "@tarojs/taro";
import { View, Canvas, Image, CoverView } from "@tarojs/components";
import styles from "./index.module.scss";
let clientHeight = Taro.$navBarWindowHeight; //可使用窗口高
let clientWidth = Taro.$navBarWindowWidth; //可使用窗口宽
let ratio; //根据尺寸动态计算 1px换算成多少rpx
export default class ProgresCanvas extends Component {
static defaultProps = {
data: "lalalal",
color: "#7d79f3",
progress: 0
};
state = { imageUrl: "", nowdata: "" };
componentDidUpdate() {
this.drawProgressbg();
}
//绘制背景
drawProgressbg = async () => {
//stepone, steptwo, size, width, colorone, colortwo
const { data } = this.props;
const { nowdata } = this.state;
if (JSON.stringify(data) === JSON.stringify(nowdata)) {
return;
} else if (data) {
// console.log("progressData====", data, nowdata);
this.setState({ nowdata: data });
Taro.getSystemInfo({
success: (res) => {
clientWidth = res.windowWidth;
clientHeight = res.windowHeight;
//屏幕宽度 375px = 750rpx, 1px = rpx
// 1px = (750 / 屏幕宽度)rpx;
// 1rpx = (屏幕宽度 / 750)px;
ratio = 550 / clientWidth;
}
});
// 使用 .createContext 获取绘图上下文 context
const { canvas, ctx } = await this.getCanvasCtx(data.idone);
ctx.lineWidth = Number(data.width);
ctx.strokeStyle = `${data.colorone}`;
// ctx.lineCap = "butt";
ctx.beginPath(); //开始一个新的路径
ctx.arc(69 / ratio, 69 / ratio, 60 / ratio, -Math.PI / data.start, data.end === 1 ? -2 * Math.PI : Math.PI + Math.PI / 2, false); //x,y,半径,开始,结束
// ctx.closePath();
ctx.stroke(); //对当前路径进行描边
ctx.strokeStyle = `${data.colortwo}`;
ctx.beginPath();
if (data.end === 1) {
ctx.arc(69 / ratio, 69 / ratio, 60 / ratio, -Math.PI / data.start, Number(data.steptwo) * Math.PI - Math.PI, false); //x,y,半径,开始,结束
} else {
ctx.arc(69 / ratio, 69 / ratio, 60 / ratio, -Math.PI / data.start, Number(data.steptwo) * Math.PI - Math.PI / 2, false); //x,y,半径,开始,结束
}
ctx.stroke();
setTimeout(() => {
const base64 = canvas.toDataURL("jpg", 0.6);
this.setState({ imageUrl: base64 });
}, 500);
}
};
getCanvasCtx = async (eleId = "", delay = 200) => {
return new Promise((resolve, reject) => {
const t = setTimeout(() => {
clearTimeout(t);
Taro.createSelectorQuery()
.select(`#${eleId}`)
.fields({ node: true })
.exec((res) => {
if (res && res[0] && res[0].node) {
const canvas = res[0].node;
const ctx = canvas.getContext("2d");
resolve({ canvas, ctx });
} else {
reject({});
}
});
}, delay);
});
};
render() {
const { data } = this.props;
return (
);
}
}
/**style样式*/
.progress_box {
width: 100%;
height: 100%;
position: relative;
}
.progress_bg {
position: absolute;
transform: translateX(-200vw);
top: 10%;
left: 10%;
}
.img {
margin-top: 4%;
margin-left: 4%;
width: 640px;
height: 320px;
}
/**使用方法*/
import ProgresCanvas from "@/components/Progress";//页面引入
const progData = {
stepone: 2,//底层圆进度,默认满圆
steptwo: 1,//上层圆进度
size: 1.2,//大小
width: 8,//宽度
colorone: "#E7E7E7",//底层圆颜色
colortwo: "#FFB17D",//上层圆颜色
idone: "bigdata_pro0101",//底层圆id(可用随机数)
idtwo: "bigdata_pro0102",//上层圆id
start: 1,//开始位置(不需要可屏蔽,相对应progress里面做相应屏蔽)
end: 1//控制整圆or半圆
};