Skip to content

Instantly share code, notes, and snippets.

@edankwan
Created April 6, 2014 06:42
Show Gist options
  • Star 6 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save edankwan/10002304 to your computer and use it in GitHub Desktop.
Save edankwan/10002304 to your computer and use it in GitHub Desktop.
2d snoise Javascript post
// port from GLSL code base on https://github.com/ashima/webgl-noise/blob/master/src/noise2D.glsl
//JS SNOISE PORT
function snoise2d(x, y) {
var C0 = 0.211324865405187;
var C1 = -0.577350269189626;
var C2 = 1.79284291400159;
var OVER_289 = 1 / 289;
var tmp = (x + y) * 0.366025403784439;
var i_0 = Math.floor(x + tmp);
var a0_0 = Math.floor(y + tmp);
tmp = (i_0 + a0_0) * C0;
var x0_0 = x - i_0 + tmp;
var x0_1 = y - a0_0 + tmp;
var t_0 = x0_0 > x0_1 ? 1 : 0;
var t_1 = 1 - t_0;
var x12_0 = x0_0 + C0 - t_0;
var x12_1 = x0_1 + C0 - t_1;
var x12_2 = x0_0 + C1;
var x12_3 = x0_1 + C1;
i_0 -= Math.floor(i_0 * OVER_289) * 289;
a0_0 -= Math.floor(a0_0 * OVER_289) * 289;
tmp = 0;
C0 =0.024390243902439;
C1 = 0.85373472095314;
var m = .5 - x12_0 * x12_0 - x12_1 * x12_1;
if(m > 0) {
var a0_1 = a0_0 + t_1;
a0_1 *= (a0_1 * 34) + 1;
a0_1 = (a0_1 - Math.floor(a0_1 * OVER_289) * 289) + i_0 + t_0;
a0_1 *= (a0_1 * 34) + 1;
a0_1 = (a0_1 - Math.floor(a0_1 * OVER_289) * 289) * C0;
a0_1 = (a0_1 - Math.floor(a0_1)) * 2 - 1;
var h_1 = Math.abs(a0_1) - 0.5;
a0_1 = a0_1 - Math.floor(a0_1 + 0.5);
tmp += (m * m * m * m) * (C2 - C1 * (a0_1 * a0_1 + h_1 * h_1)) * (a0_1 * x12_0 + h_1 * x12_1);
}
m = .5 - x12_2 * x12_2 - x12_3 * x12_3;
if(m > 0) {
var a0_2 = a0_0 + 1;
a0_2 *= (a0_2 * 34) + 1;
a0_2 = (a0_2 - Math.floor(a0_2 * OVER_289) * 289) + i_0 + 1;
a0_2 *= (a0_2 * 34) + 1;
a0_2 = (a0_2 - Math.floor(a0_2 * OVER_289) * 289) * C0;
a0_2 = (a0_2 - Math.floor(a0_2)) * 2 - 1;
var h_2 = Math.abs(a0_2) - 0.5;
a0_2 = a0_2 - Math.floor(a0_2 + 0.5);
tmp += (m * m * m * m) * (C2 - C1 * (a0_2 * a0_2 + h_2 * h_2)) * (a0_2 * x12_2 + h_2 * x12_3);
}
m = .5 - x0_0 * x0_0 - x0_1 * x0_1;
if(m > 0) {
a0_0 *= (a0_0 * 34) + 1;
a0_0 = (a0_0 - Math.floor(a0_0 * OVER_289) * 289) + i_0;
a0_0 *= (a0_0 * 34) + 1;
a0_0 = (a0_0 - Math.floor(a0_0 * OVER_289) * 289) * C0;
a0_0 = (a0_0 - Math.floor(a0_0)) * 2 - 1;
var h_0 = Math.abs(a0_0) - 0.5;
a0_0 = a0_0 - Math.floor(a0_0 + 0.5);
tmp += (m * m * m * m) * (C2 - C1 * (a0_0 * a0_0 + h_0 * h_0)) * (a0_0 * x0_0 + h_0 * x0_1);
}
return tmp * 130;
}
@Bald-mans
Copy link

”i remember“,i am a beginner in chian。I like this website very much。Unfortunately, when I learned about your site, it was down。 I want to make a website similar to it。this is my little dream。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment