Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Images moved by Arcade physics shake as they move #5104

Closed
mwiedmann opened this issue Apr 22, 2020 · 3 comments
Closed

Images moved by Arcade physics shake as they move #5104

mwiedmann opened this issue Apr 22, 2020 · 3 comments

Comments

@mwiedmann
Copy link

VersionPhaser v3.22.0 (WebGL | Web Audio)

  • Operating system: Windows 10 Home 1903
  • Browser: Not browser specific, verified on Firefox and Chrome

Description

Images/sprites moved by Arcade physics (with setVelocity for instance) "shake" as they move. This is very obvious when using a camera follow. Even when not following with a camera though, the image still shakes even though it is a little harder to see because its moving across the screen.

I've seen similar issues reported in the past but this is still definitely an issue. I've tried all of the various anti-alias, and pixel rounding settings with no difference in the results.

I've put together an all in one html file with embedded images and code to demo the issue. You can press "L" to turn Lerping on/off, and press "F" to turn the camera follow on/off. The ball is very shakey as it moves across the field.

Example Test Code

<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/phaser.min.js"></script>
Press "L" to turn Lerp on/off, press "F" to turn camera follow on/off
With Lerp on, the ball shakes a lot but the background is smooth. With Lerp off, the background shakes a lot but the ball is smooth.
With camera follow off, the ball still shakes but isn't as easy to see.
<script> const ballData= ""

const fieldData =""

let testObject
let isFollowing = true
let isLerping = true
let textureCount = 2

function create() {
this.physics.world.setBounds(0, 0, 800, 600)
this.physics.world.setBoundsCollision(true, true, true, true)

this.textures.addBase64('field', fieldData)
this.textures.addBase64('ball', ballData)
	
this.textures.on('onload', () => {
	textureCount--
	// Wait for both textures to be loaded
	if (textureCount == 0) {
		this.add.image(400, 300, 'field')
		
		testObject = this.physics.add.image(200, 200, 'ball')
		testObject.setCollideWorldBounds(true)
		testObject.setBounce(1, 1)
		testObject.setVelocity(200, 250)
		
		this.cameras.main.startFollow(testObject)
		this.cameras.main.setLerp(0.1, 0.1)
			
		let lerpKey = this.input.keyboard.addKey('L');
		lerpKey.on('down', () => { 
			if (isLerping) {
				this.cameras.main.setLerp(1, 1)
			} else {
				this.cameras.main.setLerp(0.1, 0.1)
			}
			isLerping = !isLerping
		})
		
		let followKey = this.input.keyboard.addKey('F');
		followKey.on('down', () => { 
			if (isFollowing) {
				this.cameras.main.stopFollow()
			} else {
				this.cameras.main.startFollow(testObject)
			}
			isFollowing = !isFollowing
		})
	}
})

}

function startGame() {
new Phaser.Game({
type: Phaser.AUTO,
width: 800,
height: 600,
physics: {
default: 'arcade',
},
scene: {
create
},
parent: 'root',
})
}

startGame()
</script>

@jjcapellan
Copy link
Contributor

The physics has its own time step, so sometimes it produce glitches.
Look at this pull request, I think it can help you:
#4989
Demo:
https://codepen.io/jjcapellan/full/KKpKxpG

@samme
Copy link
Contributor

samme commented Apr 22, 2020

I think this is #5018.

@mwiedmann
Copy link
Author

Switching to the Matter physics completely removed this issue for me so I think I'm done with Arcade physics. There are a few other weird things I've experienced with Arcade physics that all go away with Matter as well.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants