;MOS3DE V 0.1 - MENUETOS 3D Engine V 0.1 ; Compile with FASM for MENUET ; this is a very early Version: I'm so happy that it runs at all. ; Of course it's a bad ASM style and it can be optimized a lot. ; anyway - I have thought I uploap this so other PPL might optimize it ; as well or transform it to something completely diffrent. ; There are some Mouse- and Keyboardhandling Subs and Constructs. They are here ; because I will probably use them for the Navigation in a First Person ; Perspective Game - which is the goal of this project. ; http://www.melog.ch/mos_pub/ dietermarfurt@angelfire.com ; of course you can remove or replace them. It has only linear Texturemapping. ; Perspective Correction is a future option. ; a flag for multiple Textures selection should be implemented in the ; Meshfile Format. As I said - it's a very erarly version. use32 org 0x0 db 'MENUET01' ; 8 byte id dd 0x01 ; header version dd START ; start of code dd I_END ; size of image dd 0x200000 ; memory for app dd 0x7fff0 ; esp dd 0x0 , 0x0 ; I_Param , I_Icon IMAGE_W = 320 IMAGE_H = 240 START: ; start of execution call init_gfx call draw_window ; at first, draw the window gamestart: ; ******* MOUSE CHECK ******* mov eax,37 mov ebx,1 ; check mouseposition int 0x40 mov ebx,eax shr eax,16 and eax,0x0000FFFF ; mousex and ebx,0x0000FFFF ; mousey mov [mousex],eax mov [mousey],ebx cmp eax,5 ; mouse out of window ? jb check_refresh ; it will prevent an app-crash cmp ebx,22 jb check_refresh cmp eax, IMAGE_W jg check_refresh cmp ebx,221 jg check_refresh cmp eax,160 ; navigating? jb m_left cmp eax,170 ; jg m_right continue: cmp ebx,100 ; jb s_up cmp ebx,144 ; jg s_down ; ******* END OF MOUSE CHECK ******* check_refresh: mov eax,23 ; wait for system event with 10 ms timeout mov ebx,1 ; wait 10 ms, then continue int 0x40 ; mov eax,11 ; or use this for full speed instead ; int 0x40 cmp eax,1 ; window redraw request ? je red2 cmp eax,2 ; key in buffer ? je key2 cmp eax,3 ; button in buffer ? je button2 call clear_screen call updateworld call put_screen ;call log ; used for debugging mov edi,[mouseya] ; check flag if a refresh has to be done cmp edi,1 jne gamestart mov [mouseya],dword 0 jmp gamestart ; END OF MAINLOOP red2: ; redraw call draw_window ; call draw_stuff jmp gamestart key2: ; key mov eax,2 int 0x40 cmp al,1 je gamestart ; keybuffer empty cmp ah,27 ; esc=End App je finish cmp ah,178 ; up je s_up cmp ah,177 ; down je s_down cmp ah,176 ; left je s_left cmp ah,179 ; right je s_right jmp gamestart ; was any other key s_up: ; walk forward (key or mouse) mov eax,[vpx] mov ebx,[vpy] mov ecx,[vheading] imul ecx,4 add ecx,sinus mov edi,[ecx] mov edx,[vheading] imul edx,4 add edx,sinus add edx,3600 cmp edx,eosinus ;cosinus taken from (sinus plus 900) mod 3600 jb ok200 sub edx,14400 ok200: mov esi,[edx] ; sal esi,1 ; edit walking speed here ; sal edi,1 add eax,edi ; newPx add ebx,esi ; newPy mov edi,eax ; newPx / ffff mov esi,ebx ; newPy / ffff sar edi,16 sar esi,16 mov ecx,esi sal ecx,5 ; equal *32 add ecx,edi add ecx,grid cmp [ecx],byte 0 ; collision check jne cannotwalk0 mov [vpx],eax mov [vpy],ebx mov [mouseya],dword 1 ; set refresh flag cannotwalk0: jmp check_refresh s_down: ; walk backward mov eax,[vpx] mov ebx,[vpy] mov ecx,[vheading] imul ecx,4 add ecx,sinus mov edi,[ecx] mov edx,[vheading] imul edx,4 add edx,sinus add edx,3600 cmp edx,eosinus ;cosinus taken from (sinus plus 900) mod 3600 jb ok201 sub edx,14400 ok201: mov esi,[edx] ; sal esi,1 ; edit walking speed here ; sal edi,1 sub eax,edi ; newPx sub ebx,esi ; newPy mov edi,eax ; newPx / ffff mov esi,ebx ; newPy / ffff sar edi,16 sar esi,16 mov ecx,esi sal ecx,5 add ecx,edi add ecx,grid cmp [ecx],byte 0 jne cannotwalk1 mov [vpx],eax mov [vpy],ebx mov [mouseya],dword 1 cannotwalk1: jmp check_refresh s_left: ; turn left (key) mov edi,[vheading] ; heading add edi,50 cmp edi,1800 jb ok_heading0 sub edi,1800 ok_heading0: mov [vheading],edi mov [mouseya],dword 1 jmp check_refresh s_right: ; turn right mov edi,[vheading] sub edi,50 cmp edi,-1 jg ok_heading1 add edi,1800 ok_heading1: mov [vheading],edi mov [mouseya],dword 1 jmp check_refresh m_left: ; turn left (mouse) mov edi,[vheading] ; heading mov ecx,160 sub ecx,eax sar ecx,2 add edi,ecx cmp edi,1800 jb ok_heading2 sub edi,1800 ok_heading2: mov [vheading],edi mov [mouseya],dword 1 jmp continue ; allow both: walk and rotate m_right: ; turn right mov edi,[vheading] sub eax,170 sar eax,2 sub edi,eax cmp edi,-1 jg ok_heading3 add edi,1800 ok_heading3: mov [vheading],edi mov [mouseya],dword 1 jmp continue button2: ; button mov eax,17 ; get id int 0x40 cmp ah,1 ; button id=1 ? jne gamestart ; eo GAME mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm finish: mov eax,-1 ; close this program int 0x40 ; ********************************************* ; ******* WINDOW DEFINITIONS AND DRAW ******** ; ********************************************* draw_window: mov eax,12 ; function 12:tell os about windowdraw mov ebx,1 ; 1, start of draw; 2 - end int 0x40 mov eax, 48 ; get skin height mov ebx, 4 int 0x40 lea ecx,[eax + (119 shl 16) + IMAGE_H + 4] mov ebx,192*65536+IMAGE_W+9 ; [x start] *65536 + [x size] mov edx,0x74000000 ; skinned window, not resizable mov edi,labelt ; window title mov eax,0 ; function 0 : define and draw window int 0x40 mov eax,12 mov ebx,2 int 0x40 ret ; --------------------------------------------------------------------- init_gfx: ; Pwidth = 63 Shl 16 ;original texture width in pixels -1 shl 16 ; Pheight = 63 Shl 16 ;original texture height in pixels -1 shl 16 mov [pwidth],dword 63 shl dword[pwidth],16 mov [pheight],dword 63 shl dword[pheight],16 ;; Read in a mesh mov eax,0 ; tex1+4 mov edi,anz add edi,4 ; beginning of mesh data ;using a copy will allow inverse kinematic transformations (future option) readmesh: mov edx,eax add edx,a_xwww ; desti mov ecx,[edi] ; value in ecx mov [edx],ecx add edi,4 ;--- mov edx,eax add edx,a_ywww ; desti mov ecx,[edi] ; value in ecx mov [edx],ecx add edi,4 ;--- mov edx,eax add edx,a_zwww ; desti mov ecx,[edi] ; value in ecx mov [edx],ecx add edi,4 ;--- add eax,4 cmp edi,eo_mesh jl readmesh ; zoom=-500 mov [zoom],dword -500 ret ;------------------------------------------------------------------ log: ;write some Variable info to screen (used for debugging) pusha mov edi,wonder ;a_xwww ;add edi,200 mov [remecx], dword 24 print: mov eax,47 mov ebx,0x000f0000 ;mov ebx,0x000f0100 ; hex mov ecx,[edi] mov edx,[remecx] or edx,0x000C0000 mov esi,0x00ff0000 int 0x40 add [remecx],dword 8 add edi,dword 4 cmp [remecx], dword 250 jl print popa ret ; --------------------------------------------------------------------- ; UPDATE WORLD ; --------------------------------------------------------------------- updateworld: mov edx,[a_xw] ; Miny% = 32767 ; Maxy% = 0 mov [miny],dword 32737 mov [maxy],dword 0 ; Color 0,0,0 ; clear screen - l8er ; Rect 0,0,320,240,1 ; a=a+1.0 ; automatic rotation... add [a],dword 10 cmp [a],dword 3598 jl ok360 mov [a],dword 0 ok360: ; If a>359.9 Then a=0 ; alpha=a ; beta=a ; gamma=a+a Mod 360 mov eax,[a] mov [alpha],eax mov [beta], eax mov [gamma],eax add [gamma],eax cmp [gamma],dword 3599 jl ok360_2 sub [gamma],dword 3600 ok360_2: ; mausy#=0.1+(MouseY()/50.0) ; >>>>>>l8er mov eax,[alpha] mov [alphacopy],eax mov eax,[beta] mov [betacopy],eax mov eax,[gamma] mov [gammacopy],eax ; For i=0 To anz ; do rotation and projection etc mov esi,0 for_i: ; ***************************** ; ROTATE pitch jaw roll... ; ***************************** ;; xl1#=zwww(i)*Sin(gamma)+xwww(i)*Cos(gamma) mov eax,esi imul eax,4 add eax,a_zwww mov ebx,[eax] mov eax,[gammacopy] call get_sinus imul ebx,[eax] mov [tempdiv],ebx ; is zwww(i)*sin(gamma) mov eax,esi imul eax,4 add eax,a_xwww mov ebx,[eax] mov eax,[gammacopy] call get_cosinus imul ebx,[eax] ; is xwww*cos(gamma add ebx,[tempdiv] mov eax,ebx ;or eax,1 cdq mov ecx,6553 idiv ecx mov [xl1],eax ;; yl1#=ywww(i) mov eax,esi imul eax,4 add eax,a_ywww mov ebx,[eax] mov [yl1],ebx ;; zl1#=zwww(i)*Cos(gamma)-xwww(i)*Sin(gamma) mov eax,esi imul eax,4 add eax,a_zwww mov ebx,[eax] mov eax,[gammacopy] call get_cosinus imul ebx,[eax] mov [tempdiv],ebx ; is zwww(i)*cos(gamma) mov eax,esi imul eax,4 add eax,a_xwww mov ebx,[eax] mov eax,[gammacopy] call get_sinus imul ebx,[eax] ; is xwww*sin(gamma sub [tempdiv],ebx mov eax,[tempdiv] ;or eax,1 cdq mov ecx,6553 ; once 6500 idiv ecx mov [zl1],eax ; ;----------------------------------------------------------------------- ;; xl2#=xl1 mov eax,[xl1] mov [xl2],eax ;; yl2#=yl1*Cos(beta)-zl1*Sin(beta) mov ebx,[yl1] mov eax,[betacopy] call get_cosinus imul ebx,[eax] mov [tempdiv],ebx ; is yl1*cos(beta) mov ebx,[zl1] ; zl1 mov eax,[betacopy] call get_sinus imul ebx,[eax] ; is zl1*sin(beta sub [tempdiv],ebx mov eax,[tempdiv] ;or eax,1 cdq mov ecx,6553 idiv ecx mov [yl2],eax ;; zl2#=yl1*Sin(beta)+zl1*Cos(beta) mov ebx,[yl1] mov eax,[betacopy] call get_sinus imul ebx,[eax] mov [tempdiv],ebx ; is yl1*sin(beta) mov ebx,[zl1] ; zl1 mov eax,[betacopy] call get_cosinus imul ebx,[eax] ; is zl1*cos(beta add ebx,[tempdiv] mov eax,ebx ;or eax,1 cdq mov ecx,6553 idiv ecx mov [zl2],eax ;----------------------------------------------------------------------- ;; xl3#=(yl2*Sin(alpha)+xl2*Cos(alpha)) mov ebx,[yl2] mov eax,[alphacopy] call get_sinus imul ebx,[eax] mov [tempdiv],ebx ; is yl2*sin(alpha) mov ebx,[xl2] ; xl2 mov eax,[alphacopy] call get_cosinus imul ebx,[eax] ; is xl2*cos(alpha add ebx,[tempdiv] mov eax,ebx ;or eax,1 cdq mov ecx,6553 idiv ecx mov [xl3],eax ;; yl3#=(yl2*Cos(alpha)-xl2*Sin(alpha)) mov ebx,[yl2] mov eax,[alphacopy] call get_cosinus imul ebx,[eax] mov [tempdiv],ebx ; is yl2*cos(alpha) mov ebx,[xl2] ; xl2 mov eax,[alphacopy] call get_sinus imul ebx,[eax] ; is xl2*sin(alpha sub [tempdiv],ebx mov eax,[tempdiv] ;or eax,1 cdq mov ecx,6553 idiv ecx mov [yl3],eax ;; zl3#=(zl2) mov eax,[zl2] mov [zl3],eax ;----------------------------------------------------------------------- ; ********************* ; PROJECTING 3D to 2D ; If yloc# - Zoom <> 0 Then yloc = Int(yl3 ) * 200 / (zl3 - Zoom) ;------- mov ecx,[zl3] sub ecx,[zoom] mov eax,[yl3] imul eax,200 or eax,1 cdq idiv ecx ;mov eax,[yl3] ; no perpective mov [yloc],eax ;------ ; If xloc# - Zoom <> 0 Then xloc = Int(xl3 ) * 200 / (zl3 - Zoom) ;------ mov ecx,[zl3] sub ecx,[zoom] mov eax,[xl3] imul eax,200 or eax,1 cdq idiv ecx ;mov eax,[xl3] ; no perspective mov [xloc],eax ;------ ; xw(i)=((mausy#)*xloc) +160 ; yw(i)=((mausy#)*yloc) +120 ; zw(i)=(zl3+256) mov eax,[mousey] ; define scaling mov [factor],eax cmp eax,32000 jl positivemousey mov [factor],dword 10 jmp less220 positivemousey: cmp eax,10 jg more20 mov [factor],dword 10 jmp less220 more20: cmp eax,220 jl less220 mov [factor],dword 220 less220: mov eax,esi ; i... imul eax,4 mov ecx,[xloc] mov eax,esi imul eax,4 mov ebx,a_xw add ebx,eax imul ecx,[factor] sar ecx,5 mov [ebx],ecx add [ebx],dword 160 mov ecx,[yloc] ; mov eax,esi ; imul eax,4 mov ebx,a_yw add ebx,eax imul ecx,[factor] sar ecx,5 mov [ebx],ecx add [ebx],dword 120 mov ecx,[zl3] ; used for z sorting mov ebx,a_zw add ebx,eax mov [ebx],ecx add [ebx],dword 256 ; Next inc esi cmp esi,[anz] jle for_i ;--------------- mov [sorted_quads],dword 0 ; ; z-sorting... ; For i=0 To 10000 ; clear old info ; zbuffer(i)=-1 ; Next mov eax,zbuffer mov ebx,eax add ebx,40000 clear_zbuffer: mov [eax],dword 1000000 add eax,4 cmp eax,ebx jle clear_zbuffer ; For i=0 To anz-3 Step 4 mov eax,0 mov ebx,[anz] for_i_0_to_anz: ; If zw(i)>=0 ; clip Quads behind Camera mov ecx,eax imul ecx,4 add ecx,a_zw mov edx,[ecx] cmp edx,0 jle behindcamera ; zwmax=zw(i) mov esi,edx ; ;find quads internal most far point ; If zwmax<zw(i+1) Then zwmax=zw(i+1) ; If zwmax<zw(i+2) Then zwmax=zw(i+2) ; If zwmax<zw(i+3) Then zwmax=zw(i+3) ; skip this for debugging ; jmp no_internal_sorting cmp esi,[ecx+4] jge checkmore1 mov esi,[ecx+4] checkmore1: cmp esi,[ecx+8] jge checkmore2 mov esi,[ecx+8] checkmore2: cmp esi,[ecx+12] jge checkmore3 mov esi,[ecx+12] checkmore3: no_internal_sorting: mov [i],eax ; anz-ID in [i] (not times 4) push eax push ebx ; While zbuffer(zwmax)<>-1 And zwmax<10000 ; zwmax=zwmax+1 ; Wend mov eax,esi ; is actual z/poititon of point (used for z-order) imul eax,4 findslot: mov ebx,eax add ebx,zbuffer cmp [ebx],dword 1000000 je found_empty_slot add eax,4 cmp eax,40000 jl findslot found_empty_slot: ; zbuffer(zwmax)=i inc dword[sorted_quads] ; check slot writing mov ecx,[i] mov [ebx],ecx pop ebx pop eax ; EndIf behindcamera: ; Next add eax,4 cmp eax,[anz] ;ebx jl for_i_0_to_anz ;---------------- ;mov [rendered_quads],dword 0 ; debugging... ; For i2=10000 To 0 Step -1 ; reading quads in z-order from far to near mov eax,40000 mov ebx,0 for_i_0_to_10000: ; i=zbuffer(i2) mov edx,eax add edx,zbuffer mov ecx,[edx] ; i... ; If i>-1 And i< anz-2 ; if it isn't -1 then it's a Quad Point 1 ID cmp ecx,1000000 je is_empty_slot ;inc dword[rendered_quads] ; used for debugging ; ;***Mapping*** ; ;GetPolygonPoints(i) ; ;FindSmallLargeY() mov [ilocal],ecx call get_polygon_points call find_small_large_y ; X1% = Polypoints%(0, 0) mov edi,[polypoints] mov [x1],edi ; Y1% = Polypoints%(0, 1) mov edi,[polypoints+4] mov [y1],edi ; X2% = Polypoints%(1, 0) mov edi,[polypoints+8] mov [x2],edi ; Y2% = Polypoints%(1, 1) mov edi,[polypoints+12] mov [y2],edi ; ScanConvert(X1%, Y1%, X2%, Y2%, 1) ;scan top of picture mov [pside],dword 1 call scan_convert ; X1% = Polypoints%(1, 0) mov edi,[polypoints+8] mov [x1],edi ; Y1% = Polypoints%(1, 1) mov edi,[polypoints+12] mov [y1],edi ; X2% = Polypoints%(2, 0) mov edi,[polypoints+16] mov [x2],edi ; Y2% = Polypoints%(2, 1) mov edi,[polypoints+20] mov [y2],edi ; ScanConvert(X1%, Y1%, X2%, Y2%, 2) ;scan Right of picture mov [pside],dword 2 call scan_convert ; X1% = Polypoints%(2, 0) mov edi,[polypoints+16] mov [x1],edi ; Y1% = Polypoints%(2, 1) mov edi,[polypoints+20] mov [y1],edi ; X2% = Polypoints%(3, 0) mov edi,[polypoints+24] mov [x2],edi ; Y2% = Polypoints%(3, 1) mov edi,[polypoints+28] mov [y2],edi ; ScanConvert(X1%, Y1%, X2%, Y2%, 3) ;scan bottom of picture mov [pside],dword 3 call scan_convert ; X1% = Polypoints%(3, 0) mov edi,[polypoints+24] mov [x1],edi ; Y1% = Polypoints%(3, 1) mov edi,[polypoints+28] mov [y1],edi ; X2% = Polypoints%(0, 0) mov edi,[polypoints] mov [x2],edi ; Y2% = Polypoints%(0, 1) mov edi,[polypoints+4] mov [y2],edi ; ScanConvert(X1%, Y1%, X2%, Y2%, 4) ;scan Left of picture mov [pside],dword 4 call scan_convert ; TextureMap() call texture_map ; EndIf is_empty_slot: ; Next sub eax,4 cmp eax,0 ;ebx jge for_i_0_to_10000 ;Wend ret ;End ; --------------------------------------------------------------------- get_sinus: imul eax,4 ; expects degree*10 add eax,sinus ret get_cosinus: imul eax,4 ; expects degree*10 add eax,sinus add eax,10804 cmp eax,eosinus jl ok3600sub sub eax,14400 ok3600sub: ret ;; ------------------ texture mapping functions----------------------------- ;Function GetPolygonPoints(ilocal%) ; initially read in a rectangle get_polygon_points: pusha ; For Count% = 0 To 3 ; Polypoints%(Count%, 0) = xw(ilocal%+Count%) ; Polypoints%(Count%, 1) = yw(ilocal%+Count%) ; Next mov eax,0 ; --- count_0_3: mov ebx,eax imul ebx,8 ; count add ebx,polypoints ; desti adr mov ecx,eax add ecx,[ilocal] imul ecx,4 add ecx,a_xw ; src adr mov edx,[ecx] mov [ebx],edx ; ---- add ebx,4 ; desti 2 mov ecx,eax add ecx,[ilocal] imul ecx,4 add ecx,a_yw ; src 2 mov edx,[ecx] mov [ebx],edx ; ---- inc eax cmp eax,4 jl count_0_3 ;End Function popa ret ; ------------------------------------------------------------------------- ;Function FindSmallLargeY() find_small_large_y: pusha ; For Count% = 0 To 3 mov eax,0 for03b: ; Ycoord% = Polypoints%(Count%, 1) mov ebx,eax imul ebx,8 add ebx,4 add ebx,polypoints mov ecx,[ebx] ; If Ycoord% < Miny% Then ; is this the New lowest y co-ord? ; Miny% = Ycoord% ; Yes... ; End If cmp ecx,[miny] jge isge0 mov [miny],ecx isge0: ; If Ycoord% > Maxy% Then ; is this the New highest y co-ord? ; Maxy% = Ycoord% ; Yes... ; End If cmp ecx,[maxy] jle isge1 mov [maxy],ecx isge1: ; Next inc eax cmp eax,4 jl for03b ;End Function popa ret ; ------------------------------------------------------------------------- ;Function ScanConvert (X1%, Y1%, X2%, Y2%, Pside) scan_convert: pusha ; If Y2% < Y1% Then mov eax,[y1] mov ebx,[y2] cmp eax,ebx jl l_else0 ; temp%=X1% : X1%=X2% : X2%=temp% ; temp%=Y1% : Y1%=Y2% : Y2%=temp% ; Lineheight% = (Y2% - Y1%) ; ScanLeftSide(X1%, X2%, Y1%, Lineheight%, Pside) mov [y1],ebx ; swap y,x mov [y2],eax mov eax,[x1] mov ebx,[x2] mov [x1],ebx mov [x2],eax mov eax,[y1] mov ebx,[y2] ; eo swap sub ebx,eax mov [lineheight],ebx call scan_left_side jmp l_endif0 ; Else l_else0: ; Lineheight% = (Y2% - Y1%) ; ScanRightSide(X1%, X2%, Y1%, Lineheight%, Pside) sub ebx,eax mov [lineheight],ebx call scan_right_side ; End If l_endif0: ;End Function popa ret ; ------------------------------------------------------------------------- ;Function ScanLeftSide (X1%, X2%, Ytop%, Lineheight%, Pside) scan_left_side: pusha mov eax,[y1] mov [ytop],eax ; Lineheight% = Lineheight% + 1 ; prevent divide by zero inc dword[lineheight] ; Xadd = (X2% - X1%) Shl 16 mov edi,[x2] sub edi,[x1] sal edi,16 ; Xadd = Xadd / Lineheight% mov eax,edi ; whole cdq mov ebx,[lineheight] ; divisor ; or ebx,1 idiv ebx ; result now in eax mov [v_xadd],eax ; ------------ ; If Pside = 1 Then cmp [pside],dword 1 jne psidenot10 ; Px = Pwidth% - 1 ; Py = 0 mov edi,[pwidth] mov esi,edi sub esi,1 mov [px],esi mov [py],dword 0 ; Pxadd = -Pwidth% / Lineheight% ; Pyadd = 0 mov eax,0 sub eax,[pwidth] cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx ; result now in eax mov [pxadd],eax mov [pyadd],dword 0 ; End If psidenot10: ; ------------ ; If Pside = 2 Then cmp [pside],dword 2 jne psidenot20 ; Px = Pwidth% ; Py = Pheight% mov edi,[pwidth] mov esi,[pheight] mov [px],edi mov [py],esi ; Pxadd = 0 ; Pyadd = -Pheight% / Lineheight% mov [pxadd],dword 0 mov eax,0 sub eax,[pheight] cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx ; result now in eax mov [pyadd],eax ; End If psidenot20: ; ------------ ; If Pside = 3 Then cmp [pside],dword 3 jne psidenot30 ; Px = 0 ; Py = Pheight% mov [px],dword 0 mov edi,[pheight] mov [py],edi ; Pxadd = Pwidth% / Lineheight% ; Pyadd = 0 mov eax,[pwidth] cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx ; result now in eax mov [pxadd],eax mov [pyadd],dword 0 ; End If psidenot30: ; ------------ ; If Pside = 4 Then cmp [pside],dword 4 jne psidenot40 ; jne ; Px = 0 ; Py = 0 mov [px],dword 0 mov [py],dword 0 ; Pxadd = 0 ; Pyadd = Pheight% / Lineheight% mov [pxadd],dword 0 mov eax,[pheight] cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx mov [pyadd],eax ; End If psidenot40: ; ------------ ; x = X1% Shl 16 mov edx,[x1] ; used for x mov edi,[px] ; used for px mov esi,[py] ; used for py sal edx,16 ;mov [x],edx ;------ ; For y% = 0 To Lineheight% mov eax,0 for0lineheight0: ; Ytopy%=Ytop%+y% mov ebx,[ytop] mov [ytopy],ebx add [ytopy],eax ; If Ytopy%<0 Then Ytopy%=0 ; prevent read pre array cmp [ytopy], dword 0 jge isnot00 mov [ytopy],dword 0 isnot00: ; Lefttable(Ytopy%, 0) = x Sar 16 ;polygon x mov ecx,[ytopy] imul ecx,16 add ecx,lefttable mov [ecx],edx sar dword[ecx],16 ; Lefttable(Ytopy%, 1) = Px ;picture x add ecx,4 mov [ecx],edi ; Lefttable(Ytopy%, 2) = Py ;picture y add ecx,4 mov [ecx],esi ; x = x + Xadd ;Next polygon x ; Px = Px + Pxadd ;Next picture x ; Py = Py + Pyadd ;Next picture y add edx,[v_xadd] add edi,[pxadd] add esi,[pyadd] ;------ ; Next inc eax cmp eax,[lineheight] jl for0lineheight0 ;End Function popa ret ; ------------------------------------------------------------------------- ; ------------------------------------------------------------------------- ;Function ScanRightSide (X1%, X2%, Ytop%, Lineheight%, Pside) scan_right_side: pusha mov eax,[y1] mov [ytop],eax ; Lineheight% = Lineheight% + 1 ; prevent divide by zero inc dword[lineheight] ; Xadd = (X2% - X1%) Shl 16 mov edi,[x2] sub edi,[x1] sal edi,16 ; Xadd = Xadd / Lineheight% mov eax,edi ; whole cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx ; result now in eax mov [v_xadd],eax ; ------------ ; If Pside = 1 Then cmp [pside],dword 1 jne psidenot11 ; Px = 0 ; Py = 0 mov [px],dword 0 mov [py],dword 0 ; Pxadd = Pwidth% / Lineheight% ; Pyadd = 0 mov eax,[pwidth] cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx ; result now in eax mov [pxadd],eax mov [pyadd],dword 0 ; End If psidenot11: ; ------------ ; If Pside = 2 Then cmp [pside],dword 2 jne psidenot21 ; Px = Pwidth% ; Py = 0 mov edi,[pwidth] mov [px],edi mov [py],dword 0 ; Pxadd = 0 ; Pyadd = Pheight% / Lineheight% mov [pxadd],dword 0 mov eax,[pheight] cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx ; result now in eax mov [pyadd],eax ; End If psidenot21: ; ------------ ; If Pside = 3 Then cmp [pside],dword 3 jne psidenot31 ; Px = Pwidth% ; Py = Pheight% mov edi,[pwidth] mov [px],edi mov esi,[pheight] mov [py],esi ; Pxadd = -Pwidth% / Lineheight% ; Pyadd = 0 mov eax,0 sub eax,[pwidth] cdq mov ebx,[lineheight] ; divisor ;or ebx,3 ; prevent div 0 idiv ebx ; result now in eax mov [pxadd],eax mov [pyadd],dword 0 ; End If psidenot31: ; ------------ ; If Pside = 4 Then cmp [pside],dword 4 jne psidenot41 ; jne ; Px = 0 ; Py = Pheight% mov [px],dword 0 mov esi,[pheight] mov [py],esi ; Pxadd = 0 ; Pyadd = -Pheight% / Lineheight% mov [pxadd],dword 0 mov eax,0 sub eax,[pheight] cdq mov ebx,[lineheight] ; divisor ;or ebx,1 idiv ebx mov [pyadd],eax ; End If psidenot41: push edx push edi push esi ; ------------ ; x = X1% Shl 16 mov edx,[x1] ; used for x mov edi,[px] ; used for px mov esi,[py] ; used for py sal edx,16 cmp [lineheight],dword 100 ; lineheight is up to 33 mio ??? jle okok mov eax,[lineheight] mov [wonder+4],eax okok: ;------ ; For y% = 0 To Lineheight% mov eax,0 for0lineheight1b: ; Ytopy%=Ytop%+y% mov ebx,[ytop] mov [ytopy],ebx add [ytopy],eax ; If Ytopy%<0 Then Ytopy%=0 ; prevent read pre array cmp [ytopy], dword 0 jg isnot01 mov [ytopy],dword 0 isnot01: ; righttable(Ytopy%, 0) = x Sar 16 ;polygon x mov ecx,[ytopy] imul ecx,16 add ecx,righttable mov [ecx],edx sar dword[ecx],16 ; righttable(Ytopy%, 1) = Px ;picture x add ecx,4 mov [ecx],edi ; righttable(Ytopy%, 2) = Py ;picture y add ecx,4 mov [ecx],esi ; x = x + Xadd ;Next polygon x ; Px = Px + Pxadd ;Next picture x ; Py = Py + Pyadd ;Next picture y add edx,[v_xadd] add edi,[pxadd] add esi,[pyadd] ;------ ; Next inc eax cmp eax,[lineheight] jl for0lineheight1b dbg2: pop esi pop edi pop edx ;End Function popa ret ; ------------------------------------------------------------------------- ; well I'm shure the following Sub CAN and SHOULD be optimized a LOT. ;Function TextureMap() texture_map: pusha ; For y% = Miny% To Maxy% mov eax,[miny] for_miny_maxy: ; If y>0 And y<=239 cmp eax,0 jle clipy cmp eax,239 jg clipy mov [y],eax ; Polyx1% = Lefttable((y%), 0) mov ebx,eax sal ebx,4 add ebx,lefttable mov ecx,[ebx] mov [polyx1],ecx ; Px1 = Lefttable(y%, 1) add ebx,4 mov ecx,[ebx] mov [px1],ecx ; Py1 = Lefttable(y%, 2) add ebx,4 mov ecx,[ebx] mov [py1],ecx ; Polyx2% = Righttable((y%), 0) mov ebx,eax sal ebx,4 add ebx,righttable mov ecx,[ebx] mov [polyx2],ecx ; Px2 = Righttable(y%, 1) add ebx,4 mov ecx,[ebx] mov [px2],ecx ; Py2 = Righttable(y%, 2) add ebx,4 mov ecx,[ebx] mov [py2],ecx ; Linewidth% = Polyx2% - Polyx1% mov ecx,[polyx2] sub ecx,[polyx1] ; Linewidth%=Linewidth% Or 1 or ecx,1 mov [linewidth],ecx ; Pxadd = ((Px2 - Px1)) / Linewidth% mov eax,[px2] sub eax,[px1] cdq mov ebx,[linewidth] ; divisor or ebx,1 idiv ebx ; should be idiv ... probs mov [pxadd],eax ; Pyadd = ((Py2 - Py1)) / Linewidth% mov eax,[py2] sub eax,[py1] cdq mov ebx,[linewidth] ; divisor or ebx,1 idiv ebx ; should be idiv ...probs mov [pyadd],eax mov edi,[px1] mov esi,[py1] ; For x% = Polyx1% To Polyx2% mov eax,[polyx1] cmp eax,[polyx2] jge clipxfully for_polyx1_polyx2: ; If x>0 And x<=319 cmp eax,0 jl clipx cmp eax,319 jg clipx ; Col%=ReadPixelFast((Px1 Shr 16),(Py1 Shr 16),imgtxt) mov ebx,edi sar ebx,16 ; is eq (px1 shr 16)*64 and ebx,63 sal ebx,2 ; is x mov ecx,esi sar ecx,16 and ecx,63 sal ecx,8 ; y add ecx,ebx add ecx,tex1 ; adr of texturepixel now in ecx mov edx,[ecx]; rgb now in edx ; WritePixelFast x%,y%,Col% mov ebx,[y] mov [tempdiv],ebx shl dword [tempdiv],6 shl ebx,10 sub ebx,[tempdiv] ;this was imul ebx,960 ; *1024 - *64 add ebx,eax add ebx,eax add ebx,eax add ebx,0x80000 or [ebx],edx ; EndIf clipx: ; Px1 = Px1 + Pxadd ; Py1 = Py1 + Pyadd add edi,dword [pxadd] add esi,dword [pyadd] ; Next x inc eax cmp eax,[polyx2] jl for_polyx1_polyx2 clipxfully: mov eax,[y] ; EndIf clipy: ; Next y inc eax cmp eax,[maxy] jl for_miny_maxy ;End Function popa ret ; ------------------------------------------------------------------------- put_screen: pusha mov eax,7 mov ebx,0x80000 mov ecx,IMAGE_W*65536+IMAGE_H mov edx,0 int 0x40 popa ret clear_screen: push ebx mov ebx,0x80000 cls: mov [ebx],dword 0 add ebx,4 cmp ebx,0x80000+(IMAGE_W*IMAGE_H*3) jl cls pop ebx ret ; ------------------------------------------------------------------------- ; DATA AREA ; cube.inc includes the mesh 3D Data, in this case a simple cube. Any Model ; is theoreticly possible. Check the File, the Format is trivial. ; The Quads should not intersect for a bearable z-sorting. The Quads must be ; clockwise. include "cube.inc" ;;------------------------------ grid: ; 32*32 Blocks, Map: 0 = Air, 1 to 5 = Wall ; this is a relict from an other program. I leave it here to keep ; the Navigation Subs compatible (planning to recycle them) db 2,1,2,1,2,1,2,1,2,1,2,1,1,1,1,1,1,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8 db 1,0,0,0,1,0,0,0,0,0,0,3,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,8,8 db 5,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,8 db 1,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,1,0,0,0,0,3,3,3,3,0,0,0,0,0,0,8 db 5,0,1,2,3,4,5,6,7,8,2,1,3,3,3,0,5,0,2,1,2,3,0,0,0,0,0,0,0,0,0,8 db 1,0,0,0,0,0,0,0,0,0,2,3,0,0,0,0,5,0,0,0,0,3,0,0,0,0,0,0,0,0,0,8 db 5,0,0,0,1,0,0,4,0,0,0,1,0,0,0,0,5,0,0,0,0,3,3,0,3,3,0,0,0,0,0,8 db 1,1,0,1,1,1,1,4,1,0,1,3,0,0,0,0,5,2,1,2,0,3,0,0,0,3,0,0,0,0,0,8 db 5,0,0,0,1,0,0,0,0,0,0,1,0,3,3,3,5,0,0,0,0,3,0,0,0,3,0,0,0,0,0,8 db 1,0,0,0,1,0,0,5,0,0,0,0,0,0,0,0,5,0,0,0,0,0,0,0,0,3,0,0,0,0,0,8 db 5,0,0,0,0,0,0,5,0,0,0,1,0,0,0,0,5,0,0,0,0,3,0,0,0,0,0,0,0,0,0,8 db 1,4,4,4,4,4,4,4,4,4,4,3,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,8,8 db 2,2,2,2,2,2,8,8,8,8,8,8,8,8,8,0,0,0,6,6,0,7,7,7,7,7,7,7,7,7,8,8 db 1,0,0,0,1,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1 db 5,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,6,0,2,2,2,2,0,0,0,0,3,3,3,3,3,1 db 1,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,6,0,0,0,0,2,0,0,0,0,3,0,0,0,0,1 db 5,0,2,3,2,3,2,3,2,3,2,1,0,0,0,0,6,0,2,2,0,2,0,0,0,0,3,0,5,5,0,1 db 1,0,0,0,0,0,0,4,0,0,0,3,0,0,0,0,6,0,0,2,0,2,0,2,0,0,3,0,0,0,0,1 db 5,0,0,0,1,0,0,4,0,0,0,1,0,0,0,0,6,0,0,2,2,2,0,2,0,0,3,3,3,3,0,1 db 1,1,0,1,1,1,1,4,1,0,1,3,7,7,7,0,6,0,0,0,0,0,0,2,0,0,0,0,0,3,0,1 db 5,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,6,0,0,0,0,2,2,2,0,0,0,0,0,3,0,1 db 1,0,0,0,1,0,0,5,0,0,0,3,0,0,0,0,6,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1 db 5,0,0,0,0,0,0,5,0,0,0,1,0,0,0,0,6,0,5,1,0,2,0,0,4,4,0,4,4,0,0,1 db 1,4,1,4,1,4,1,4,1,4,1,3,0,0,0,0,6,0,0,5,0,2,0,0,0,4,0,4,0,0,0,1 db 1,0,0,0,0,0,0,4,0,0,0,3,0,3,3,3,6,0,0,1,0,1,0,0,4,4,0,4,4,0,0,1 db 5,0,0,0,1,0,0,4,0,0,0,1,0,0,0,0,6,0,0,5,0,1,0,4,4,0,0,0,4,4,0,1 db 1,1,0,1,1,1,1,4,1,0,1,3,0,0,0,0,6,0,0,1,0,1,0,4,0,0,0,0,0,4,0,1 db 5,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,6,0,0,5,0,1,0,4,0,0,0,0,0,4,0,1 db 1,0,0,0,1,0,0,5,0,0,0,3,0,0,0,0,6,1,5,1,0,1,0,4,4,0,0,0,4,4,0,1 db 5,0,0,0,0,0,0,5,0,0,0,0,0,0,1,1,0,0,0,0,0,1,0,0,4,4,4,4,4,0,0,1 db 1,4,1,4,1,4,1,4,1,4,1,3,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1 db 2,1,2,1,2,1,2,1,2,1,2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1 sinus: dd 0,11,22,34,45,57,68,80,91,102 dd 114,125,137,148,160,171,182,194,205,217 dd 228,240,251,263,274,285,297,308,320,331 dd 342,354,365,377,388,400,411,422,434,445 dd 457,468,479,491,502,514,525,536,548,559 dd 571,582,593,605,616,628,639,650,662,673 dd 685,696,707,719,730,741,753,764,775,787 dd 798,810,821,832,844,855,866,878,889,900 dd 912,923,934,946,957,968,979,991,1002,1013 dd 1025,1036,1047,1059,1070,1081,1092,1104,1115,1126 dd 1138,1149,1160,1171,1183,1194,1205,1216,1228,1239 dd 1250,1261,1272,1284,1295,1306,1317,1328,1340,1351 dd 1362,1373,1384,1396,1407,1418,1429,1440,1451,1463 dd 1474,1485,1496,1507,1518,1529,1541,1552,1563,1574 dd 1585,1596,1607,1618,1629,1640,1651,1663,1674,1685 dd 1696,1707,1718,1729,1740,1751,1762,1773,1784,1795 dd 1806,1817,1828,1839,1850,1861,1872,1883,1894,1905 dd 1916,1926,1937,1948,1959,1970,1981,1992,2003,2014 dd 2025,2036,2046,2057,2068,2079,2090,2101,2111,2122 dd 2133,2144,2155,2166,2176,2187,2198,2209,2219,2230 dd 2241,2252,2262,2273,2284,2295,2305,2316,2327,2337 dd 2348,2359,2369,2380,2391,2401,2412,2423,2433,2444 dd 2454,2465,2476,2486,2497,2507,2518,2529,2539,2550 dd 2560,2571,2581,2592,2602,2613,2623,2634,2644,2655 dd 2665,2675,2686,2696,2707,2717,2728,2738,2748,2759 dd 2769,2779,2790,2800,2811,2821,2831,2841,2852,2862 dd 2872,2883,2893,2903,2913,2924,2934,2944,2954,2965 dd 2975,2985,2995,3005,3015,3026,3036,3046,3056,3066 dd 3076,3086,3096,3106,3117,3127,3137,3147,3157,3167 dd 3177,3187,3197,3207,3217,3227,3237,3246,3256,3266 dd 3276,3286,3296,3306,3316,3326,3336,3345,3355,3365 dd 3375,3385,3394,3404,3414,3424,3433,3443,3453,3463 dd 3472,3482,3492,3501,3511,3521,3530,3540,3550,3559 dd 3569,3578,3588,3598,3607,3617,3626,3636,3645,3655 dd 3664,3674,3683,3693,3702,3711,3721,3730,3740,3749 dd 3758,3768,3777,3786,3796,3805,3814,3824,3833,3842 dd 3852,3861,3870,3879,3888,3898,3907,3916,3925,3934 dd 3943,3953,3962,3971,3980,3989,3998,4007,4016,4025 dd 4034,4043,4052,4061,4070,4079,4088,4097,4106,4115 dd 4124,4133,4142,4150,4159,4168,4177,4186,4194,4203 dd 4212,4221,4230,4238,4247,4256,4264,4273,4282,4290 dd 4299,4308,4316,4325,4333,4342,4351,4359,4368,4376 dd 4385,4393,4402,4410,4419,4427,4435,4444,4452,4461 dd 4469,4477,4486,4494,4502,4511,4519,4527,4535,4544 dd 4552,4560,4568,4577,4585,4593,4601,4609,4617,4625 dd 4634,4642,4650,4658,4666,4674,4682,4690,4698,4706 dd 4714,4722,4730,4737,4745,4753,4761,4769,4777,4785 dd 4792,4800,4808,4816,4824,4831,4839,4847,4854,4862 dd 4870,4877,4885,4893,4900,4908,4915,4923,4930,4938 dd 4945,4953,4960,4968,4975,4983,4990,4998,5005,5012 dd 5020,5027,5034,5042,5049,5056,5064,5071,5078,5085 dd 5093,5100,5107,5114,5121,5128,5135,5143,5150,5157 dd 5164,5171,5178,5185,5192,5199,5206,5213,5220,5226 dd 5233,5240,5247,5254,5261,5268,5274,5281,5288,5295 dd 5301,5308,5315,5321,5328,5335,5341,5348,5355,5361 dd 5368,5374,5381,5387,5394,5400,5407,5413,5420,5426 dd 5433,5439,5445,5452,5458,5464,5471,5477,5483,5489 dd 5496,5502,5508,5514,5521,5527,5533,5539,5545,5551 dd 5557,5563,5569,5575,5581,5587,5593,5599,5605,5611 dd 5617,5623,5629,5635,5640,5646,5652,5658,5664,5669 dd 5675,5681,5686,5692,5698,5703,5709,5715,5720,5726 dd 5731,5737,5742,5748,5753,5759,5764,5770,5775,5781 dd 5786,5791,5797,5802,5807,5813,5818,5823,5828,5834 dd 5839,5844,5849,5854,5859,5864,5870,5875,5880,5885 dd 5890,5895,5900,5905,5910,5915,5920,5924,5929,5934 dd 5939,5944,5949,5953,5958,5963,5968,5972,5977,5982 dd 5986,5991,5996,6000,6005,6009,6014,6019,6023,6028 dd 6032,6036,6041,6045,6050,6054,6059,6063,6067,6072 dd 6076,6080,6084,6089,6093,6097,6101,6105,6109,6114 dd 6118,6122,6126,6130,6134,6138,6142,6146,6150,6154 dd 6158,6162,6166,6169,6173,6177,6181,6185,6188,6192 dd 6196,6200,6203,6207,6211,6214,6218,6222,6225,6229 dd 6232,6236,6239,6243,6246,6250,6253,6257,6260,6263 dd 6267,6270,6273,6277,6280,6283,6286,6290,6293,6296 dd 6299,6302,6305,6309,6312,6315,6318,6321,6324,6327 dd 6330,6333,6336,6338,6341,6344,6347,6350,6353,6356 dd 6358,6361,6364,6367,6369,6372,6375,6377,6380,6382 dd 6385,6388,6390,6393,6395,6398,6400,6403,6405,6407 dd 6410,6412,6415,6417,6419,6421,6424,6426,6428,6430 dd 6433,6435,6437,6439,6441,6443,6445,6447,6449,6451 dd 6453,6455,6457,6459,6461,6463,6465,6467,6469,6471 dd 6472,6474,6476,6478,6479,6481,6483,6484,6486,6488 dd 6489,6491,6492,6494,6495,6497,6498,6500,6501,6503 dd 6504,6506,6507,6508,6510,6511,6512,6513,6515,6516 dd 6517,6518,6519,6521,6522,6523,6524,6525,6526,6527 dd 6528,6529,6530,6531,6532,6533,6534,6535,6535,6536 dd 6537,6538,6539,6539,6540,6541,6541,6542,6543,6543 dd 6544,6545,6545,6546,6546,6547,6547,6548,6548,6549 dd 6549,6549,6550,6550,6550,6551,6551,6551,6552,6552 dd 6552,6552,6552,6553,6553,6553,6553,6553,6553,6553 dd 6553,6553,6553,6553,6553,6553,6553,6553,6552,6552 dd 6552,6552,6552,6551,6551,6551,6550,6550,6550,6549 dd 6549,6549,6548,6548,6547,6547,6546,6546,6545,6545 dd 6544,6543,6543,6542,6541,6541,6540,6539,6539,6538 dd 6537,6536,6535,6535,6534,6533,6532,6531,6530,6529 dd 6528,6527,6526,6525,6524,6523,6522,6521,6519,6518 dd 6517,6516,6515,6513,6512,6511,6510,6508,6507,6506 dd 6504,6503,6501,6500,6498,6497,6495,6494,6492,6491 dd 6489,6488,6486,6484,6483,6481,6479,6478,6476,6474 dd 6472,6471,6469,6467,6465,6463,6461,6459,6457,6455 dd 6453,6451,6449,6447,6445,6443,6441,6439,6437,6435 dd 6433,6430,6428,6426,6424,6421,6419,6417,6415,6412 dd 6410,6407,6405,6403,6400,6398,6395,6393,6390,6388 dd 6385,6382,6380,6377,6375,6372,6369,6367,6364,6361 dd 6358,6356,6353,6350,6347,6344,6341,6338,6336,6333 dd 6330,6327,6324,6321,6318,6315,6312,6309,6305,6302 dd 6299,6296,6293,6290,6286,6283,6280,6277,6273,6270 dd 6267,6263,6260,6257,6253,6250,6246,6243,6239,6236 dd 6232,6229,6225,6222,6218,6214,6211,6207,6203,6200 dd 6196,6192,6188,6185,6181,6177,6173,6169,6166,6162 dd 6158,6154,6150,6146,6142,6138,6134,6130,6126,6122 dd 6118,6114,6109,6105,6101,6097,6093,6089,6084,6080 dd 6076,6072,6067,6063,6059,6054,6050,6045,6041,6036 dd 6032,6028,6023,6019,6014,6009,6005,6000,5996,5991 dd 5986,5982,5977,5972,5968,5963,5958,5953,5949,5944 dd 5939,5934,5929,5924,5920,5915,5910,5905,5900,5895 dd 5890,5885,5880,5875,5870,5864,5859,5854,5849,5844 dd 5839,5834,5828,5823,5818,5813,5807,5802,5797,5791 dd 5786,5781,5775,5770,5764,5759,5753,5748,5742,5737 dd 5731,5726,5720,5715,5709,5703,5698,5692,5686,5681 dd 5675,5669,5664,5658,5652,5646,5640,5635,5629,5623 dd 5617,5611,5605,5599,5593,5587,5581,5575,5569,5563 dd 5557,5551,5545,5539,5533,5527,5521,5514,5508,5502 dd 5496,5489,5483,5477,5471,5464,5458,5452,5445,5439 dd 5433,5426,5420,5413,5407,5400,5394,5387,5381,5374 dd 5368,5361,5355,5348,5341,5335,5328,5321,5315,5308 dd 5301,5295,5288,5281,5274,5268,5261,5254,5247,5240 dd 5233,5226,5220,5213,5206,5199,5192,5185,5178,5171 dd 5164,5157,5150,5143,5135,5128,5121,5114,5107,5100 dd 5093,5085,5078,5071,5064,5056,5049,5042,5034,5027 dd 5020,5012,5005,4998,4990,4983,4975,4968,4960,4953 dd 4945,4938,4930,4923,4915,4908,4900,4893,4885,4877 dd 4870,4862,4854,4847,4839,4831,4824,4816,4808,4800 dd 4792,4785,4777,4769,4761,4753,4745,4737,4730,4722 dd 4714,4706,4698,4690,4682,4674,4666,4658,4650,4642 dd 4634,4625,4617,4609,4601,4593,4585,4577,4568,4560 dd 4552,4544,4535,4527,4519,4511,4502,4494,4486,4477 dd 4469,4461,4452,4444,4435,4427,4419,4410,4402,4393 dd 4385,4376,4368,4359,4351,4342,4333,4325,4316,4308 dd 4299,4290,4282,4273,4264,4256,4247,4238,4230,4221 dd 4212,4203,4194,4186,4177,4168,4159,4150,4142,4133 dd 4124,4115,4106,4097,4088,4079,4070,4061,4052,4043 dd 4034,4025,4016,4007,3998,3989,3980,3971,3962,3953 dd 3943,3934,3925,3916,3907,3898,3888,3879,3870,3861 dd 3852,3842,3833,3824,3814,3805,3796,3786,3777,3768 dd 3758,3749,3740,3730,3721,3711,3702,3693,3683,3674 dd 3664,3655,3645,3636,3626,3617,3607,3598,3588,3578 dd 3569,3559,3550,3540,3530,3521,3511,3501,3492,3482 dd 3472,3463,3453,3443,3433,3424,3414,3404,3394,3385 dd 3375,3365,3355,3345,3336,3326,3316,3306,3296,3286 dd 3276,3266,3256,3246,3237,3227,3217,3207,3197,3187 dd 3177,3167,3157,3147,3137,3127,3117,3106,3096,3086 dd 3076,3066,3056,3046,3036,3026,3015,3005,2995,2985 dd 2975,2965,2954,2944,2934,2924,2913,2903,2893,2883 dd 2872,2862,2852,2841,2831,2821,2811,2800,2790,2779 dd 2769,2759,2748,2738,2728,2717,2707,2696,2686,2675 dd 2665,2655,2644,2634,2623,2613,2602,2592,2581,2571 dd 2560,2550,2539,2529,2518,2507,2497,2486,2476,2465 dd 2454,2444,2433,2423,2412,2401,2391,2380,2369,2359 dd 2348,2337,2327,2316,2305,2295,2284,2273,2262,2252 dd 2241,2230,2219,2209,2198,2187,2176,2166,2155,2144 dd 2133,2122,2111,2101,2090,2079,2068,2057,2046,2036 dd 2025,2014,2003,1992,1981,1970,1959,1948,1937,1926 dd 1916,1905,1894,1883,1872,1861,1850,1839,1828,1817 dd 1806,1795,1784,1773,1762,1751,1740,1729,1718,1707 dd 1696,1685,1674,1663,1651,1640,1629,1618,1607,1596 dd 1585,1574,1563,1552,1541,1529,1518,1507,1496,1485 dd 1474,1463,1451,1440,1429,1418,1407,1396,1384,1373 dd 1362,1351,1340,1328,1317,1306,1295,1284,1272,1261 dd 1250,1239,1228,1216,1205,1194,1183,1171,1160,1149 dd 1138,1126,1115,1104,1092,1081,1070,1059,1047,1036 dd 1025,1013,1002,991,979,968,957,946,934,923 dd 912,900,889,878,866,855,844,832,821,810 dd 798,787,775,764,753,741,730,719,707,696 dd 685,673,662,650,639,628,616,605,593,582 dd 571,559,548,536,525,514,502,491,479,468 dd 457,445,434,422,411,400,388,377,365,354 dd 342,331,320,308,297,285,274,263,251,240 dd 228,217,205,194,182,171,160,148,137,125 dd 114,102,91,80,68,57,45,34,22,11 dd 0,-12,-23,-35,-46,-58,-69,-81,-92,-103 dd -115,-126,-138,-149,-161,-172,-183,-195,-206,-218 dd -229,-241,-252,-264,-275,-286,-298,-309,-321,-332 dd -343,-355,-366,-378,-389,-401,-412,-423,-435,-446 dd -458,-469,-480,-492,-503,-515,-526,-537,-549,-560 dd -572,-583,-594,-606,-617,-629,-640,-651,-663,-674 dd -686,-697,-708,-720,-731,-742,-754,-765,-776,-788 dd -799,-811,-822,-833,-845,-856,-867,-879,-890,-901 dd -913,-924,-935,-947,-958,-969,-980,-992,-1003,-1014 dd -1026,-1037,-1048,-1060,-1071,-1082,-1093,-1105,-1116,-1127 dd -1139,-1150,-1161,-1172,-1184,-1195,-1206,-1217,-1229,-1240 dd -1251,-1262,-1273,-1285,-1296,-1307,-1318,-1329,-1341,-1352 dd -1363,-1374,-1385,-1397,-1408,-1419,-1430,-1441,-1452,-1464 dd -1475,-1486,-1497,-1508,-1519,-1530,-1542,-1553,-1564,-1575 dd -1586,-1597,-1608,-1619,-1630,-1641,-1652,-1664,-1675,-1686 dd -1697,-1708,-1719,-1730,-1741,-1752,-1763,-1774,-1785,-1796 dd -1807,-1818,-1829,-1840,-1851,-1862,-1873,-1884,-1895,-1906 dd -1917,-1927,-1938,-1949,-1960,-1971,-1982,-1993,-2004,-2015 dd -2026,-2037,-2047,-2058,-2069,-2080,-2091,-2102,-2112,-2123 dd -2134,-2145,-2156,-2167,-2177,-2188,-2199,-2210,-2220,-2231 dd -2242,-2253,-2263,-2274,-2285,-2296,-2306,-2317,-2328,-2338 dd -2349,-2360,-2370,-2381,-2392,-2402,-2413,-2424,-2434,-2445 dd -2455,-2466,-2477,-2487,-2498,-2508,-2519,-2530,-2540,-2551 dd -2561,-2572,-2582,-2593,-2603,-2614,-2624,-2635,-2645,-2656 dd -2666,-2676,-2687,-2697,-2708,-2718,-2729,-2739,-2749,-2760 dd -2770,-2780,-2791,-2801,-2812,-2822,-2832,-2842,-2853,-2863 dd -2873,-2884,-2894,-2904,-2914,-2925,-2935,-2945,-2955,-2966 dd -2976,-2986,-2996,-3006,-3016,-3027,-3037,-3047,-3057,-3067 dd -3077,-3087,-3097,-3107,-3118,-3128,-3138,-3148,-3158,-3168 dd -3178,-3188,-3198,-3208,-3218,-3228,-3238,-3247,-3257,-3267 dd -3277,-3287,-3297,-3307,-3317,-3327,-3337,-3346,-3356,-3366 dd -3376,-3386,-3395,-3405,-3415,-3425,-3434,-3444,-3454,-3464 dd -3473,-3483,-3493,-3502,-3512,-3522,-3531,-3541,-3551,-3560 dd -3570,-3579,-3589,-3599,-3608,-3618,-3627,-3637,-3646,-3656 dd -3665,-3675,-3684,-3694,-3703,-3712,-3722,-3731,-3741,-3750 dd -3759,-3769,-3778,-3787,-3797,-3806,-3815,-3825,-3834,-3843 dd -3853,-3862,-3871,-3880,-3889,-3899,-3908,-3917,-3926,-3935 dd -3944,-3954,-3963,-3972,-3981,-3990,-3999,-4008,-4017,-4026 dd -4035,-4044,-4053,-4062,-4071,-4080,-4089,-4098,-4107,-4116 dd -4125,-4134,-4143,-4151,-4160,-4169,-4178,-4187,-4195,-4204 dd -4213,-4222,-4231,-4239,-4248,-4257,-4265,-4274,-4283,-4291 dd -4300,-4309,-4317,-4326,-4334,-4343,-4352,-4360,-4369,-4377 dd -4386,-4394,-4403,-4411,-4420,-4428,-4436,-4445,-4453,-4462 dd -4470,-4478,-4487,-4495,-4503,-4512,-4520,-4528,-4536,-4545 dd -4553,-4561,-4569,-4578,-4586,-4594,-4602,-4610,-4618,-4626 dd -4635,-4643,-4651,-4659,-4667,-4675,-4683,-4691,-4699,-4707 dd -4715,-4723,-4731,-4738,-4746,-4754,-4762,-4770,-4778,-4786 dd -4793,-4801,-4809,-4817,-4825,-4832,-4840,-4848,-4855,-4863 dd -4871,-4878,-4886,-4894,-4901,-4909,-4916,-4924,-4931,-4939 dd -4946,-4954,-4961,-4969,-4976,-4984,-4991,-4999,-5006,-5013 dd -5021,-5028,-5035,-5043,-5050,-5057,-5065,-5072,-5079,-5086 dd -5094,-5101,-5108,-5115,-5122,-5129,-5136,-5144,-5151,-5158 dd -5165,-5172,-5179,-5186,-5193,-5200,-5207,-5214,-5221,-5227 dd -5234,-5241,-5248,-5255,-5262,-5269,-5275,-5282,-5289,-5296 dd -5302,-5309,-5316,-5322,-5329,-5336,-5342,-5349,-5356,-5362 dd -5369,-5375,-5382,-5388,-5395,-5401,-5408,-5414,-5421,-5427 dd -5434,-5440,-5446,-5453,-5459,-5465,-5472,-5478,-5484,-5490 dd -5497,-5503,-5509,-5515,-5522,-5528,-5534,-5540,-5546,-5552 dd -5558,-5564,-5570,-5576,-5582,-5588,-5594,-5600,-5606,-5612 dd -5618,-5624,-5630,-5636,-5641,-5647,-5653,-5659,-5665,-5670 dd -5676,-5682,-5687,-5693,-5699,-5704,-5710,-5716,-5721,-5727 dd -5732,-5738,-5743,-5749,-5754,-5760,-5765,-5771,-5776,-5782 dd -5787,-5792,-5798,-5803,-5808,-5814,-5819,-5824,-5829,-5835 dd -5840,-5845,-5850,-5855,-5860,-5865,-5871,-5876,-5881,-5886 dd -5891,-5896,-5901,-5906,-5911,-5916,-5921,-5925,-5930,-5935 dd -5940,-5945,-5950,-5954,-5959,-5964,-5969,-5973,-5978,-5983 dd -5987,-5992,-5997,-6001,-6006,-6010,-6015,-6020,-6024,-6029 dd -6033,-6037,-6042,-6046,-6051,-6055,-6060,-6064,-6068,-6073 dd -6077,-6081,-6085,-6090,-6094,-6098,-6102,-6106,-6110,-6115 dd -6119,-6123,-6127,-6131,-6135,-6139,-6143,-6147,-6151,-6155 dd -6159,-6163,-6167,-6170,-6174,-6178,-6182,-6186,-6189,-6193 dd -6197,-6201,-6204,-6208,-6212,-6215,-6219,-6223,-6226,-6230 dd -6233,-6237,-6240,-6244,-6247,-6251,-6254,-6258,-6261,-6264 dd -6268,-6271,-6274,-6278,-6281,-6284,-6287,-6291,-6294,-6297 dd -6300,-6303,-6306,-6310,-6313,-6316,-6319,-6322,-6325,-6328 dd -6331,-6334,-6337,-6339,-6342,-6345,-6348,-6351,-6354,-6357 dd -6359,-6362,-6365,-6368,-6370,-6373,-6376,-6378,-6381,-6383 dd -6386,-6389,-6391,-6394,-6396,-6399,-6401,-6404,-6406,-6408 dd -6411,-6413,-6416,-6418,-6420,-6422,-6425,-6427,-6429,-6431 dd -6434,-6436,-6438,-6440,-6442,-6444,-6446,-6448,-6450,-6452 dd -6454,-6456,-6458,-6460,-6462,-6464,-6466,-6468,-6470,-6472 dd -6473,-6475,-6477,-6479,-6480,-6482,-6484,-6485,-6487,-6489 dd -6490,-6492,-6493,-6495,-6496,-6498,-6499,-6501,-6502,-6504 dd -6505,-6507,-6508,-6509,-6511,-6512,-6513,-6514,-6516,-6517 dd -6518,-6519,-6520,-6522,-6523,-6524,-6525,-6526,-6527,-6528 dd -6529,-6530,-6531,-6532,-6533,-6534,-6535,-6536,-6536,-6537 dd -6538,-6539,-6540,-6540,-6541,-6542,-6542,-6543,-6544,-6544 dd -6545,-6546,-6546,-6547,-6547,-6548,-6548,-6549,-6549,-6550 dd -6550,-6550,-6551,-6551,-6551,-6552,-6552,-6552,-6553,-6553 dd -6553,-6553,-6553,-6554,-6554,-6554,-6554,-6554,-6554,-6554 dd -6554,-6554,-6554,-6554,-6554,-6554,-6554,-6554,-6553,-6553 dd -6553,-6553,-6553,-6552,-6552,-6552,-6551,-6551,-6551,-6550 dd -6550,-6550,-6549,-6549,-6548,-6548,-6547,-6547,-6546,-6546 dd -6545,-6544,-6544,-6543,-6542,-6542,-6541,-6540,-6540,-6539 dd -6538,-6537,-6536,-6536,-6535,-6534,-6533,-6532,-6531,-6530 dd -6529,-6528,-6527,-6526,-6525,-6524,-6523,-6522,-6520,-6519 dd -6518,-6517,-6516,-6514,-6513,-6512,-6511,-6509,-6508,-6507 dd -6505,-6504,-6502,-6501,-6499,-6498,-6496,-6495,-6493,-6492 dd -6490,-6489,-6487,-6485,-6484,-6482,-6480,-6479,-6477,-6475 dd -6473,-6472,-6470,-6468,-6466,-6464,-6462,-6460,-6458,-6456 dd -6454,-6452,-6450,-6448,-6446,-6444,-6442,-6440,-6438,-6436 dd -6434,-6431,-6429,-6427,-6425,-6422,-6420,-6418,-6416,-6413 dd -6411,-6408,-6406,-6404,-6401,-6399,-6396,-6394,-6391,-6389 dd -6386,-6383,-6381,-6378,-6376,-6373,-6370,-6368,-6365,-6362 dd -6359,-6357,-6354,-6351,-6348,-6345,-6342,-6339,-6337,-6334 dd -6331,-6328,-6325,-6322,-6319,-6316,-6313,-6309,-6306,-6303 dd -6300,-6297,-6294,-6291,-6287,-6284,-6281,-6278,-6274,-6271 dd -6268,-6264,-6261,-6258,-6254,-6251,-6247,-6244,-6240,-6237 dd -6233,-6230,-6226,-6223,-6219,-6215,-6212,-6208,-6204,-6201 dd -6197,-6193,-6189,-6186,-6182,-6178,-6174,-6170,-6167,-6163 dd -6159,-6155,-6151,-6147,-6143,-6139,-6135,-6131,-6127,-6123 dd -6119,-6115,-6110,-6106,-6102,-6098,-6094,-6090,-6085,-6081 dd -6077,-6073,-6068,-6064,-6060,-6055,-6051,-6046,-6042,-6037 dd -6033,-6029,-6024,-6020,-6015,-6010,-6006,-6001,-5997,-5992 dd -5987,-5983,-5978,-5973,-5969,-5964,-5959,-5954,-5950,-5945 dd -5940,-5935,-5930,-5925,-5921,-5916,-5911,-5906,-5901,-5896 dd -5891,-5886,-5881,-5876,-5871,-5865,-5860,-5855,-5850,-5845 dd -5840,-5835,-5829,-5824,-5819,-5814,-5808,-5803,-5798,-5792 dd -5787,-5782,-5776,-5771,-5765,-5760,-5754,-5749,-5743,-5738 dd -5732,-5727,-5721,-5716,-5710,-5704,-5699,-5693,-5687,-5682 dd -5676,-5670,-5665,-5659,-5653,-5647,-5641,-5636,-5630,-5624 dd -5618,-5612,-5606,-5600,-5594,-5588,-5582,-5576,-5570,-5564 dd -5558,-5552,-5546,-5540,-5534,-5528,-5522,-5515,-5509,-5503 dd -5497,-5490,-5484,-5478,-5472,-5465,-5459,-5453,-5446,-5440 dd -5434,-5427,-5421,-5414,-5408,-5401,-5395,-5388,-5382,-5375 dd -5369,-5362,-5356,-5349,-5342,-5336,-5329,-5322,-5316,-5309 dd -5302,-5296,-5289,-5282,-5275,-5269,-5262,-5255,-5248,-5241 dd -5234,-5227,-5221,-5214,-5207,-5200,-5193,-5186,-5179,-5172 dd -5165,-5158,-5151,-5144,-5136,-5129,-5122,-5115,-5108,-5101 dd -5094,-5086,-5079,-5072,-5065,-5057,-5050,-5043,-5035,-5028 dd -5021,-5013,-5006,-4999,-4991,-4984,-4976,-4969,-4961,-4954 dd -4946,-4939,-4931,-4924,-4916,-4909,-4901,-4894,-4886,-4878 dd -4871,-4863,-4855,-4848,-4840,-4832,-4825,-4817,-4809,-4801 dd -4793,-4786,-4778,-4770,-4762,-4754,-4746,-4738,-4731,-4723 dd -4715,-4707,-4699,-4691,-4683,-4675,-4667,-4659,-4651,-4643 dd -4635,-4626,-4618,-4610,-4602,-4594,-4586,-4578,-4569,-4561 dd -4553,-4545,-4536,-4528,-4520,-4512,-4503,-4495,-4487,-4478 dd -4470,-4462,-4453,-4445,-4436,-4428,-4420,-4411,-4403,-4394 dd -4386,-4377,-4369,-4360,-4352,-4343,-4334,-4326,-4317,-4309 dd -4300,-4291,-4283,-4274,-4265,-4257,-4248,-4239,-4231,-4222 dd -4213,-4204,-4195,-4187,-4178,-4169,-4160,-4151,-4143,-4134 dd -4125,-4116,-4107,-4098,-4089,-4080,-4071,-4062,-4053,-4044 dd -4035,-4026,-4017,-4008,-3999,-3990,-3981,-3972,-3963,-3954 dd -3944,-3935,-3926,-3917,-3908,-3899,-3889,-3880,-3871,-3862 dd -3853,-3843,-3834,-3825,-3815,-3806,-3797,-3787,-3778,-3769 dd -3759,-3750,-3741,-3731,-3722,-3712,-3703,-3694,-3684,-3675 dd -3665,-3656,-3646,-3637,-3627,-3618,-3608,-3599,-3589,-3579 dd -3570,-3560,-3551,-3541,-3531,-3522,-3512,-3502,-3493,-3483 dd -3473,-3464,-3454,-3444,-3434,-3425,-3415,-3405,-3395,-3386 dd -3376,-3366,-3356,-3346,-3337,-3327,-3317,-3307,-3297,-3287 dd -3277,-3267,-3257,-3247,-3238,-3228,-3218,-3208,-3198,-3188 dd -3178,-3168,-3158,-3148,-3138,-3128,-3118,-3107,-3097,-3087 dd -3077,-3067,-3057,-3047,-3037,-3027,-3016,-3006,-2996,-2986 dd -2976,-2966,-2955,-2945,-2935,-2925,-2914,-2904,-2894,-2884 dd -2873,-2863,-2853,-2842,-2832,-2822,-2812,-2801,-2791,-2780 dd -2770,-2760,-2749,-2739,-2729,-2718,-2708,-2697,-2687,-2676 dd -2666,-2656,-2645,-2635,-2624,-2614,-2603,-2593,-2582,-2572 dd -2561,-2551,-2540,-2530,-2519,-2508,-2498,-2487,-2477,-2466 dd -2455,-2445,-2434,-2424,-2413,-2402,-2392,-2381,-2370,-2360 dd -2349,-2338,-2328,-2317,-2306,-2296,-2285,-2274,-2263,-2253 dd -2242,-2231,-2220,-2210,-2199,-2188,-2177,-2167,-2156,-2145 dd -2134,-2123,-2112,-2102,-2091,-2080,-2069,-2058,-2047,-2037 dd -2026,-2015,-2004,-1993,-1982,-1971,-1960,-1949,-1938,-1927 dd -1917,-1906,-1895,-1884,-1873,-1862,-1851,-1840,-1829,-1818 dd -1807,-1796,-1785,-1774,-1763,-1752,-1741,-1730,-1719,-1708 dd -1697,-1686,-1675,-1664,-1652,-1641,-1630,-1619,-1608,-1597 dd -1586,-1575,-1564,-1553,-1542,-1530,-1519,-1508,-1497,-1486 dd -1475,-1464,-1452,-1441,-1430,-1419,-1408,-1397,-1385,-1374 dd -1363,-1352,-1341,-1329,-1318,-1307,-1296,-1285,-1273,-1262 dd -1251,-1240,-1229,-1217,-1206,-1195,-1184,-1172,-1161,-1150 dd -1139,-1127,-1116,-1105,-1093,-1082,-1071,-1060,-1048,-1037 dd -1026,-1014,-1003,-992,-980,-969,-958,-947,-935,-924 dd -913,-901,-890,-879,-867,-856,-845,-833,-822,-811 dd -799,-788,-776,-765,-754,-742,-731,-720,-708,-697 dd -686,-674,-663,-651,-640,-629,-617,-606,-594,-583 dd -572,-560,-549,-537,-526,-515,-503,-492,-480,-469 dd -458,-446,-435,-423,-412,-401,-389,-378,-366,-355 dd -343,-332,-321,-309,-298,-286,-275,-264,-252,-241 dd -229,-218,-206,-195,-183,-172,-161,-149,-138,-126 dd -115,-103,-92,-81,-69,-58,-46,-35,-23,-12 eosinus: ; misc vars for mouse / keys: wonder: dd 7777 dududu: dd 0 rendered_quads: dd 0 sorted_quads: dd 0 vxx: dd 0 mouseya: dd 0 vpx: dd 0 vpy: dd 0 vheading: dd 0 wtolong: dw 0,0 ; misc Engine Vars -------------------------- imgtxt: dd 0 mousex: dd 0 mousey: dd 0 factor: dd 0 i: dd 0 miny: dd 0 maxy: dd 0 pwidth: dd 0 pheight: dd 0 ;anz: ; dd 0 a: dd 0 alpha: dd 0 beta: dd 0 gamma: dd 0 zoom: dd 0 zwmax: dd 0 i2: dd 0 x1: dd 0 y1: dd 0 x2: dd 0 y2: dd 0 count: dd 0 ilocal: dd 0 ycoord: dd 0 pside: dd 0 temp: dd 0 lineheight: dd 0 linewidth: dd 0 v_xadd: dd 0 pxadd: dd 0 pyadd: dd 0 ytop: dd 0 ytopy: dd 0 px: dd 0 py: dd 0 x: dd 0 y: dd 0 polyx1: dd 0 polyx2: dd 0 px1: dd 0 py1: dd 0 px2: dd 0 py2: dd 0 remeax: dd 0 remebx: dd 0 remecx: dd 0 remedx: dd 0 remedi: dd 0 remesi: dd 0 singamma: dd 0 sinbeta: dd 0 sinalpha: dd 0 alphacopy: dd 0 betacopy: dd 0 gammacopy: dd 0 ;;fixed size arrays -------------------- lefttable: times 1920*2 dd 0 ; 1440 righttable: times 1920*2 dd 0 polypoints: times 12 dd 0 ; 8 zbuffer: times 10010 dd 0 ; 10000 ; floating vars ------------------------ twohundred: dd 200 mausy: dd 0 xl1: dd 0 yl1: dd 0 zl1: dd 0 xl2: dd 0 yl2: dd 0 zl2: dd 0 xl3: dd 0 yl3: dd 0 zl3: dd 0 xloc: dd 0 yloc: dd 0 tempdiv: dd 0 tex1: ; the texture ( dd 0xRRGGBB,0xRRGGBB... 64*64*32 Bit) include "wall3.inc" labelt: db 'MOS3DE',0 labellen: I_END: