shithub: qk1

Download patch

ref: 9ce925452bc4b22c27133ea3bc26ad7b191d37e0
parent: f112dfc381355fea03cb81b3c71f04e07760dca4
author: Sigrid Solveig Haflínudóttir <[email protected]>
date: Wed Nov 1 08:00:25 EDT 2023

.alpha: part 7 - fix alpha blending on .mdl

--- a/d_polyse.c
+++ b/d_polyse.c
@@ -86,7 +86,7 @@
 int		skinwidth;
 byte	*skinstart;
 
-void D_PolysetDrawSpans8 (spanpackage_t *pspanpackage);
+void D_PolysetDrawSpans8 (spanpackage_t *pspanpackage, byte alpha);
 void D_PolysetCalcGradients (int skinwidth);
 void D_DrawSubdiv (void);
 void D_DrawNonSubdiv (void);
@@ -561,7 +561,7 @@
 D_PolysetDrawSpans8
 ================
 */
-void D_PolysetDrawSpans8 (spanpackage_t *pspanpackage)
+void D_PolysetDrawSpans8 (spanpackage_t *pspanpackage, byte alpha)
 {
 	int		lcount;
 	byte	*lpdest;
@@ -598,11 +598,18 @@
 
 			do
 			{
-				if ((lzi >> 16) >= *lpz)
-				{
-					*lpdest = ((byte *)acolormap)[*lptex + (llight & 0xFF00)];
-// gel mapping					*lpdest = gelmap[*lpdest];
-					*lpz = lzi >> 16;
+				if ((lzi >> 16) >= *lpz){
+					if(r_drawflags & DRAW_BLEND){
+						*lpdest = blendalpha(
+							((byte *)acolormap)[*lptex + (llight & 0xFF00)],
+							*lpdest,
+							alpha
+						);
+					}else{
+						*lpdest = ((byte *)acolormap)[*lptex + (llight & 0xFF00)];
+	// gel mapping					*lpdest = gelmap[*lpdest];
+						*lpz = lzi >> 16;
+					}
 				}
 				lpdest++;
 				lzi += r_zistepx;
@@ -854,7 +861,7 @@
 	d_countextrastep = ubasestep + 1;
 	originalcount = a_spans[initialrightheight].count;
 	a_spans[initialrightheight].count = Q_MININT; // mark end of the spanpackages
-	D_PolysetDrawSpans8 (a_spans);
+	D_PolysetDrawSpans8 (a_spans, currententity->alpha);
 
 // scan out the bottom part of the right edge, if it exists
 	if (pedgetable->numrightedges == 2)
@@ -878,7 +885,7 @@
 		d_countextrastep = ubasestep + 1;
 		a_spans[initialrightheight + height].count = Q_MININT;
 											// mark end of the spanpackages
-		D_PolysetDrawSpans8 (pstart);
+		D_PolysetDrawSpans8 (pstart, currententity->alpha);
 	}
 }