- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两条成 90 度 Angular 的线,我想通过旋转垂直线使 Angular 在 90 度和 0 度之间变小和变大。我试图通过更改 moveTo
参数来做到这一点,我可以增加值但不能减少它们。你也能帮我确保移动的线与动画期间的水平线长度相同。现在它看起来像完成后变小然后变大。
window.onload = function(){
var canvas =document.getElementById("canvas");
var context = canvas.getContext("2d");
var length = 50;
var x = 50;
var y= 50;
var forward = true;
(function animate(){
if(x <= 201 && y <= 201){
x++
y++
}
if(x > 195){
forward = false;
}
// console.log(x, y)
if(forward == false){
// alert("yo")
x = x - 1
y = y -1
}
console.log(x)
console.log(forward)
context.clearRect(0,0, canvas.width, canvas.height)
context.beginPath();
context.moveTo(x,y)
context.lineTo(50,200);
context.stroke();
context.closePath();
window.requestAnimationFrame(animate)
context.beginPath();
context.moveTo(50, 200);
context.lineTo(200, 200)
context.stroke();
context.closePath();
}())
}
<canvas id="canvas" width="400" height="400"></canvas>
编辑:::
window.onload = function(){
var canvas =document.getElementById("canvas");
var context = canvas.getContext("2d");
var length = 50;
var x = 50;
var y= 50;
var dlt = 1
var forward = true;
var i = 0;
(function animate(){
if(x >= 50 && x < 200 ){
i++
x += dlt
y += dlt
console.log(i)
$(".display").html(i)
if(i >= 150){
X = 200;
Y = 200;
x -= dlt
y -= dlt
}
}
console.log("x", x)
console.log(forward)
context.clearRect(0,0, canvas.width, canvas.height)
context.beginPath();
context.moveTo(x,y)
context.lineTo(50,200);
context.stroke();
context.closePath();
window.requestAnimationFrame(animate)
context.beginPath();
context.moveTo(50, 200);
context.lineTo(200, 200)
context.stroke();
context.closePath();
}())
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<canvas id="canvas" width="400" height="400"></canvas>
最佳答案
您可以使用变换而不是三 Angular 函数来绘制垂直折叠线:
这是带注释的代码和演示:
var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var cw=canvas.width;
var ch=canvas.height;
var nextTime=0;
var delay=100;
var angle=-Math.PI/2;
var cx=150;
var cy=150;
var radius=50;
requestAnimationFrame(animate);
function animate(time){
// wait until the desired time elapses
if(time<nextTime){requestAnimationFrame(animate); return;}
nextTime+=delay;
// draw the horizontal line
ctx.clearRect(0,0,cw,ch);
ctx.beginPath();
ctx.moveTo(cx,cy);
ctx.lineTo(cx+radius,cy);
ctx.stroke();
// use transformations to draw the vertical line
// at the desired angle
ctx.translate(cx,cy);
ctx.rotate(angle);
ctx.beginPath();
ctx.moveTo(0,0);
ctx.lineTo(radius,0);
ctx.stroke();
ctx.setTransform(1,0,0,1,0,0);
// if the vertical line isn't horizontal,
// request another animation frame
if(angle<0){ requestAnimationFrame(animate); }
// adjust the angle
angle+=Math.PI/90;
}
body{ background-color: ivory; }
#canvas{border:1px solid red; margin:0 auto; }
<canvas id="canvas" width=300 height=300></canvas>
如果你想使用 Trig,那么你可以像这样计算线端点:
var lineX1 = lineX0 + radius*Math.cos(angle);
var lineY1 = lineY1 + radius*Math.sin(angle);
[添加:在提问者的代码中添加三 Angular 函数]
您的代码已重构为使用三 Angular 函数重新定位垂直线。
var canvas =document.getElementById("canvas");
var context = canvas.getContext("2d");
var length = 50;
var x = 50;
var y= 50;
var dlt = 1
var forward = true;
var i = 0;
var angle=-Math.PI/2;
var direction=1;
(function animate(){
/*
if(x >= 50 && x < 200 ){
i++
x += dlt
y += dlt
console.log(i)
$(".display").html(i)
if(i >= 150){
X = 200;
Y = 200;
x -= dlt
y -= dlt
}
}
*/
var moveX=50+(200-50)*Math.cos(angle);
var moveY=200+(200-50)*Math.sin(angle);
// change the angle
angle+=(Math.PI/120*direction);
// if the angle is beyond vertical or horizontal then
// swing it the other way
if(angle<-Math.PI/2 || angle>0){ direction*=-1;}
context.clearRect(0,0, canvas.width, canvas.height)
context.beginPath();
context.moveTo(moveX,moveY)
context.lineTo(50,200);
context.stroke();
// context.closePath();
context.beginPath();
context.moveTo(50, 200);
context.lineTo(200, 200)
context.stroke();
// context.closePath();
window.requestAnimationFrame(animate)
}())
<canvas id="canvas" width=300 height=300></canvas>
关于javascript - context.moveTo() x 和 y 参数不使用 requestAnimationFrame 递减,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34326461/
我想逐步动画化两个十进制数之间的差异。 已找到Joss Crowcroft's solution对于效果很好的整数,我做了 example on jsfiddle .代码片段: $({numberVa
我试图弄清楚如何使用 ffmpeg drawtext 函数,该函数在视频上打印叠加层,视频文件结束时还有时间。 使用 %{pts\:hms} 从开始 (00:00:00) 开始似乎没问题从视频文件的开
本周我开始学习 Java 线程和并发;我需要一些关于我使用 Thread 而不是 Runnable 实现的下一个代码的帮助: 类别 package hilos; public class Hilo e
我有一个对象列表(发票)。这些对象有一个 qty 属性。我有一个产品返回表格,其中包含要退回的产品的数量。 提交返回行时。我用提交的行填充一个 gridview,以便在提交整个返回表格之前可以根据需要
这个问题已经有答案了: Can you have a triple minus signs in C programming? What does it mean? [duplicate] (5 个回
var a = 0; (++a)+(a++)+(++a); print(a); 这会打印 3。我假设它只执行单个增量。 var a = 0; (++a)+(a++)+(--a); 这会打印 1. 这里
我知道 C 中的计算顺序并不严格,所以表达式 --a+++a 的值是未定义的,因为不知道语句的哪一部分先运行。 但是,如果我知道在特定情况下计算顺序无关紧要怎么办?例如: 所有修改对应不同的变量(如a
if (getchar == '+') { answer = getnum1+getnum2; // if the random operation is add, it will add
我会尽量用代码来解释这个问题: double power = 5000; //picked up 5 power ups, now need to increase power by 10% per
这个问题在这里已经有了答案: Loop backwards using indices (17 个回答) 关闭5年前. 我想要一个像这样的 for 循环: for counter in range(1
像这样: decr(X, X) :- X is X-1. 我想用它来递减父规则中的数字,如果这个数字等于 0,例如,父规则返回 false。 最佳答案 Prolog 是声明性的:声明性语言的一
我正在制作一个包含三张图片的 slider 。对于此幻灯片的后退按钮,它应该从最后一张图像开始并返回到 1。下面的代码在控制台记录时从 3 减少到 2 但未命中 1,所以 3 2 3 2 3 2 ..
这实际上是我关于 javascript 的第一篇文章。想知道以下代码的性能,因为它是一个“递减 while 循环”,在 while 循环中有一个递增变量。 var i = data.d.length;
将 pg_trgm.word_similarity_threshold 设置为 0.2;降低当前 session 的阈值但不为数据库做。我需要降低支持拼写错误的阈值。 最佳答案 赞the docume
我希望能够增加和减少一个值(5),并且我想用一个函数来覆盖它(我知道如何用两个函数来实现)。不幸的是,我无法完成它,也无法找出问题所在。 这是我的代码: HTML: -
我有一堆 enum 类型,像这样: enum Color {COLOR_RED = 0, COLOR_GREEN = 1, COLOR_BLUE = 2, COLOR_NUM}; enum Direc
在我的机器上递减一个 NULL 指针仍然得到一个 NULL 指针,我想知道这是否定义明确。 char *p = NULL; --p; 最佳答案 是的,行为未定义。 --p 等同于 p = p - 1(
简而言之,我正在将地形(2d 高度图)从生成的值平滑回到其原始值。 有一个仅使用生成值的 6 单位平坦区域,然后是一个从生成值移回原始值的 3 单位平滑区域(总共 9 个) 在平坦区域中,所有 x、z
给定一个数组,其中的值要么只增加,要么只减少或先增加再减少,如何找到此类数组的最大值和最小值? 最小值只是最终值中的最小值。 但是如何找到最大值呢? 一种方法是运行时间为 O(n) 的线性方法,是否可
假设您有一个递归方法,并且您在递归调用中递增/递减一个值。为什么这会导致堆栈溢出异常,而预自增/自减不会? 例如 numberCount(currentNumber++); //Stack overf
我是一名优秀的程序员,十分优秀!