Advertisement
nzisaacnz

3D Heightmap Test

Apr 16th, 2013
129
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. <html>
  2. <head>
  3. <style>
  4. #cvs
  5. {
  6.     border:1px solid;
  7. }
  8. </style>
  9. <script>
  10. function Point (x,y,z)
  11. {
  12.     this.x = x;
  13.     this.y = y;
  14.     this.z = z;
  15. }
  16. function Sprite(mesh,rot)
  17. {
  18.     this.mesh = mesh;
  19.     this.rot = rot;
  20. }
  21. function Camera(pos,rot)
  22. {
  23.     this.pos = pos;
  24.     this.rot = rot;
  25. }
  26. function Rotate(point,rot)
  27. {
  28.     var ox=0,oy=1,oz=2;
  29.     var s=[Math.sin(rot.x),Math.sin(rot.y),Math.sin(rot.z)];
  30.     var c=[Math.cos(rot.x),Math.cos(rot.y),Math.cos(rot.z)];
  31.     var x = point.x;
  32.     var y = point.y;
  33.     var z = point.z;
  34.     var dx = c[oy]*(s[oz]*y+c[oz]*x)-s[oy]*z;
  35.     var dy = s[ox]*(c[oy]*z+s[oy]*(s[oz]*y+c[oz]*x))+c[ox]*(c[oz]*y-s[oz]*x);
  36.     var dz = c[ox]*(c[oy]*z+s[oy]*(s[oz]*y+c[oz]*x))-s[ox]*(c[oz]*y-s[oz]*x);
  37.     return new Point(dx,dy,dz);
  38. }
  39. function Project(sprite,cam,Dim,perp)
  40. {
  41.     var ox=0,oy=1,oz=2;
  42.     var s=[Math.sin(cam.rot.x),Math.sin(cam.rot.y),Math.sin(cam.rot.z)];
  43.     var c=[Math.cos(cam.rot.x),Math.cos(cam.rot.y),Math.cos(cam.rot.z)];
  44.     var cx=cam.pos.x
  45.     var cy=cam.pos.y
  46.     var cz=cam.pos.z
  47.     var P = [];
  48.     for(var i=0; i<sprite.mesh.length; i++)
  49.     {
  50.         var point = Rotate(sprite.mesh[i],sprite.rot);
  51.         var x = point.x-cx;
  52.         var y = point.y-cy;
  53.         var z = point.z-cz;
  54.         var dx = c[oy]*(s[oz]*y+c[oz]*x)-s[oy]*z;
  55.         var dy = s[ox]*(c[oy]*z+s[oy]*(s[oz]*y+c[oz]*x))+c[ox]*(c[oz]*y-s[oz]*x);
  56.         var dz = c[ox]*(c[oy]*z+s[oy]*(s[oz]*y+c[oz]*x))-s[ox]*(c[oz]*y-s[oz]*x);
  57.         P[i] = new Point(perp/dz*dx+Dim.width/2,perp/dz*dy+Dim.height/2);
  58.     }
  59.     return P;
  60. }
  61.  
  62.  
  63. var sprite = new Sprite([],new Point(
  64. Math.sin(0*180/Math.PI),
  65. Math.sin(0*180/Math.PI),
  66. Math.sin(0*180/Math.PI)));
  67. var camera = new Camera(new Point(0,0,1000),new Point(0,0,0));
  68. var perspective = 1000;
  69. var cvs,G,Dim,active;
  70. var img = new Image();
  71. function loadMesh()
  72. {
  73.     G.drawImage(img,0,0);
  74.     var imgData = G.getImageData(0,0,img.width,img.height);
  75.     for(var i=2; i<imgData.width; i+=2)
  76.     {
  77.         for(var j=2; j<imgData.height; j+=2)
  78.         {
  79.             sprite.mesh[sprite.mesh.length] = new Point(i*3-200,200-j*3,(255-imgData.data[(i+imgData.width*j)*4+1])/3);
  80.             sprite.mesh[sprite.mesh.length] = new Point((i-2)*3-200,200-j*3,(255-imgData.data[((i-2)+imgData.width*j)*4+1])/3);
  81.             sprite.mesh[sprite.mesh.length] = new Point((i-2)*3-200,200-(j-2)*3,(255-imgData.data[((i-2)+imgData.width*(j-2))*4+1])/3);
  82.             sprite.mesh[sprite.mesh.length] = new Point(i*3-200,200-(j-2)*3,(255-imgData.data[(i+imgData.width*(j-2))*4+1])/3);
  83.         }
  84.     }
  85.     webkitRequestAnimationFrame(draw);
  86. }
  87.  
  88. function init()
  89. {
  90.     cvs = document.getElementById("cvs");
  91.     G = cvs.getContext("2d");
  92.     Dim = {width:cvs.width,height:cvs.height};
  93.     img.addEventListener("load",loadMesh,false);
  94.     img.src="";
  95. }
  96. function draw()
  97. {
  98.     sprite.rot.x+=0.001;
  99.     sprite.rot.y+=0.002;
  100.     sprite.rot.z+=0.003;
  101.     G.clearRect(0,0,Dim.width,Dim.height);
  102.     var points = Project(sprite,camera,Dim,perspective);
  103.     G.beginPath();
  104.     for(var i=0; i<points.length; i++)
  105.     {
  106.         G.lineTo(points[i].x,points[i].y);
  107.     }
  108.     G.stroke();
  109.     if(active)webkitRequestAnimationFrame(draw);
  110. }
  111. function activate(CB)
  112. {
  113.     active = CB.checked;
  114.     if(active)webkitRequestAnimationFrame(draw);
  115. }
  116. function mouse(e)
  117. {
  118.     sprite.rot.y=e.offsetX/100;
  119.     sprite.rot.x=e.offsetY/100;
  120.     webkitRequestAnimationFrame(draw);
  121. }
  122. </script>
  123. </head>
  124. <body>
  125. <canvas width="800" height="800" id="cvs" onmousemove="mouse(event)"></canvas><br>
  126. <script>
  127. init();
  128. </script>
  129. <input type="checkbox" onclick="activate(this)" />Rotate
  130. </body>
  131. </html>
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement