|
|
@ -9,6 +9,7 @@ import java.awt.Color; |
|
|
|
import java.awt.Image; |
|
|
|
import java.awt.Image; |
|
|
|
import java.awt.image.MemoryImageSource; |
|
|
|
import java.awt.image.MemoryImageSource; |
|
|
|
import java.util.ArrayList; |
|
|
|
import java.util.ArrayList; |
|
|
|
|
|
|
|
import java.util.HashMap; |
|
|
|
import java.util.List; |
|
|
|
import java.util.List; |
|
|
|
import java.awt.image.ColorModel; |
|
|
|
import java.awt.image.ColorModel; |
|
|
|
import java.awt.GraphicsEnvironment; |
|
|
|
import java.awt.GraphicsEnvironment; |
|
|
@ -65,6 +66,7 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
thread.start(); |
|
|
|
thread.start(); |
|
|
|
} |
|
|
|
} |
|
|
|
SigRenderer.depthBuffer = new float[width*height]; |
|
|
|
SigRenderer.depthBuffer = new float[width*height]; |
|
|
|
|
|
|
|
SigRenderer.depthBuffer_tri = new Triangle[width*height]; |
|
|
|
} |
|
|
|
} |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Do your draws in here !! |
|
|
|
* Do your draws in here !! |
|
|
@ -84,6 +86,7 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
for (int y=0;y<height;y++) { |
|
|
|
for (int y=0;y<height;y++) { |
|
|
|
p[ (int)(x*SigRenderer.RESOLUTION) + (int)(y*SigRenderer.RESOLUTION) * width] = 0; |
|
|
|
p[ (int)(x*SigRenderer.RESOLUTION) + (int)(y*SigRenderer.RESOLUTION) * width] = 0; |
|
|
|
SigRenderer.depthBuffer[x+y*width]=0; |
|
|
|
SigRenderer.depthBuffer[x+y*width]=0; |
|
|
|
|
|
|
|
SigRenderer.depthBuffer_tri[x+y*width]=null; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -107,6 +110,7 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
Matrix matView = Matrix.QuickInverse(matCamera); |
|
|
|
Matrix matView = Matrix.QuickInverse(matCamera); |
|
|
|
|
|
|
|
|
|
|
|
for (Triangle t : SigRenderer.triRender) { |
|
|
|
for (Triangle t : SigRenderer.triRender) { |
|
|
|
|
|
|
|
if (t.nextRenderTime<=System.currentTimeMillis()) { |
|
|
|
Triangle triProjected = new Triangle(),triTransformed=new Triangle(),triViewed=new Triangle(); |
|
|
|
Triangle triProjected = new Triangle(),triTransformed=new Triangle(),triViewed=new Triangle(); |
|
|
|
|
|
|
|
|
|
|
|
if (t.b!=null) { |
|
|
|
if (t.b!=null) { |
|
|
@ -121,6 +125,7 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
triTransformed.V = t.V; |
|
|
|
triTransformed.V = t.V; |
|
|
|
triTransformed.tex = t.tex; |
|
|
|
triTransformed.tex = t.tex; |
|
|
|
triTransformed.b=t.b; |
|
|
|
triTransformed.b=t.b; |
|
|
|
|
|
|
|
triTransformed.unmodifiedTri=t; |
|
|
|
|
|
|
|
|
|
|
|
Vector normal=new Vector(),line1=new Vector(),line2=new Vector(); |
|
|
|
Vector normal=new Vector(),line1=new Vector(),line2=new Vector(); |
|
|
|
line1 = Vector.subtract(triTransformed.B,triTransformed.A); |
|
|
|
line1 = Vector.subtract(triTransformed.B,triTransformed.A); |
|
|
@ -131,7 +136,11 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
|
|
|
|
|
|
|
|
Vector cameraRay = Vector.subtract(triTransformed.A,SigRenderer.vCamera); |
|
|
|
Vector cameraRay = Vector.subtract(triTransformed.A,SigRenderer.vCamera); |
|
|
|
|
|
|
|
|
|
|
|
if (Vector.dotProduct(normal,cameraRay)<0) { |
|
|
|
float distSquared = ((triTransformed.b.pos.x-SigRenderer.vCamera.x)*(triTransformed.b.pos.x-SigRenderer.vCamera.x)+ |
|
|
|
|
|
|
|
(triTransformed.b.pos.y-SigRenderer.vCamera.y)*(triTransformed.b.pos.y-SigRenderer.vCamera.y)+ |
|
|
|
|
|
|
|
(triTransformed.b.pos.z-SigRenderer.vCamera.z)*(triTransformed.b.pos.z-SigRenderer.vCamera.z)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (Vector.dotProduct(normal,cameraRay)<0&&Vector.dotProduct(cameraRay,SigRenderer.vLookDir)>0.1f&&distSquared<4096) { |
|
|
|
Vector lightDir = Vector.multiply(SigRenderer.vLookDir, -1); |
|
|
|
Vector lightDir = Vector.multiply(SigRenderer.vLookDir, -1); |
|
|
|
lightDir = Vector.normalize(lightDir); |
|
|
|
lightDir = Vector.normalize(lightDir); |
|
|
|
|
|
|
|
|
|
|
@ -176,6 +185,7 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
triProjected.U = (Vector2)clipped[i].U.clone(); |
|
|
|
triProjected.U = (Vector2)clipped[i].U.clone(); |
|
|
|
triProjected.V = (Vector2)clipped[i].V.clone(); |
|
|
|
triProjected.V = (Vector2)clipped[i].V.clone(); |
|
|
|
triProjected.b=clipped[i].b; |
|
|
|
triProjected.b=clipped[i].b; |
|
|
|
|
|
|
|
triProjected.unmodifiedTri=clipped[i].unmodifiedTri; |
|
|
|
|
|
|
|
|
|
|
|
triProjected.T.u = triProjected.T.u/triProjected.A.w; |
|
|
|
triProjected.T.u = triProjected.T.u/triProjected.A.w; |
|
|
|
triProjected.U.u = triProjected.U.u/triProjected.B.w; |
|
|
|
triProjected.U.u = triProjected.U.u/triProjected.B.w; |
|
|
@ -212,6 +222,9 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
|
|
|
|
|
|
|
|
accumulatedTris.add(triProjected); |
|
|
|
accumulatedTris.add(triProjected); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
t.nextRenderTime=System.currentTimeMillis()+200; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
if (SigRenderer.PROFILING) { |
|
|
|
if (SigRenderer.PROFILING) { |
|
|
@ -258,6 +271,7 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
} |
|
|
|
} |
|
|
|
for (Triangle tt : triList) { |
|
|
|
for (Triangle tt : triList) { |
|
|
|
if (tt.tex!=null) { |
|
|
|
if (tt.tex!=null) { |
|
|
|
|
|
|
|
tt.unmodifiedTri.nextRenderTime=System.currentTimeMillis()+200; |
|
|
|
DrawUtils.TexturedTriangle(p, |
|
|
|
DrawUtils.TexturedTriangle(p, |
|
|
|
(int)tt.A.x,(int)tt.A.y,tt.T.u,tt.T.v,tt.T.w, |
|
|
|
(int)tt.A.x,(int)tt.A.y,tt.T.u,tt.T.v,tt.T.w, |
|
|
|
(int)tt.B.x,(int)tt.B.y,tt.U.u,tt.U.v,tt.U.w, |
|
|
|
(int)tt.B.x,(int)tt.B.y,tt.U.u,tt.U.v,tt.U.w, |
|
|
@ -274,6 +288,14 @@ public class Panel extends JPanel implements Runnable { |
|
|
|
totalTime+=System.nanoTime()-startTime2; |
|
|
|
totalTime+=System.nanoTime()-startTime2; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
for (int x=0;x<SigRenderer.SCREEN_WIDTH;x++) { |
|
|
|
|
|
|
|
for (int y=0;y<SigRenderer.SCREEN_HEIGHT;y++) { |
|
|
|
|
|
|
|
Triangle t = SigRenderer.depthBuffer_tri[x+y*SigRenderer.SCREEN_WIDTH]; |
|
|
|
|
|
|
|
if (t!=null) { |
|
|
|
|
|
|
|
t.nextRenderTime=-1; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
SigRenderer.request=null; |
|
|
|
SigRenderer.request=null; |
|
|
|
SigRenderer.answer=SigRenderer.tempAnswer; |
|
|
|
SigRenderer.answer=SigRenderer.tempAnswer; |
|
|
|
if (SigRenderer.PROFILING) { |
|
|
|
if (SigRenderer.PROFILING) { |
|
|
|