繁体   English   中英

连续画一条线

[英]Draw a line animated continously

我想在画布上连续画一条线。 我已经从很多来源读到了。 有一个示例使用svg和jquery绘制它们。

我想做的是像上述示例http://jsfiddle.net/UtmTh/那样,在没有jquery或svg的情况下连续画一条线。 可能吗?

像这样在轨道上画一条线。

function draw_line(param1,.......) {
    var canvas = document.getElementById("myCanvas");
    var ctx = canvas.getContext("2d");
    //just function to draw a lines
}
function line_track() {
      //set X & Y position start
      var x = 0;
      var y = 30;

      //set X & Y position finish
      //in here i want to create a finish position of line after animation run,
      like a jsfiddle example//

}

如果我的计划和设计有误,请帮助我。

就像评论中所说的那样,JQuery库的唯一用途是获取画布元素的第一行。

您可以使用var canvas = document.getElementById("paper");进行更改

另外,如果重复绘图,则不必在每个绘图周期执行clearRectmoveTo

 var canvas = document.getElementById('paper'); var c = canvas.getContext("2d"); var startX = 50; var startY = 50; var endX = 100; var endY = 100; var amount = 0; c.strokeStyle = "black"; c.moveTo(startX, startY); setInterval(function() { amount += 0.05; // change to alter duration if (amount > 1) amount = 1; // lerp : a + (b - a) * f c.lineTo(startX + (endX - startX) * amount, startY + (endY - startY) * amount); c.stroke(); }, 30); 
 <canvas id="paper" width="500" height="500"></canvas> 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM