2016-12-30 69 views
4

Follow image to mouse with rotation on Javascript後續圖像鼠標上的Javascript

旋轉如何讓聖誕老人跟着鼠標旋轉和自己的速度,而不是鼠標速度?

現在鼠標在哪裏 - 它的目的地,在哪裏與自己的速度去聖誕老人。

聖誕老人隨速度旋轉。

我該怎麼做?

Demo code

game.js

var canvas, ctx, player 

function init() { 
    canvas = document.getElementById("canvas") 
    ctx = canvas.getContext("2d") 
    resizeCanvas() 

    player = new Player( 
    ctx, 
    canvas.width/2, 
    canvas.height/2 + 100 
) 

    window.onresize = resizeCanvas 
    canvas.onmousemove = mousemove 
} 

function mousemove(e) { 
    player.x = e.clientX * devicePixelRatio 
    player.y = e.clientY * devicePixelRatio 
} 

function render() { 
    ctx.clearRect(0, 0, canvas.width, canvas.height) 
    player.draw() 
} 

function step() { 
    render() 
    requestAnimationFrame(step) 
} 

init() 
step() 

回答

3

這不是與旋轉簡單的任務。

修改版與一些魔術:demo

對於distance用勾股定理。

玩家前進(通過當前旋轉)。

class Player { 
    constructor(ctx, x, y) { 
     this.x = x 
     this.y = y 

     this.dest = { 
     x: 0, 
     y: 0 
     } 

     this.width = 200 
     this.height = 200 
     this.velocity = 12 
     this.angularVelocity = 7 
     this.rotation = 0 

     this.ctx = ctx 

     this.image = new Image() 
     this.image.src = "//habrastorage.org/files/447/9b4/6d3/4479b46d397e439a9613ce122a66a506.png" 
    } 

    draw() { 
     this.ctx.translate(this.x, this.y) 
     this.ctx.rotate(this.rotation + 4.7) 
     this.ctx.drawImage(
     this.image, 
     -this.width/2, -this.height/2, 
     this.width, this.height 
    ) 
     this.ctx.rotate(-this.rotation - 4.7) 
     this.ctx.translate(-this.x, -this.y) 
    } 

    distance(target) { 
     let data = { 
     x: target.x - this.x, 
     y: target.y - this.y 
     } 
     data.len = Math.sqrt(data.x * data.x + data.y * data.y) 
     return data 
    } 

    rotate(dt) { 
     let path = this.distance(this.dest) 
     let target = Math.atan2(path.y, path.x) 

     let delta = this.rotation - target 
     if (delta > 0.1 || delta < -0.1) { 

     var _delta = delta 
     if (_delta < 0) { 
      _delta += Math.PI * 2 
     } 

     if (delta < -Math.PI || (delta > 0 && delta < Math.PI)) { 
      this.rotation -= _delta/this.angularVelocity 
     } else { 
      this.rotation -= (_delta - Math.PI * 2)/this.angularVelocity 
     } 

     // Reduce character rotation into the -PI thru PI range 
     this.rotation = (this.rotation + 3 * Math.PI) % (2 * Math.PI) - Math.PI 
     } 
    } 

    step() { 
     let distance = this.distance(this.dest).len 
     if (distance < this.width/1.5) { 
     this.draw() 
     return 
     } 

     let vel = distance/15 

     if (vel > this.velocity) { 
     vel = this.velocity 
     } 

     this.rotate() 

     this.x += vel * Math.cos(this.rotation) 
     this.y += vel * Math.sin(this.rotation) 

     this.draw() 
    } 

    }