2014-11-01 00:28:24 +03:00
|
|
|
|
;
|
|
|
|
|
; We draw a triangle with various interpolations
|
|
|
|
|
;
|
2015-11-20 02:28:22 +03:00
|
|
|
|
; Порядок преобразований цветов вершин:
|
|
|
|
|
; ZBufferPoint.r -> r1 (+drdl_min or +drdl_max) -> or1 (+drdx) -> [pixel buffer]
|
|
|
|
|
; ZBufferPoint.g -> g1 (+dgdl_min or +dgdl_max) -> og1 (+dgdx) -> [pixel buffer]
|
|
|
|
|
; ZBufferPoint.b -> b1 (+dbdl_min or +dbdl_max) -> ob1 (+dbdx) -> [pixel buffer]
|
|
|
|
|
;
|
|
|
|
|
; В некоторых случаях значения цвета (во 2-м байте переменных: or1,og1,ob1)
|
|
|
|
|
; может становиться < 0 или > 255, тогда появляються пиксели не правильного
|
|
|
|
|
; цвета. Скорее всего это связано с ошибками округления дробных чисел,
|
|
|
|
|
; при вычислении коэфициентов для плавного перехода цвета.
|
|
|
|
|
;
|
|
|
|
|
; Для лечения этой проблемы в версии на C++ специально ограничиваються
|
|
|
|
|
; минимальные и максимальные значения цвета точек (например от 3 до 252).
|
|
|
|
|
; Потому цвета граней могут немного отличаться от указанных в программе.
|
|
|
|
|
;
|
|
|
|
|
; В даной версии алгоритм немного другой. В наиболее вероятных местах появления
|
|
|
|
|
; пикселей не правильного цвета (обычно начало и конец линии) иправляеться
|
|
|
|
|
; цвет испорченных пикселей. Цвет получаеться наиболее близким к указанному
|
|
|
|
|
; пользователем.
|
|
|
|
|
|
2014-11-01 00:28:24 +03:00
|
|
|
|
pr1 dd ? ;ZBufferPoint*
|
|
|
|
|
pr2 dd ? ;ZBufferPoint*
|
|
|
|
|
l1 dd ? ;ZBufferPoint*
|
|
|
|
|
l2 dd ? ;ZBufferPoint*
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fdx1 dd ? ;float
|
|
|
|
|
fdx2 dd ? ;float
|
|
|
|
|
fdy1 dd ? ;float
|
|
|
|
|
fdy2 dd ? ;float
|
2016-01-30 23:09:01 +03:00
|
|
|
|
fz dd ? ;float - переменная отвечающая за геометрию фигуры
|
2014-11-07 18:23:03 +03:00
|
|
|
|
d1 dd ? ;float
|
|
|
|
|
d2 dd ? ;float
|
2014-11-01 00:28:24 +03:00
|
|
|
|
pz1 dd ? ;unsigned short*
|
|
|
|
|
pp1 dd ? ;PIXEL*
|
|
|
|
|
part dd ?
|
|
|
|
|
update_left dd ?
|
|
|
|
|
update_right dd ?
|
|
|
|
|
|
2014-11-22 22:14:55 +03:00
|
|
|
|
nb_lines dd ? ;число горизонтальных линий в половине треугольника
|
2014-11-01 00:28:24 +03:00
|
|
|
|
dx1 dd ?
|
|
|
|
|
dy1 dd ?
|
2014-11-22 22:14:55 +03:00
|
|
|
|
;dx2 dd ?
|
2014-11-01 00:28:24 +03:00
|
|
|
|
dy2 dd ?
|
|
|
|
|
|
2014-11-22 22:14:55 +03:00
|
|
|
|
error dd ? ;int
|
|
|
|
|
derror dd ? ;int
|
|
|
|
|
x1 dd ? ;int
|
|
|
|
|
dxdy_min dd ? ;int
|
|
|
|
|
dxdy_max dd ? ;int
|
2014-11-01 00:28:24 +03:00
|
|
|
|
; warning: x2 is multiplied by 2^16
|
2014-11-22 22:14:55 +03:00
|
|
|
|
x2 dd ? ;int
|
|
|
|
|
dx2dy2 dd ? ;int
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
2016-01-28 22:22:54 +03:00
|
|
|
|
z dd ? ;uint
|
2016-01-30 23:09:01 +03:00
|
|
|
|
n dd ? ;int - длинна горизонтальной линии в пикселях
|
|
|
|
|
|
2014-11-01 00:28:24 +03:00
|
|
|
|
if INTERP_Z eq 1
|
2014-11-22 22:14:55 +03:00
|
|
|
|
z1 dd ? ;int
|
|
|
|
|
dzdx dd ? ;int
|
|
|
|
|
dzdy dd ? ;int
|
|
|
|
|
dzdl_min dd ? ;int
|
|
|
|
|
dzdl_max dd ? ;int
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_RGB eq 1
|
|
|
|
|
r1 dd ? ;int
|
|
|
|
|
drdx dd ?
|
|
|
|
|
drdy dd ?
|
|
|
|
|
drdl_min dd ?
|
|
|
|
|
drdl_max dd ?
|
|
|
|
|
g1 dd ?
|
|
|
|
|
dgdx dd ?
|
|
|
|
|
dgdy dd ?
|
|
|
|
|
dgdl_min dd ?
|
|
|
|
|
dgdl_max dd ?
|
|
|
|
|
b1 dd ?
|
|
|
|
|
dbdx dd ?
|
|
|
|
|
dbdy dd ?
|
|
|
|
|
dbdl_min dd ?
|
|
|
|
|
dbdl_max dd ?
|
2016-01-30 23:09:01 +03:00
|
|
|
|
or1 dd ? ;uint
|
|
|
|
|
og1 dd ? ;uint
|
|
|
|
|
ob1 dd ? ;uint
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_ST eq 1
|
2014-11-22 22:14:55 +03:00
|
|
|
|
s1 dd ? ;int
|
|
|
|
|
dsdy dd ? ;int
|
|
|
|
|
dsdl_min dd ? ;int
|
|
|
|
|
dsdl_max dd ? ;int
|
|
|
|
|
t1 dd ? ;int
|
|
|
|
|
dtdy dd ? ;int
|
|
|
|
|
dtdl_min dd ? ;int
|
|
|
|
|
dtdl_max dd ? ;int
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_STZ eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
sz1 dd ? ;float
|
|
|
|
|
dszdx dd ? ;float
|
|
|
|
|
dszdy dd ? ;float
|
|
|
|
|
dszdl_min dd ? ;float
|
|
|
|
|
dszdl_max dd ? ;float
|
|
|
|
|
tz1 dd ? ;float
|
|
|
|
|
dtzdx dd ? ;float
|
|
|
|
|
dtzdy dd ? ;float
|
|
|
|
|
dtzdl_min dd ? ;float
|
|
|
|
|
dtzdl_max dd ? ;float
|
2016-01-28 22:22:54 +03:00
|
|
|
|
s_z dd ? ;float
|
|
|
|
|
t_z dd ? ;float
|
2014-11-07 18:23:03 +03:00
|
|
|
|
end if
|
2016-01-30 23:09:01 +03:00
|
|
|
|
if (INTERP_ST eq 1) | (DRAW_LINE_M eq 1)
|
2014-11-07 18:23:03 +03:00
|
|
|
|
s dd ? ;uint
|
|
|
|
|
t dd ? ;uint
|
2016-01-30 23:09:01 +03:00
|
|
|
|
dsdx dd ? ;int
|
|
|
|
|
dtdx dd ? ;int
|
2014-11-07 18:23:03 +03:00
|
|
|
|
end if
|
2014-11-01 00:28:24 +03:00
|
|
|
|
endl
|
2014-11-22 22:14:55 +03:00
|
|
|
|
pushad
|
|
|
|
|
|
2014-11-07 18:23:03 +03:00
|
|
|
|
; we sort the vertex with increasing y
|
|
|
|
|
mov ebx,[p0]
|
|
|
|
|
mov ecx,[p1]
|
|
|
|
|
mov edx,[p2]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.y]
|
|
|
|
|
cmp [ecx+ZBufferPoint.y],eax ;(2-1)
|
2014-11-22 22:14:55 +03:00
|
|
|
|
jle @f
|
|
|
|
|
xchg edx,ecx
|
2014-11-07 18:23:03 +03:00
|
|
|
|
@@:
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.y]
|
|
|
|
|
cmp [ebx+ZBufferPoint.y],eax ;(1-0)
|
2014-11-22 22:14:55 +03:00
|
|
|
|
jle @f
|
|
|
|
|
xchg ecx,ebx
|
|
|
|
|
@@:
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.y]
|
|
|
|
|
cmp [ecx+ZBufferPoint.y],eax ;(2-1)
|
2014-11-22 22:14:55 +03:00
|
|
|
|
jle @f
|
|
|
|
|
xchg edx,ecx
|
|
|
|
|
@@:
|
|
|
|
|
mov [p0],ebx
|
|
|
|
|
mov [p1],ecx
|
|
|
|
|
mov [p2],edx
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
|
|
|
|
; we compute dXdx and dXdy for all interpolated values
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.x]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.x]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [fdx1],eax ;p1.x - p0.x
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.y]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.y]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [fdy1],eax ;p1.y - p0.y
|
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.x]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.x]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [fdx2],eax ;p2.x - p0.x
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.y]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.y]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [fdy2],eax ;p2.y - p0.y
|
|
|
|
|
|
|
|
|
|
fild dword[fdx1]
|
2016-02-05 14:57:16 +03:00
|
|
|
|
fimul dword[fdy2]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fild dword[fdx2]
|
2016-02-05 14:57:16 +03:00
|
|
|
|
fimul dword[fdy1]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fsubp ;st0 = st1-st0
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fst dword[fz] ;fz = fdx1 * fdy2 - fdx2 * fdy1
|
|
|
|
|
fldz
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fcompp ;if (fz == 0) return
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fstsw ax
|
|
|
|
|
sahf
|
|
|
|
|
je .end_f
|
2014-11-25 02:05:55 +03:00
|
|
|
|
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fld1
|
|
|
|
|
fdiv dword[fz] ;fz = 1.0 / fz
|
|
|
|
|
fst dword[fz] ;st0 = fz
|
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
fild dword[fdx1]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fmul st0,st1
|
|
|
|
|
fstp dword[fdx1] ;fdx1 *= fz
|
2016-02-05 14:57:16 +03:00
|
|
|
|
fild dword[fdy1]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fmul st0,st1
|
|
|
|
|
fstp dword[fdy1] ;fdy1 *= fz
|
2016-02-05 14:57:16 +03:00
|
|
|
|
fild dword[fdx2]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fmul st0,st1
|
|
|
|
|
fstp dword[fdx2] ;fdx2 *= fz
|
2016-02-05 14:57:16 +03:00
|
|
|
|
fild dword[fdy2]
|
|
|
|
|
fmulp
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fstp dword[fdy2] ;fdy2 *= fz
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
|
|
|
|
if INTERP_Z eq 1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.z]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.z]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d1],eax
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.z]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.z]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d2],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fild dword[d1] ;d1 = p1.z - p0.z
|
|
|
|
|
fild dword[d2] ;d2 = p2.z - p0.z
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;dzdx = (int) (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;dzdy = (int) (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 fi, dzdx, dzdy
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
if INTERP_RGB eq 1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.r]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.r]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d1],eax
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.r]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.r]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d2],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fild dword[d1] ;d1 = p1.r - p0.r
|
|
|
|
|
fild dword[d2] ;d2 = p2.r - p0.r
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;drdx = (int) (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;drdy = (int) (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 fi, drdx, drdy
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.g]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.g]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d1],eax
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.g]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.g]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d2],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fild dword[d1] ;d1 = p1.g - p0.g
|
|
|
|
|
fild dword[d2] ;d2 = p2.g - p0.g
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;dgdx = (int) (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;dgdy = (int) (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 fi, dgdx, dgdy
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.b]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.b]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d1],eax
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.b]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.b]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d2],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fild dword[d1] ;d1 = p1.b - p0.b
|
|
|
|
|
fild dword[d2] ;d2 = p2.b - p0.b
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;dbdx = (int) (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;dbdy = (int) (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 fi, dbdx, dbdy
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
if INTERP_ST eq 1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.s]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.s]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d1],eax
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.s]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.s]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d2],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fild dword[d1] ;d1 = p1.s - p0.s
|
|
|
|
|
fild dword[d2] ;d2 = p2.s - p0.s
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;dsdx = (int) (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;dsdy = (int) (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 fi, dsdx, dsdy
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.t]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.t]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d1],eax
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.t]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.t]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [d2],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fild dword[d1] ;d1 = p1.t - p0.t
|
|
|
|
|
fild dword[d2] ;d2 = p2.t - p0.t
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;dtdx = (int) (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;dtdy = (int) (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 fi, dtdx, dtdy
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
if INTERP_STZ eq 1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fild dword[ebx+ZBufferPoint.z]
|
|
|
|
|
fild dword[ebx+ZBufferPoint.s]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fmul st0,st1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fstp dword[ebx+ZBufferPoint.fsz] ;p0.sz = (float) p0.s * p0.z
|
|
|
|
|
fild dword[ebx+ZBufferPoint.t]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fmulp
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fstp dword[ebx+ZBufferPoint.tz] ;p0.tz = (float) p0.t * p0.z
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fild dword[ecx+ZBufferPoint.z]
|
|
|
|
|
fild dword[ecx+ZBufferPoint.s]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fmul st0,st1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fstp dword[ecx+ZBufferPoint.fsz] ;p1.sz = (float) p1.s * p1.z
|
|
|
|
|
fild dword[ecx+ZBufferPoint.t]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fmulp
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fstp dword[ecx+ZBufferPoint.tz] ;p1.tz = (float) p1.t * p1.z
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fild dword[edx+ZBufferPoint.z]
|
|
|
|
|
fild dword[edx+ZBufferPoint.s]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fmul st0,st1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fstp dword[edx+ZBufferPoint.fsz] ;p2.sz = (float) p2.s * p2.z
|
|
|
|
|
fild dword[edx+ZBufferPoint.t]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
fmulp
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fstp dword[edx+ZBufferPoint.tz] ;p2.tz = (float) p2.t * p2.z
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fld dword[ecx+ZBufferPoint.fsz]
|
|
|
|
|
fsub dword[ebx+ZBufferPoint.fsz] ;d1 = p1.sz - p0.sz
|
|
|
|
|
fld dword[edx+ZBufferPoint.fsz]
|
|
|
|
|
fsub dword[ebx+ZBufferPoint.fsz] ;d2 = p2.sz - p0.sz
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;dszdx = (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;dszdy = (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 f, dszdx, dszdy
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
fld dword[ecx+ZBufferPoint.tz]
|
|
|
|
|
fsub dword[ebx+ZBufferPoint.tz] ;d1 = p1.tz - p0.tz
|
|
|
|
|
fld dword[edx+ZBufferPoint.tz]
|
|
|
|
|
fsub dword[ebx+ZBufferPoint.tz] ;d2 = p2.tz - p0.tz
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
2016-02-05 14:57:16 +03:00
|
|
|
|
;dtzdx = (fdy2*d1 - fdy1*d2)
|
|
|
|
|
;dtzdy = (fdx1*d2 - fdx2*d1)
|
|
|
|
|
calc_d1d2 f, dtzdx, dtzdy
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
; screen coordinates
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[zb]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov edx,[eax+ZBuffer.linesize]
|
|
|
|
|
imul edx,[ebx+ZBufferPoint.y]
|
|
|
|
|
add edx,[eax+ZBuffer.pbuf]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [pp1],edx ;pp1 = zb.pbuf + zb.linesize * p0.y
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov edx,[eax+ZBuffer.xsize]
|
|
|
|
|
imul edx,[ebx+ZBufferPoint.y]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
shl edx,1
|
2020-09-19 22:57:00 +03:00
|
|
|
|
add edx,[eax+ZBuffer.zbuf]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [pz1],edx ;pz1 = zb.zbuf + zb.xsize * p0.y
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
|
|
|
|
DRAW_INIT
|
|
|
|
|
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov dword[part],0
|
|
|
|
|
.cycle_0:
|
|
|
|
|
mov ebx,[p0]
|
|
|
|
|
mov ecx,[p1]
|
|
|
|
|
mov edx,[p2]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
cmp dword[part],0 ;if (part == 0)
|
2014-11-07 18:23:03 +03:00
|
|
|
|
jne .els_0
|
|
|
|
|
mov dword[update_left],1
|
|
|
|
|
mov dword[update_right],1
|
|
|
|
|
mov [l1],ebx
|
|
|
|
|
mov [pr1],ebx
|
|
|
|
|
fldz
|
|
|
|
|
fld dword[fz]
|
|
|
|
|
fcompp ;if (fz > 0)
|
|
|
|
|
fstsw ax
|
|
|
|
|
sahf
|
|
|
|
|
jbe .els_1
|
|
|
|
|
mov [l2],edx
|
|
|
|
|
mov [pr2],ecx
|
|
|
|
|
jmp .end_1
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.els_1:
|
|
|
|
|
mov [l2],ecx
|
|
|
|
|
mov [pr2],edx
|
|
|
|
|
.end_1:
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.y]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.y]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [nb_lines],eax ;nb_lines = p1.y - p0.y
|
|
|
|
|
jmp .end_0
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.els_0:
|
|
|
|
|
; second part
|
|
|
|
|
fldz
|
|
|
|
|
fld dword[fz]
|
|
|
|
|
fcompp ;if (fz > 0)
|
|
|
|
|
fstsw ax
|
|
|
|
|
sahf
|
|
|
|
|
jbe .els_2
|
2014-11-22 22:14:55 +03:00
|
|
|
|
mov dword[update_left],0
|
|
|
|
|
mov dword[update_right],1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [pr1],ecx
|
|
|
|
|
mov [pr2],edx
|
|
|
|
|
jmp .end_2
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.els_2:
|
2014-11-22 22:14:55 +03:00
|
|
|
|
mov dword[update_left],1
|
|
|
|
|
mov dword[update_right],0
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [l1],ecx
|
|
|
|
|
mov [l2],edx
|
|
|
|
|
.end_2:
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[edx+ZBufferPoint.y]
|
|
|
|
|
sub eax,[ecx+ZBufferPoint.y]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
inc eax
|
|
|
|
|
mov [nb_lines],eax ;nb_lines = p2.y - p1.y + 1
|
|
|
|
|
.end_0:
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
|
|
|
|
; compute the values for the left edge
|
2014-11-07 18:23:03 +03:00
|
|
|
|
cmp dword[update_left],0 ;if (update_left)
|
|
|
|
|
je .end_upd_l
|
|
|
|
|
mov ebx,[l1]
|
|
|
|
|
mov ecx,[l2]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov edx,[ecx+ZBufferPoint.y]
|
|
|
|
|
sub edx,[ebx+ZBufferPoint.y]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
mov [dy1],edx ;dy1 = l2.y - l1.y
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ecx+ZBufferPoint.x]
|
|
|
|
|
sub eax,[ebx+ZBufferPoint.x]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [dx1],eax ;dx1 = l2.x - l1.x
|
2014-11-22 22:14:55 +03:00
|
|
|
|
cmp edx,0 ;if (dy1 > 0)
|
2014-11-07 18:23:03 +03:00
|
|
|
|
jle .els_3
|
|
|
|
|
xor edx,edx
|
2014-11-22 22:14:55 +03:00
|
|
|
|
cmp eax,0
|
|
|
|
|
jl .otr_dx1
|
|
|
|
|
shl eax,16
|
2014-11-07 18:23:03 +03:00
|
|
|
|
div dword[dy1] ;eax = (dx1 << 16) / dy1
|
|
|
|
|
jmp .end_3
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-22 22:14:55 +03:00
|
|
|
|
.otr_dx1:
|
|
|
|
|
neg eax
|
|
|
|
|
inc eax
|
|
|
|
|
shl eax,16
|
|
|
|
|
div dword[dy1] ;eax = (-dx1 << 16) / dy1
|
|
|
|
|
neg eax
|
|
|
|
|
inc eax
|
|
|
|
|
jmp .end_3
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.els_3:
|
|
|
|
|
xor eax,eax
|
|
|
|
|
.end_3:
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov edx,[ebx+ZBufferPoint.x]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
mov [x1],edx ;x1 = l1.x
|
|
|
|
|
mov dword[error],0 ;error = 0
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov dword[derror],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
and dword[derror],0xffff ;derror = eax & 0x0000ffff
|
2014-12-01 19:52:18 +03:00
|
|
|
|
sar eax,16
|
2014-11-22 22:14:55 +03:00
|
|
|
|
mov [dxdy_min],eax ;dxdy_min = eax >> 16
|
2014-11-07 18:23:03 +03:00
|
|
|
|
inc eax
|
|
|
|
|
mov [dxdy_max],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
|
|
|
|
if INTERP_Z eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[l1]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[eax+ZBufferPoint.z]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [z1],eax ;z1 = l1.z
|
|
|
|
|
mov eax,[dzdx]
|
|
|
|
|
imul eax,[dxdy_min]
|
|
|
|
|
add eax,[dzdy]
|
|
|
|
|
mov [dzdl_min],eax ;dzdl_min = (dzdy +dzdx*dxdy_min)
|
|
|
|
|
add eax,[dzdx]
|
|
|
|
|
mov [dzdl_max],eax ;dzdl_max = dzdl_min +dzdx
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_RGB eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov ebx,[l1]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBufferPoint.r]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [r1],eax ;r1 = l1.r
|
|
|
|
|
mov eax,[drdx]
|
|
|
|
|
imul eax,[dxdy_min]
|
|
|
|
|
add eax,[drdy]
|
|
|
|
|
mov [drdl_min],eax ;drdl_min = (drdy +drdx*dxdy_min)
|
|
|
|
|
add eax,[drdx]
|
|
|
|
|
mov [drdl_max],eax ;drdl_max = drdl_min +drdx
|
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBufferPoint.g]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [g1],eax ;g1 = l1.g
|
|
|
|
|
mov eax,[dgdx]
|
|
|
|
|
imul eax,[dxdy_min]
|
|
|
|
|
add eax,[dgdy]
|
|
|
|
|
mov [dgdl_min],eax ;dgdl_min = (dgdy +dgdx*dxdy_min)
|
|
|
|
|
add eax,[dgdx]
|
|
|
|
|
mov [dgdl_max],eax ;dgdl_max = dgdl_min +dgdx
|
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBufferPoint.b]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [b1],eax ;b1 = l1.b
|
|
|
|
|
mov eax,[dbdx]
|
|
|
|
|
imul eax,[dxdy_min]
|
|
|
|
|
add eax,[dbdy]
|
|
|
|
|
mov [dbdl_min],eax ;dbdl_min = (dbdy +dbdx*dxdy_min)
|
|
|
|
|
add eax,[dbdx]
|
|
|
|
|
mov [dbdl_max],eax ;dbdl_max = dbdl_min +dbdx
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_ST eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov ebx,[l1]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBufferPoint.s]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [s1],eax ;s1 = l1.s
|
|
|
|
|
mov eax,[dsdx]
|
|
|
|
|
imul eax,[dxdy_min]
|
|
|
|
|
add eax,[dsdy]
|
|
|
|
|
mov [dsdl_min],eax ;dsdl_min = (dsdy +dsdx*dxdy_min)
|
|
|
|
|
add eax,[dsdx]
|
|
|
|
|
mov [dsdl_max],eax ;dsdl_max = dsdl_min +dsdx
|
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBufferPoint.t]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [t1],eax ;t1 = l1.t
|
|
|
|
|
mov eax,[dtdx]
|
|
|
|
|
imul eax,[dxdy_min]
|
|
|
|
|
add eax,[dtdy]
|
|
|
|
|
mov [dtdl_min],eax ;dtdl_min = (dtdy +dtdx*dxdy_min)
|
|
|
|
|
add eax,[dtdx]
|
|
|
|
|
mov [dtdl_max],eax ;dtdl_max = dtdl_min +dtdx
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_STZ eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov ebx,[l1]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBufferPoint.fsz]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [sz1],eax ;sz1 = l1.sz - преобразований нет, потому без сопроцессора
|
|
|
|
|
fild dword[dxdy_min]
|
|
|
|
|
fmul dword[dszdx]
|
|
|
|
|
fadd dword[dszdy]
|
|
|
|
|
fst dword[dszdl_min] ;dszdl_min = (dszdy +dszdx*dxdy_min)
|
|
|
|
|
fadd dword[dszdx]
|
|
|
|
|
fstp dword[dszdl_max] ;dszdl_max = dszdl_min +dszdx
|
|
|
|
|
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBufferPoint.tz]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [tz1],eax ;tz1 = l1.tz - преобразований нет, потому без сопроцессора
|
|
|
|
|
fild dword[dxdy_min]
|
|
|
|
|
fmul dword[dtzdx]
|
|
|
|
|
fadd dword[dtzdy]
|
|
|
|
|
fst dword[dtzdl_min] ;dtzdl_min = (dtzdy +dtzdx*dxdy_min)
|
|
|
|
|
fadd dword[dtzdx]
|
|
|
|
|
fstp dword[dtzdl_max] ;dtzdl_max = dtzdl_min +dtzdx
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.end_upd_l:
|
|
|
|
|
|
|
|
|
|
; compute values for the right edge
|
|
|
|
|
|
|
|
|
|
cmp dword[update_right],0 ;if(update_right)
|
|
|
|
|
je .end_upd_r
|
|
|
|
|
mov ebx,[pr1]
|
|
|
|
|
mov ecx,[pr2]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov edx,[ebx+ZBufferPoint.x]
|
|
|
|
|
mov eax,[ecx+ZBufferPoint.x]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
sub eax,edx
|
|
|
|
|
;mov [dx2],eax ;dx2 = pr2.x - pr1.x
|
|
|
|
|
shl edx,16
|
|
|
|
|
mov [x2],edx ; x2 = pr1.x << 16
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov edx,[ecx+ZBufferPoint.y]
|
|
|
|
|
sub edx,[ebx+ZBufferPoint.y]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
mov [dy2],edx ;dy2 = pr2.y - pr1.y
|
|
|
|
|
cmp edx,0 ;if (dy2 > 0)
|
2014-11-07 18:23:03 +03:00
|
|
|
|
jle .els_4
|
|
|
|
|
xor edx,edx
|
2014-11-22 22:14:55 +03:00
|
|
|
|
cmp eax,0
|
|
|
|
|
jl .otr_dx2
|
|
|
|
|
shl eax,16
|
2014-11-07 18:23:03 +03:00
|
|
|
|
div dword[dy2] ;eax = (dx2 << 16) / dy2
|
|
|
|
|
jmp .end_4
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-22 22:14:55 +03:00
|
|
|
|
.otr_dx2:
|
|
|
|
|
neg eax
|
|
|
|
|
inc eax ;dx2 *= -1
|
|
|
|
|
shl eax,16
|
|
|
|
|
div dword[dy2] ;eax = (-dx2 << 16) / dy2
|
|
|
|
|
neg eax
|
|
|
|
|
inc eax
|
|
|
|
|
jmp .end_4
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.els_4:
|
|
|
|
|
xor eax,eax
|
|
|
|
|
.end_4:
|
|
|
|
|
mov [dx2dy2],eax
|
|
|
|
|
.end_upd_r:
|
|
|
|
|
|
|
|
|
|
; we draw all the scan line of the part
|
2014-11-22 22:14:55 +03:00
|
|
|
|
if DEBUG ;[nb_lines]
|
|
|
|
|
push ecx edi
|
|
|
|
|
mov eax,[nb_lines]
|
|
|
|
|
mov ecx,80
|
|
|
|
|
lea edi,[buf_param]
|
|
|
|
|
stdcall convert_int_to_str,ecx
|
|
|
|
|
|
|
|
|
|
stdcall str_n_cat,edi,txt_nl,2
|
|
|
|
|
stdcall dbg_print,f_fill_tr_nl,buf_param
|
|
|
|
|
pop edi ecx
|
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
|
|
|
|
.beg_w_lin:
|
|
|
|
|
cmp dword[nb_lines],0 ;while (nb_lines>0)
|
|
|
|
|
jle .end_w_lin
|
|
|
|
|
dec dword[nb_lines]
|
|
|
|
|
if DRAW_LINE_M eq 1
|
2016-01-30 23:09:01 +03:00
|
|
|
|
DRAW_LINE
|
2014-11-07 18:23:03 +03:00
|
|
|
|
else
|
|
|
|
|
; generic draw line
|
|
|
|
|
mov eax,[x2]
|
2014-12-01 19:52:18 +03:00
|
|
|
|
sar eax,16
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov edi,[x1]
|
|
|
|
|
sub eax,edi
|
|
|
|
|
mov [n],eax ;n = (x2 >> 16) - x1
|
|
|
|
|
imul edi,PSZB
|
|
|
|
|
add edi,[pp1] ;pp = pp1 + x1 * PSZB
|
2014-11-22 22:14:55 +03:00
|
|
|
|
|
2014-11-01 00:28:24 +03:00
|
|
|
|
if INTERP_Z eq 1
|
2016-02-02 02:20:41 +03:00
|
|
|
|
mov esi,[x1]
|
|
|
|
|
shl esi,1
|
|
|
|
|
add esi,[pz1]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[z1]
|
|
|
|
|
mov [z],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_RGB eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[r1]
|
2015-11-20 02:28:22 +03:00
|
|
|
|
bt eax,31 ; коректирование испорченных пикселей (в начале линии)
|
|
|
|
|
jnc @f
|
|
|
|
|
xor eax,eax
|
|
|
|
|
@@:
|
|
|
|
|
bt eax,16
|
|
|
|
|
jnc @f
|
|
|
|
|
mov eax,0xff00
|
|
|
|
|
@@:
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [or1],eax
|
|
|
|
|
mov eax,[g1]
|
2015-11-20 02:28:22 +03:00
|
|
|
|
bt eax,31
|
|
|
|
|
jnc @f
|
|
|
|
|
xor eax,eax
|
|
|
|
|
@@:
|
|
|
|
|
bt eax,16
|
|
|
|
|
jnc @f
|
|
|
|
|
mov eax,0xff00
|
|
|
|
|
@@:
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [og1],eax
|
|
|
|
|
mov eax,[b1]
|
2015-11-20 02:28:22 +03:00
|
|
|
|
bt eax,31
|
|
|
|
|
jnc @f
|
|
|
|
|
xor eax,eax
|
|
|
|
|
@@:
|
|
|
|
|
bt eax,16
|
|
|
|
|
jnc @f
|
|
|
|
|
mov eax,0xff00
|
|
|
|
|
@@:
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov [ob1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_ST eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[s1]
|
|
|
|
|
mov [s],eax
|
|
|
|
|
mov eax,[t1]
|
|
|
|
|
mov [t],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_STZ eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[sz1]
|
|
|
|
|
mov [s_z],eax
|
|
|
|
|
mov eax,[tz1]
|
|
|
|
|
mov [t_z],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
2014-11-22 22:14:55 +03:00
|
|
|
|
|
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.cycle_1: ;while (n>=3)
|
2015-11-20 02:28:22 +03:00
|
|
|
|
if INTERP_RGB eq 1
|
|
|
|
|
cmp dword[n],5
|
|
|
|
|
jl .cycle_2
|
|
|
|
|
else
|
2014-11-22 22:14:55 +03:00
|
|
|
|
cmp dword[n],3
|
|
|
|
|
jl .cycle_2
|
2015-11-20 02:28:22 +03:00
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
PUT_PIXEL 0
|
|
|
|
|
PUT_PIXEL 1
|
|
|
|
|
PUT_PIXEL 2
|
|
|
|
|
PUT_PIXEL 3
|
2014-11-01 00:28:24 +03:00
|
|
|
|
if INTERP_Z eq 1
|
2016-02-02 02:20:41 +03:00
|
|
|
|
add esi,8 ;=4*sizeof(uint)
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
add edi,4*PSZB
|
|
|
|
|
sub dword[n],4
|
2014-11-22 22:14:55 +03:00
|
|
|
|
jmp .cycle_1
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.cycle_2: ;while (n>=0)
|
2015-12-01 15:51:32 +03:00
|
|
|
|
cmp dword[n],0
|
|
|
|
|
jl .cycle_2_end
|
2015-11-20 02:28:22 +03:00
|
|
|
|
if INTERP_RGB eq 1
|
|
|
|
|
; коректирование испорченных пикселей (в конце линии)
|
|
|
|
|
bt dword[or1],31
|
|
|
|
|
jnc @f
|
|
|
|
|
mov dword[or1],0
|
|
|
|
|
jmp .end_r
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2015-11-20 02:28:22 +03:00
|
|
|
|
@@:
|
|
|
|
|
bt dword[or1],16
|
|
|
|
|
jnc .end_r
|
|
|
|
|
mov dword[or1],0xff00
|
|
|
|
|
.end_r:
|
|
|
|
|
bt dword[og1],31
|
|
|
|
|
jnc @f
|
|
|
|
|
mov dword[og1],0
|
|
|
|
|
jmp .end_g
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2015-11-20 02:28:22 +03:00
|
|
|
|
@@:
|
|
|
|
|
bt dword[og1],16
|
|
|
|
|
jnc .end_g
|
|
|
|
|
mov dword[og1],0xff00
|
|
|
|
|
.end_g:
|
|
|
|
|
bt dword[ob1],31
|
|
|
|
|
jnc @f
|
|
|
|
|
mov dword[ob1],0
|
|
|
|
|
jmp .end_b
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2015-11-20 02:28:22 +03:00
|
|
|
|
@@:
|
|
|
|
|
bt dword[ob1],16
|
|
|
|
|
jnc .end_b
|
|
|
|
|
mov dword[ob1],0xff00
|
|
|
|
|
.end_b:
|
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
PUT_PIXEL 0
|
2014-11-01 00:28:24 +03:00
|
|
|
|
if INTERP_Z eq 1
|
2016-02-02 02:20:41 +03:00
|
|
|
|
add esi,2 ;=sizeof(uint)
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
add edi,PSZB
|
|
|
|
|
dec dword[n]
|
2014-11-22 22:14:55 +03:00
|
|
|
|
jmp .cycle_2
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-22 22:14:55 +03:00
|
|
|
|
.cycle_2_end:
|
|
|
|
|
end if ;проверка от макроса DRAW_LINE
|
2014-11-07 18:23:03 +03:00
|
|
|
|
|
|
|
|
|
; left edge
|
|
|
|
|
mov eax,[derror]
|
|
|
|
|
add [error],eax
|
2014-11-22 22:14:55 +03:00
|
|
|
|
cmp dword[error],0 ;if (error > 0)
|
2014-11-07 18:23:03 +03:00
|
|
|
|
jle .els_er
|
|
|
|
|
sub dword[error],0x10000
|
|
|
|
|
mov eax,[dxdy_max]
|
|
|
|
|
add [x1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
if INTERP_Z eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[dzdl_max]
|
|
|
|
|
add [z1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_RGB eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[drdl_max]
|
|
|
|
|
add [r1],eax
|
|
|
|
|
mov eax,[dgdl_max]
|
|
|
|
|
add [g1],eax
|
|
|
|
|
mov eax,[dbdl_max]
|
|
|
|
|
add [b1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_ST eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[dsdl_max]
|
|
|
|
|
add [s1],eax
|
|
|
|
|
mov eax,[dtdl_max]
|
|
|
|
|
add [t1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_STZ eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fld dword[dszdl_max]
|
|
|
|
|
fadd dword[sz1]
|
|
|
|
|
fstp dword[sz1]
|
|
|
|
|
fld dword[dtzdl_max]
|
|
|
|
|
fadd dword[tz1]
|
|
|
|
|
fstp dword[tz1]
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
jmp .end_er
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.els_er:
|
|
|
|
|
mov eax,[dxdy_min]
|
|
|
|
|
add [x1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
if INTERP_Z eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[dzdl_min]
|
|
|
|
|
add [z1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_RGB eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[drdl_min]
|
|
|
|
|
add [r1],eax
|
|
|
|
|
mov eax,[dgdl_min]
|
|
|
|
|
add [g1],eax
|
|
|
|
|
mov eax,[dbdl_min]
|
|
|
|
|
add [b1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_ST eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
mov eax,[dsdl_min]
|
|
|
|
|
add [s1],eax
|
|
|
|
|
mov eax,[dtdl_min]
|
|
|
|
|
add [t1],eax
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
|
|
|
|
if INTERP_STZ eq 1
|
2014-11-07 18:23:03 +03:00
|
|
|
|
fld dword[dszdl_min]
|
|
|
|
|
fadd dword[sz1]
|
|
|
|
|
fstp dword[sz1]
|
|
|
|
|
fld dword[dtzdl_min]
|
|
|
|
|
fadd dword[tz1]
|
|
|
|
|
fstp dword[tz1]
|
2014-11-01 00:28:24 +03:00
|
|
|
|
end if
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.end_er:
|
|
|
|
|
; right edge
|
|
|
|
|
mov eax,[dx2dy2]
|
|
|
|
|
add [x2],eax
|
|
|
|
|
|
|
|
|
|
; screen coordinates
|
|
|
|
|
mov ebx,[zb]
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBuffer.linesize]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
add [pp1],eax
|
2020-09-19 22:57:00 +03:00
|
|
|
|
mov eax,[ebx+ZBuffer.xsize]
|
2014-11-07 18:23:03 +03:00
|
|
|
|
shl eax,1
|
|
|
|
|
add [pz1],eax
|
|
|
|
|
jmp .beg_w_lin
|
2016-02-05 14:57:16 +03:00
|
|
|
|
align 4
|
2014-11-07 18:23:03 +03:00
|
|
|
|
.end_w_lin:
|
|
|
|
|
inc dword[part]
|
|
|
|
|
cmp dword[part],2
|
|
|
|
|
jl .cycle_0
|
|
|
|
|
.end_f:
|
2014-11-22 22:14:55 +03:00
|
|
|
|
popad
|
2014-11-07 18:23:03 +03:00
|
|
|
|
ret
|
|
|
|
|
endp
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
|
|
|
|
restore INTERP_Z
|
|
|
|
|
restore INTERP_RGB
|
|
|
|
|
restore INTERP_ST
|
|
|
|
|
restore INTERP_STZ
|
2014-11-07 18:23:03 +03:00
|
|
|
|
restore DRAW_LINE_M
|
2014-11-01 00:28:24 +03:00
|
|
|
|
|
|
|
|
|
purge DRAW_INIT
|
2014-11-07 18:23:03 +03:00
|
|
|
|
purge DRAW_LINE
|
2014-11-01 00:28:24 +03:00
|
|
|
|
purge PUT_PIXEL
|