Skip to content

Instantly share code, notes, and snippets.

@mrweb-site
Created November 16, 2020 18:58
Show Gist options
  • Save mrweb-site/c95348ef02130aecf48746fd0db48306 to your computer and use it in GitHub Desktop.
Save mrweb-site/c95348ef02130aecf48746fd0db48306 to your computer and use it in GitHub Desktop.
1d noise
<!-- Motocross image base64 -->
<template></template>
var c = document.createElement('canvas')
var ctx = c.getContext('2d')
document.body.appendChild(Object.assign(c, {width:innerWidth, height:innerWidth *0.5}));
var rect = [0,0,c.width,c.height];
var perm = [];
while(perm.length < 255){
while(perm.includes(val = Math.floor(Math.random() * 255)));
perm.push(val)
}
var noise = (x)=> {
x = x%254;
return lerp(perm[Math.floor(x)], perm[Math.ceil(x)], x-Math.floor(x))};
var lerp = (a,b,t) => a + (b-a) * ((1-Math.cos(t*Math.PI))/2);
var Moto = function(x, w){
this.x = x || c.width/2;
this.w = w || 0.1;
this.y = 0;
this.yS = 0;
this.rot = 0;
this.image = new Image();
this.image.src = document.querySelector("template").innerHTML;
this.draw = function(){
var pp = c.height - noise(t + (this.x*0.01))*0.25;
ctx.fillStyle = 'red';
var grounded = 0.5;
if(this.y < pp-10){
this.yS += this.w;
}else{
this.yS -= this.y - (pp-10);
this.y = pp-10;
grounded = 1;
}
this.y += this.yS;
ctx.save()
ctx.translate(this.x,this.y)
this.rot -= (this.rot - (this.yS * this.w * grounded)) * (0.025 - (-0.5 * grounded))
ctx.rotate(this.rot)
ctx.drawImage(this.image,-10, -10, 23,23)
ctx.restore();
}
}
var players = [new Moto(), new Moto(c.width*0.25, 0.15), new Moto(c.width*0.15, 0.075), new Moto(c.width*0.4,0.085), new Moto(c.width*0.65, 0.2)];
var t = 0;
loop();
function loop (){
t+= .05
ctx.fillStyle = '#19f'
ctx.fillRect(...rect);
ctx.beginPath();
ctx.moveTo(0,c.height);
for (let i = 0; i < c.width; i++)
ctx.lineTo(i, c.height - noise(t + (i*0.01))*0.25);
ctx.lineTo(c.width,c.height);
ctx.fillStyle = '#345'
ctx.fill();
players.forEach(p => p.draw());
requestAnimationFrame(loop)
}
body{
margin:0;
background-color:#345;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment