gpt4 book ai didi

javascript - 在 HTML5 Canvas 上动画绘制路径

转载 作者:行者123 更新时间:2023-11-30 08:21:14 26 4
gpt4 key购买 nike

我的问题是如何为两点之间路径的绘制设置动画。

考虑两点 A 和 B 之间的曲线或路径。我可以使用 Konvajs 中的画线功能在 Canvas 上轻松绘制它。

然而,我真正想要的是为线条的显示设置动画,使其从 A 点开始逐渐绘制到 B 点。显示应该是动画的,这样我就可以应用令人愉悦的缓动。

作为比较示例,请参阅本网站上的简短视频 https://coggle.it/视频中显示了新盒子的创建以及将其连接到旧盒子的线条。

最佳答案

这是一个可能的答案(特别感谢 @markov00 SVG 中的相同技术)。它通过操纵路径 dashOffset 和 dash 属性来工作。对该技术有很好的解释here in a post by Jake Archibald其中还包括一个带有 slider 的交互式实验,我发现它非常有用。

我已尝试使演示尽可能轻便,并仅展示技术 - 尽管我添加了一个 slider 和一些 UI 来帮助理解该过程。 jquery 的使用仅用于该技术不需要的 UI 部分。

几点:

  • 此处的演示使用来自 3 个直线段的路径。但我尝试了曲线和组合路径,并且该技术在这些情况下也适用 - 所以任何路径都应该有效。
  • 我发现在路径上使用闭合路径命令 (z) 会导致路径长度函数在真实距离上变短。这显示为在任一端保持描边或间隙的路径量,其大小取决于第一个和最后一个之间的跳跃以关闭路径。
  • 路径长度实际上总是小数,因此不要尝试将所有内容都设为整数,因为您最终会发现您的笔画略微过长或略短。

要将其用于动画和缓动等,从 slider 更改事件中取出几行并将它们粘贴到框架回调中,根据您的情况处理数学。

// Set up the canvas / stage
var stage = new Konva.Stage({container: 'container1', width: 320, height: 180});

// Add a layer
var layer = new Konva.Layer({draggable: false});
stage.add(layer);

// show where the start of the path is.
var circle = new Konva.Circle({
x: 66,
y: 15,
radius: 5,
stroke: 'red'
})
layer.add(circle);

// draw a path.
var path = new Konva.Path({
x: 0,
y: 0,
data: 'M66 15 L75 100 L225 120 L100 17 L66 15',
stroke: 'green'
});

// get the path length and set this as the dash and dashOffset.
var pathLen = path.getLength();
path.dashOffset(pathLen);
path.dash([pathLen]);

layer.add(path)
stage.draw();

// Some UI bits
$('#dist').attr('max', parseInt(pathLen)); // set slider max to length of path
$('#pathLen').html('Path : ' + pathLen); // display path length

// jquery event listener on slider change
$('#dist').on('input', function(){

// compute the new dash lenth as original path length - current slider value.
// Means that dashLen initially = path len and moves toward zero as slider val increases.
var dashLen = pathLen - $(this).val();;
path.dashOffset(dashLen); // set new value
layer.draw(); // refresh the layer to see effect

// update the UI elements
$('#dashLen').html('Dash: ' + dashLen);
$('#pathPC').html(parseInt(100-(100 * (dashLen/pathLen)), 10) + '%');

})
.info 
{
padding-left: 20px;

}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/konva/2.5.1/konva.js"></script>
<div class="slidecontainer">
<input class='slider' id='dist' type="range" min="0" max="100" value="0" class="slider" id="myRange"/>
<span class='info' id='pathPC'></span>
<span class='info' id='pathLen'></span>
<span class='info' id='dashLen'></span>
</div>
<div id='container1' style="display: inline-block; width: 300px, height: 200px; background-color: silver; overflow: hidden; position: relative;"></div>
<div id='img'></div>

关于javascript - 在 HTML5 Canvas 上动画绘制路径,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53214214/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com