我正在研究图形编辑器。我需要突出显示一个圆圈,并在屏幕中心使该圆圈并将缩放比例设置为2。如果该圆圈已被高亮显示,则对其进行设置以将其切换并设置为普通圆圈。我至少需要在关闭圆圈之前先使圆圈闪烁。
我看不到如何使圆圈闪烁。有人知道“ two.js”该怎么做。我知道它在函数two.update();
中 // Render loop
var temps = 0;
two.bind('update', function(){
if (selectedNodes.length > 0){
if (temps > 0) {
temps -= 0.02;
for(var i = 0; i < selectedNodes.length; i++){
selectedNodes[i].circle.fill = 'yellow';
selectedNodes[i].circle.scale = 1.3;
selectedNodes[i].circle.stroke = "red";
selectedNodes[i].circle.linewidth = 2;
}
} else {
for(var i = 0; i < selectedNodes.length; i++){
selectedNodes[i].circle.fill = '#FF8000';
selectedNodes[i].circle.scale = 1;
selectedNodes[i].circle.noStroke();
}
}
}
});
并触发眨眼
function Blink(){
temps = 1;
}
这是闪烁一次的最佳方法(即使它仅闪烁一次)
这是一个JsFiddle https://jsfiddle.net/hichem147/uf0b82ry/
要使用它:单击[(+)节点],然后创建一些节点,然后单击[选择]并单击一个圆,然后单击[闪烁]按钮。
答案 0 :(得分:0)
最后,我使用了setTimeout和setInterval
function MakeCircleBlink(){
var count = 5;
if (count > 0) {
var x = setInterval(function(){
count--;
console.log(count);
if (count ===0) {clearInterval(x);}
blink();
}, 1000);
}
}
function blink(n){
n--;
circle1.stroke = 'red';
circle1.linewidth = 4;
circle1.scale = 1.0;
setTimeout(function(){ circle1.noStroke(); circle1.scale = 1;}, 500);
}
这是一个显示其工作原理的codepen:https://codepen.io/hichem147/pen/jvjKzP?editors=0010