如何使地面与轮子的转动同步?
How to synchronize the ground with the rotation of the wheel?
我想使地面与轮子的旋转同步(随着轮子的旋转将地面拉下)。车轮具有动态直径。
在我的示例中,如果我按向右箭头,地面应该继续向左移动,但事实并非如此。
const wheel=$('#wheel')
const plane=$('#plane')
let degree=0
let interval
$(document).on('mousedown','span',event=>{
let planeX=plane.offset().left
interval=setInterval(()=>{
if(event.currentTarget.id==='left')degree-=1
else degree+=1
wheel.css('transform', 'rotate(' + degree + 'deg)')
const radians=degree * (Math.PI / 180)
const cos = Math.cos(radians)
planeX+=cos
plane.css('left',planeX+'px')
},10)
})
$(document).on('mouseup','span',event=>clearInterval(interval))
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div style="position:fixed;top:0; font-size:200%;"><span style="cursor:pointer;" id="left"><</span> <span style="cursor:pointer;" id="right">></span></div>
<div id="wheelContainer" style="position:fixed;bottom:1em;left:50%;transform:translateX(-50%);"><div id="wheel" style="width:150px;height:150px;border:1px solid;border-radius:50%;background:url('')"></div></div>
<div id="plane" style="position:fixed;bottom:0;left:-1000vw;right:-1000vw;height:1em;border:1px solid;background:url('')"></div>
总弧长等于总角度(以弧度为单位)乘以半径。由于地面在 车轮下方,因此您需要相反的符号。所以而不是
planeX+=cos
bettwer 写
planeX = planeX0 - radians * radius
在您的场景中半径为 75px。
const wheel=$('#wheel')
const plane=$('#plane')
const radius=75
const planeX0=plane.offset().left
let degree=0
let interval
$(document).on('mousedown','span',event=>{
interval=setInterval(()=>{
if(event.currentTarget.id==='left')degree-=1
else degree+=1
wheel.css('transform', 'rotate(' + degree + 'deg)')
const radians=degree * (Math.PI / 180)
planeX = planeX0 - radians * radius
plane.css('left',planeX+'px')
},10)
})
$(document).on('mouseup','span',event=>clearInterval(interval))
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div style="position:fixed;top:0; font-size:200%;"><span style="cursor:pointer;" id="left"><</span> <span style="cursor:pointer;" id="right">></span></div>
<div id="wheelContainer" style="position:fixed;bottom:1em;left:50%;transform:translateX(-50%);"><div id="wheel" style="width:150px;height:150px;border:1px solid;border-radius:50%;background:url('')"></div></div>
<div id="plane" style="position:fixed;bottom:0;left:-1000vw;right:-1000vw;height:1em;border:1px solid;background:url('')"></div>
如果你按住箭头的时间足够长,你会看到地面以正弦函数移动,无论按住左箭头还是右箭头。
问题出在这段代码中:
const radians=degree * (Math.PI / 180)
const cos = Math.cos(radians)
planeX+=cos
degree
是一个累加值,其中planeX +=
只需要一个值的阶跃变化。
解决方法:
如果度数为 +=1 弧度,则平面 X 应仅 +=1,或 += 1 * 圆半径。
我想使地面与轮子的旋转同步(随着轮子的旋转将地面拉下)。车轮具有动态直径。
在我的示例中,如果我按向右箭头,地面应该继续向左移动,但事实并非如此。
const wheel=$('#wheel')
const plane=$('#plane')
let degree=0
let interval
$(document).on('mousedown','span',event=>{
let planeX=plane.offset().left
interval=setInterval(()=>{
if(event.currentTarget.id==='left')degree-=1
else degree+=1
wheel.css('transform', 'rotate(' + degree + 'deg)')
const radians=degree * (Math.PI / 180)
const cos = Math.cos(radians)
planeX+=cos
plane.css('left',planeX+'px')
},10)
})
$(document).on('mouseup','span',event=>clearInterval(interval))
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div style="position:fixed;top:0; font-size:200%;"><span style="cursor:pointer;" id="left"><</span> <span style="cursor:pointer;" id="right">></span></div>
<div id="wheelContainer" style="position:fixed;bottom:1em;left:50%;transform:translateX(-50%);"><div id="wheel" style="width:150px;height:150px;border:1px solid;border-radius:50%;background:url('')"></div></div>
<div id="plane" style="position:fixed;bottom:0;left:-1000vw;right:-1000vw;height:1em;border:1px solid;background:url('')"></div>
总弧长等于总角度(以弧度为单位)乘以半径。由于地面在 车轮下方,因此您需要相反的符号。所以而不是
planeX+=cos
bettwer 写
planeX = planeX0 - radians * radius
在您的场景中半径为 75px。
const wheel=$('#wheel')
const plane=$('#plane')
const radius=75
const planeX0=plane.offset().left
let degree=0
let interval
$(document).on('mousedown','span',event=>{
interval=setInterval(()=>{
if(event.currentTarget.id==='left')degree-=1
else degree+=1
wheel.css('transform', 'rotate(' + degree + 'deg)')
const radians=degree * (Math.PI / 180)
planeX = planeX0 - radians * radius
plane.css('left',planeX+'px')
},10)
})
$(document).on('mouseup','span',event=>clearInterval(interval))
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div style="position:fixed;top:0; font-size:200%;"><span style="cursor:pointer;" id="left"><</span> <span style="cursor:pointer;" id="right">></span></div>
<div id="wheelContainer" style="position:fixed;bottom:1em;left:50%;transform:translateX(-50%);"><div id="wheel" style="width:150px;height:150px;border:1px solid;border-radius:50%;background:url('')"></div></div>
<div id="plane" style="position:fixed;bottom:0;left:-1000vw;right:-1000vw;height:1em;border:1px solid;background:url('')"></div>
如果你按住箭头的时间足够长,你会看到地面以正弦函数移动,无论按住左箭头还是右箭头。
问题出在这段代码中:
const radians=degree * (Math.PI / 180)
const cos = Math.cos(radians)
planeX+=cos
degree
是一个累加值,其中planeX +=
只需要一个值的阶跃变化。
解决方法: 如果度数为 +=1 弧度,则平面 X 应仅 +=1,或 += 1 * 圆半径。