【问题标题】:Animate a Fill Circle like pie chart using Canvas使用 Canvas 为像饼图一样的填充圆制作动画
【发布时间】:2016-05-21 12:49:19
【问题描述】:

基本上我希望能够使用画布填充一个圆圈,但它像饼图和蒙版一样动画以在圆圈中显示新图像。 我的画布知识并不惊人,这是一个显示我想要的图像。 有人对如何做到这一点有所了解吗? 这是我管理的一个小提琴

    var canvas = document.getElementById('Circle');
      var context = canvas.getContext('2d');
      var centerX = canvas.width / 2;
      var centerY = canvas.height / 2;
      var radius = 80;
            var full = radius*2;
            var amount = 0;
            var amountToIncrease = 0.1;
      function draw() {
      context.beginPath();
      context.arc(centerX, centerY, radius, 0, amount * Math.PI, false);
      context.fillStyle = '#13a8a4';
      context.fill();
      context.lineWidth = 10;
      context.strokeStyle = '#000000';
      context.stroke();
    amount += amountToIncrease;
    if (amount > full) amount = 0; // restart
}
draw();
// Every second we'll fill more;
setInterval(draw, 100);

【问题讨论】:

  • 你可以选择markE的回复作为答案,效果很好。

标签: javascript html canvas


【解决方案1】:

这是一种方式:

  1. 绘制灰色背景。
  2. 用 -Math.PI*2 (=="12 on a clock") 和 -Math.PI*2 + Math.PI*2*percent (= = 2PI 乘以所需百分比的整圈)。
  3. 绘制您的徽标。

要制作动画,只需使用 requestAnimationFrame 循环,该循环从 0% 开始逐渐绘制百分比弧,并以目标百分比结束。

示例代码和演示:

var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var cw=canvas.width;
var ch=canvas.height;

var nextTime=0;
var duration=1000;
var endingPct=75;
var pct=0;
var increment=duration/pct;
requestAnimationFrame(animate);

function animate(time){
    draw(pct);
    pct++;
    if(pct<=endingPct){requestAnimationFrame(animate);}
}

function draw(pct){
    var endRadians=-Math.PI/2+Math.PI*2*pct/100;
    ctx.fillStyle='lightgray';
    ctx.fillRect(0,0,cw,ch);
    ctx.beginPath();
    ctx.arc(150,125,100,-Math.PI/2,endRadians);
    ctx.lineTo(150,125);
    ctx.fillStyle='white';
    ctx.fill();
    ctx.beginPath();
    ctx.moveTo(150,100);
    ctx.lineTo(175,150);
    ctx.quadraticCurveTo(150,125,125,150);
    ctx.closePath();
    ctx.strokeStyle='#13a8a4';
    ctx.lineJoin='bevel';
    ctx.lineWidth=10;
    ctx.stroke();
    ctx.fillStyle='black';
    ctx.textAlign='center';
    ctx.textBaseline='middle'
    ctx.font='18px arial';
    ctx.fillText('ADUR',150,175);
}
body{ background-color: ivory; }
#canvas{border:1px solid red; margin:0 auto; }
&lt;canvas id="canvas" width=300 height=300&gt;&lt;/canvas&gt;

[更新:我们需要在动画楔形内部剪辑图像]

var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var cw=canvas.width;
var ch=canvas.height;

var nextTime=0;
var duration=1000;
var endingPct=75;
var pct=0;
var increment=duration/pct;
var cx=cw/2;
var cy=ch/2;

var img=new Image();
img.onload=start;
img.src="https://dl.dropboxusercontent.com/u/139992952/multple/mm.jpg";
function start(){
    requestAnimationFrame(animate);
}

function animate(time){
    draw(pct);
    pct++;
    if(pct<=endingPct){requestAnimationFrame(animate);}
}

function draw(pct){
    //
    var endRadians=-Math.PI/2+Math.PI*2*pct/100;
    //
    ctx.fillStyle='lightgray';
    ctx.fillRect(0,0,cw,ch);
    //
    ctx.beginPath();
    ctx.arc(cx,cy,100,-Math.PI/2,endRadians);
    ctx.lineTo(cx,cy);
    ctx.save();
    ctx.clip();
    ctx.drawImage(img,cx-img.width/2,cx-img.height/2);
    ctx.restore();
}
body{ background-color: ivory; }
#canvas{border:1px solid red; margin:0 auto; }
&lt;canvas id="canvas" width=300 height=300&gt;&lt;/canvas&gt;

【讨论】:

  • 很好的答案,但你忘了做掩蔽。一个简单的剪辑就可以了。
  • 感谢 markE,但我需要彩色徽标图像掩码来圈出并显示流程圈,
  • @hamedfallahi。啊……标志夹在动画楔子内。检查我更新的答案。
猜你喜欢
  • 2013-05-27
  • 2011-05-15
  • 1970-01-01
  • 1970-01-01
  • 2020-03-16
  • 2012-07-28
  • 1970-01-01
  • 2014-03-29
  • 1970-01-01
相关资源
最近更新 更多