shithub: 3dee

Download patch

ref: 4e60c43745f430182eb44b40e69d8a9dac4b44e1
parent: 3c16d2adc58ea335203c24d34b58b2f51bf55da6
author: rodri <[email protected]>
date: Sat Sep 14 07:09:26 EDT 2024

vis: add an MMB option to show the z-buffer.

--- a/vis.c
+++ b/vis.c
@@ -92,7 +92,7 @@
 static int doprof;
 static int inception;
 static int showhud;
-static int shownormals;
+static char *curraster;
 static int blendon;
 static int depthon;
 static int abuffon;
@@ -612,7 +612,7 @@
 		if(Δt > HZ2MS(60)*1000000ULL){
 			lockdisplay(display);
 			draw(screenb, screenb->r, clr, nil, ZP);
-			maincam->view->draw(maincam->view, screenb, shownormals? "normals": nil);
+			maincam->view->draw(maincam->view, screenb, curraster);
 			unlockdisplay(display);
 			nbsend(drawc, nil);
 			t0 += Δt;
@@ -705,6 +705,7 @@
 		TSBILINEAR,
 		SP1,
 		SHOWNORMALS,
+		SHOWZBUFFER,
 		SP2,
 		SETCLRCOL,
 		SP3,
@@ -723,6 +724,7 @@
 	 [TSBILINEAR]	"use bilinear sampler",
 			"",
 	 [SHOWNORMALS]	"show normals",
+	 [SHOWZBUFFER]	"show z-buffer",
 			"",
 	 [SETCLRCOL]	"set clear color",
 			"",
@@ -760,7 +762,10 @@
 		tsampler = bilitexsampler;
 		break;
 	case SHOWNORMALS:
-		shownormals ^= 1;
+		curraster = curraster && strcmp(curraster, "normals") == 0? nil: "normals";
+		break;
+	case SHOWZBUFFER:
+		curraster = curraster && strcmp(curraster, "z-buffer") == 0? nil: "z-buffer";
 		break;
 	case SETCLRCOL:
 		if(unloadimage(clr, UR, (uchar*)&clrcol, 4) != 4)