亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? xpbmclip.asm

?? 視頻游戲開發C語言源程序
?? ASM
?? 第 1 頁 / 共 3 頁
字號:
;-----------------------------------------------------------------------
; MODULE XPBMCLIP
;
; Clipped Planar Bitmap functions - System Ram <-> Video Ram
;
; Compile with Tasm.
; C callable.
;
;
; ****** XLIB - Mode X graphics library                ****************
; ******                                               ****************
; ****** Written By Themie Gouthas                     ****************
;
; egg@dstos3.dsto.gov.au
; teg@bart.dsto.gov.au
;-----------------------------------------------------------------------


COMMENT $

  This module implements a set of functions to operate on planar bitmaps.
  Planar bitmaps as used by these functions have the following structure:

  BYTE 0                 The bitmap width in bytes (4 pixel groups) range 1..255
  BYTE 1                 The bitmap height in rows range 1..255
  BYTE 2..n1             The plane 0 pixels width*height bytes
  BYTE n1..n2            The plane 1 pixels width*height bytes
  BYTE n2..n3            The plane 2 pixels width*height bytes
  BYTE n3..n4            The plane 3 pixels width*height bytes

  These functions provide the fastest possible bitmap blts from system ram to
  to video and further, the single bitmap is applicable to all pixel
  allignments. The masked functions do not need separate masks since all non
  zero pixels are considered to be masking pixels, hence if a pixel is 0 the
  corresponding screen destination pixel is left unchanged.


$
LOCALS
include xlib.inc
include xpbmclip.inc

	.code

;----------------------------------------------------------------------
; x_put_masked_pbm_clipx - mask write a planar bitmap from system ram to video
;			ram all zero source bitmap bytes indicate destination
;			byte to be left unchanged.
;                       Performs clipping in x directions. similar to
;		        "x_put_masked_pbm".
;
; See Also:  x_put_masked_pbm, x_put_masked_pbm_clipxy
;
; Clipping region variables: LeftClip,RightClip
;
; Written by Themie Gouthas
;
; This code is a SLOW hack, any better ideas are welcome
;----------------------------------------------------------------------
_x_put_masked_pbm_clipx  proc
ARG X:word,Y:word,ScrnOffs:word,Bitmap:dword
LOCAL   Plane:byte,CType,LeftSkip,DataInc,Width,Height,TopRow,LineInc:word=LocalStk
	push  bp
        mov   bp,sp
	sub   sp,LocalStk                 ; Create space for local variables
        push  si
        push  di
        push  ds
	cld

	les   si,[Bitmap]                 ; Point ES:SI to start of bitmap

	xor   ax,ax                       ; Clear AX
	mov   [CType],ax                  ; Clear Clip type descision var
	mov   al,byte ptr es:[si]         ; AX=width (byte coverted to word)


	mov   di,[X]                      ; DI = X coordinate of dest
	mov   cx,di                       ; copy to CX
	sar   di,2                        ; convert to offset in row


	;;;;; CLIP PROCESSING FOR LEFT CLIP BORDER ;;;;;;;;;;;;;;;;;;;

	mov   dx,[_LeftClip]              ; Is X Coord to the right of
	sub   dx,di                       ; LeftClip ?
	jle   @@NotLeftClip               ; Yes! => no left clipping
	cmp   dx,ax                       ; Is dist of X Coord from
	jnl   @@NotVisible                ; ClipLeft > Width ? yes => the
					  ; bitmap is not visible
	add   di,dx
	mov   [LeftSkip],dx
	mov   [DataInc],dx
	sub   ax,dx
	mov   [CType],1
	jmp   short @@HorizClipDone

	;;;; EXIT FOR COMPLETELY OBSCURED P.B.M's ;;;;;;;;;;;;;;;;;;;;;;

@@NotVisible:
	mov   ax,1
	pop   ds                          ; restore data segment
	pop   di                          ; restore registers
	pop   si
	mov   sp,bp                       ; dealloc local variables
	pop   bp
	ret

	;;;;; CLIP PROCESSING FOR RIGHT CLIP BORDER ;;;;;;;;;;;;;;;;;;;

@@NotLeftClip:
	mov   dx,[_RightClip]
	sub   dx,di
	js    @@NotVisible
	mov   [LeftSkip],0
	mov   [DataInc],0
	cmp   dx,ax
	jge   @@HorizClipDone       ; was jg
	inc   dx
	sub   ax,dx
	mov   [DataInc],ax
	mov   ax,dx
	mov   [CType],-1

@@HorizClipDone:

	xor   bh,bh
	mov   bl,byte ptr es:[si+1]       ; BX = height

	mov   [Width],ax                  ; Save width and height of clipped
	mov   [Height],bx                 ;  image


	add   si,2                        ; Skip dimension bytes in source
	add   si,[LeftSkip]               ; Skip pixels in front of row that
					  ;  are clipped


	mov   bx,[_ScrnLogicalByteWidth]  ; Set BX to Logical Screen Width
	mov   dx,bx                       ; BX - Width of image = No. bytes
	sub   dx,ax                       ;  to first byte of next screen
	mov   [LineInc],dx                ;  row.

	mov   ax,[Y]                      ; Calculate screen start row
	mul   bx                          ;  then adding screen offset
	add   di,ax
	add   di,[ScrnOffs]
	mov   ax,es                       ; copy ES to DS
	mov   ds,ax
	mov   ax,SCREEN_SEG               ; Point ES to VGA segment
	mov   es,ax

	and   cx,3
	mov   ah,11h                      ; Set up initial plane mask
	shl   ah,cl

	mov   dx,SC_INDEX                 ; Prepare VGA for cpu to video writes
	mov   al,MAP_MASK
	out   dx,al
	inc   dx
	mov   [Plane],4                   ; Set plane counter to 4
	mov   bh,byte ptr [Width]         ; set bh to width for fast looping
@@PlaneLoop:
	push  di 			  ; Save bitmap's start dest. offset
	mov   bl,byte ptr [Height]        ; Reset row counter (BL)
	mov   al,ah
	out   dx,al                       ; set vga write plane
@@RowLoop:
	mov   cl,bh                       ; Reset Column counter cl
	jcxz  @@NoWidth
@@ColLoop:
	lodsb        		          ; Get next source bitmap byte
	or    al,al                       ; If not zero then write to dest.
	jz    @@NoPixel                   ; otherwise skip to next byte
	mov   es:[di],al
@@NoPixel:
	inc   di
	loop @@ColLoop
@@NoWidth:
	add   si,[DataInc]                ; Move to next source row
	add   di,[LineInc]                ; Move to next screen row
	dec   bl                          ; decrement row counter
	jnz   @@RowLoop                   ; Jump if more rows left
	pop   di                          ; Restore bitmaps start dest byte
	rol   ah,1		          ; Shift mask for next plane

	; Plane Transition (A HACK but it works!)

	jnb   @@Nocarry                   ; Jump if not plane transition
	mov   bl,ah                       ; Save Plane Mask
	mov   ax,[CType]                  ; set AX to clip type inc variable
	add   bh,al                       ; Update advancing variables
	sub   [DataInc],ax                ;
	sub   [LineInc],ax                ;
	cmp   al,0                        ; What type of clip do we have
	mov   ah,bl                       ;   restore Plane mask
	jg    @@RightAdvance              ; jump on a right clip!
	inc   di                          ; otherwise increment DI
	jmp   @@Nocarry
@@RightAdvance:
	dec si
@@Nocarry:
	dec   [Plane]                     ; Decrement plane counter
	jnz   @@PlaneLoop                 ; Jump if more planes left

	xor   ax,ax
	pop   ds                          ; restore data segment
	pop   di                          ; restore registers
	pop   si
	mov   sp,bp                       ; dealloc local variables
	pop   bp
	ret
_x_put_masked_pbm_clipx  endp


;----------------------------------------------------------------------
; x_put_masked_pbm_clipy - mask write a planar bitmap from system ram to video
;			ram all zero source bitmap bytes indicate destination
;			byte to be left unchanged.
;                       Performs clipping in y direction. similar to
;		        "x_put_masked_pbm".
;
; See Also:  x_put_masked_pbm, x_put_masked_pbm_clipx, x_put_masked_pbm_clipy
;
; Clipping region variables: TopClip,BottomClip
;
; Written by Themie Gouthas
;----------------------------------------------------------------------
_x_put_masked_pbm_clipy  proc
ARG X:word,Y:word,ScrnOffs:word,Bitmap:dword
LOCAL   Width,Height,TopRow,LineInc,PlaneInc:word=LocalStk
	push  bp
	mov   bp,sp
	sub   sp,LocalStk                 ; Create space for local variables
	push  si
	push  di
	push  ds
	cld

	les   si,[Bitmap]

	xor   bh,bh
	mov   bl,byte ptr es:[si+1]       ; BX = height

	xor   ah,ah
	mov   al,byte ptr es:[si]         ; AX = width

	mov   cx,ax                       ; Save AX
	mul   bx                          ; AX = AX*BX = bytes/plane
	mov   [PlaneInc],ax               ;  save as PlaneInc
	mov   ax,cx                       ; Restore AX

	mov   di,[X]
	mov   cx,di
	shr   di,2

	;;;;; CLIP PROCESSING FOR TOP CLIP BORDER ;;;;;;;;;;;;;;;;;;;;;

	mov   dx,[_TopClip]           ; Compare u.l. Y coord with Top
	sub   dx,[Y]                  ; clipping border
	jle   @@NotTopClip            ; jump if VBM not clipped from above
	cmp   dx,bx
	jnl   @@NotVisible            ; jump if VBM is completely obscured
	mov   [TopRow],dx
	sub   bx,dx
	add   [Y],dx
	jmp   short @@VertClipDone

	;;;; EXIT FOR COMPLETELY OBSCURED P.B.M's ;;;;;;;;;;;;;;;;;;;;;;

@@NotVisible:
	mov   ax,1
	pop   ds                          ; restore data segment
	pop   di                          ; restore registers
	pop   si
	mov   sp,bp                       ; dealloc local variables
	pop   bp
	ret

	;;;;; CLIP PROCESSING FOR BOTTOM CLIP BORDER ;;;;;;;;;;;;;;;;;;;

@@NotTopClip:
	mov   dx,[_BottomClip]
	sub   dx,[Y]
	js    @@NotVisible
	mov   [TopRow],0
	cmp   dx,bx
	jg    @@VertClipDone
	inc   dx
	mov   bx,dx

@@VertClipDone:

	mov   [Width],ax
	mov   [Height],bx                 ; Calculate relative offset in data
	mul   [TopRow]                    ;  of first visible scanline
	add   ax,2                        ; Skip dimension bytes in source
	add   si,ax                       ; Skip top rows that arent visible


	mov   ax,[Y]                      ; Calculate screen row
	mov   bx,[_ScrnLogicalByteWidth]  ;  by mult. Y coord by Screen
	mul   bx                          ;  width then adding screen offset
	add   di,ax
	add   di,[ScrnOffs]
	sub   bx,[Width]                  ; calculate difference from end of
	mov   [LineInc],bx                ; b.m. in curr line to beginning of
					  ; b.m. on next scan line
	mov   ax,es                       ; copy ES to DS
	mov   ds,ax
	mov   ax,SCREEN_SEG               ; Point ES to VGA segment
	mov   es,ax

	mov   ah,11h                      ; Set up initial plane mask
	and   cx,3
	shl   ah,cl

	mov   dx,SC_INDEX                 ; Prepare VGA for cpu to video writes
	mov   al,MAP_MASK
	out   dx,al
	inc   dx
	mov   bh,4                        ; Set plane counter to 4
@@PlaneLoop:
	push  di 			  ; Save bitmap's start dest. offset
	push  si                          ; Save Bitmaps data offset
	mov   bl,byte ptr [Height]        ; Reset row counter (BL)
	mov   al,ah
	out   dx,al                       ; set vga write plane
@@RowLoop:
	mov   cl,byte ptr [Width]         ; Reset Column counter cl
@@ColLoop:
	lodsb                             ; Get next source bitmap byte
	or    al,al                       ; If not zero then write to dest.
	jz    @@NoPixel                   ; otherwise skip to next byte
	mov   es:[di],al
@@NoPixel:
	inc   di
	loop  @@ColLoop                   ; loop if more columns left
	add   di,[LineInc]                ; Move to next row
	dec   bl                          ; decrement row counter
	jnz   @@RowLoop                   ; Jump if more rows left
	pop   si                          ; Restore SI and set to offset of
	add   si,[PlaneInc]               ; first vis pixel in next plane data
	pop   di                          ; Restore bitmaps start dest byte
	rol   ah,1                        ; Shift mask for next plane
	adc   di,0                        ; if carry increment screen offset
	dec   bh                          ; Decrement plane counter
	jnz   @@PlaneLoop                 ; Jump if more planes left

	xor   ax,ax
	pop   ds                          ; restore data segment
	pop   di                          ; restore registers
	pop   si
	mov   sp,bp                       ; dealloc local variables
	pop   bp
	ret
_x_put_masked_pbm_clipy   endp

;----------------------------------------------------------------------
; x_put_masked_pbm_clipxy - Write a planar bitmap from system ram to video

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区高清免费观看影视大全| 欧美变态tickling挠脚心| 精品一区二区三区久久| 亚洲日本欧美天堂| 中文字幕中文在线不卡住| 日韩限制级电影在线观看| 日本韩国精品在线| 成人av网站在线观看免费| 久久99精品国产.久久久久久| 一区二区不卡在线播放 | 久久婷婷久久一区二区三区| 欧美艳星brazzers| 在线一区二区三区四区五区 | 最新热久久免费视频| 中文字幕 久热精品 视频在线 | 国产一区二区三区在线观看精品 | 亚洲欧美日韩久久| 亚洲乱码国产乱码精品精的特点 | 亚洲国产精品久久久久秋霞影院| 最新久久zyz资源站| 亚洲人精品午夜| 一区二区三区免费在线观看| 中文字幕在线观看不卡| 中文字幕中文乱码欧美一区二区| 国产精品视频在线看| 国产精品久久久久四虎| 亚洲狼人国产精品| 午夜精品123| 国产麻豆精品theporn| 国产成人精品影视| 色丁香久综合在线久综合在线观看| 91农村精品一区二区在线| 欧美日韩精品免费| 久久精品无码一区二区三区| 亚洲老司机在线| 久久69国产一区二区蜜臀| 成人中文字幕电影| 欧美久久久久久久久中文字幕| 精品欧美一区二区三区精品久久| 中文一区二区完整视频在线观看| 亚洲女人****多毛耸耸8| 日韩av高清在线观看| 丁香网亚洲国际| 欧美一区在线视频| 中文av一区二区| 午夜精品久久久| 成人99免费视频| av一区二区三区黑人| 欧美日韩视频一区二区| 久久久精品影视| 久久精品国产久精国产爱| 色综合色综合色综合色综合色综合 | 精品一区二区在线播放| 91成人在线观看喷潮| 久久综合久久综合亚洲| 亚洲成人1区2区| 91在线观看下载| 国产日韩视频一区二区三区| 日本不卡的三区四区五区| 91啪在线观看| 中文字幕在线不卡视频| 高清不卡一二三区| 久久久亚洲精品石原莉奈 | 久久久一区二区三区捆绑**| 亚洲第一成年网| 欧美日韩视频第一区| 亚洲欧美国产毛片在线| 91丝袜高跟美女视频| 亚洲欧美日韩一区二区三区在线观看| 国产成人亚洲精品青草天美| 久久久欧美精品sm网站| 国产99久久久国产精品免费看| 欧美成人性福生活免费看| 久国产精品韩国三级视频| 欧美一级片免费看| 欧美aaa在线| 久久在线观看免费| 成人免费观看视频| 亚洲日本欧美天堂| 欧美日本在线视频| 国产在线不卡一区| 日韩一区在线播放| 国产乱理伦片在线观看夜一区| 粉嫩av亚洲一区二区图片| 国产欧美一区二区精品性色| 一区二区三区日韩欧美精品| 91福利小视频| 久久99日本精品| 97se狠狠狠综合亚洲狠狠| 天天免费综合色| 国产欧美日韩一区二区三区在线观看| 色婷婷久久久综合中文字幕 | 色猫猫国产区一区二在线视频| 亚洲成a人v欧美综合天堂下载 | 五月婷婷激情综合| 国产欧美日韩精品a在线观看| 欧美欧美欧美欧美首页| 一区二区三区精品在线观看| 欧美色涩在线第一页| 国产精品69毛片高清亚洲| 亚洲在线视频一区| 日韩美女啊v在线免费观看| 精品国产亚洲在线| 91精品国产aⅴ一区二区| 91免费视频观看| 成人成人成人在线视频| 日韩在线卡一卡二| 久久国产麻豆精品| 日韩黄色免费电影| 亚洲成a人片在线不卡一二三区 | 亚洲一区视频在线| 综合久久久久久| 日本一区二区三区视频视频| 26uuu精品一区二区在线观看| 欧美一区二区啪啪| 欧美一区永久视频免费观看| 欧美一二区视频| 欧美高清hd18日本| 日韩免费看的电影| 久久只精品国产| 日本一区二区三区国色天香| 国产嫩草影院久久久久| 国产成人免费视频精品含羞草妖精| 欧美日韩国产bt| 欧美一区二区三区爱爱| 日韩三级.com| 精品精品欲导航| www激情久久| 国产精品国产三级国产专播品爱网| 国产精品欧美一级免费| 一区二区三区 在线观看视频| 亚洲欧美日韩久久| 亚洲一二三区不卡| 美国一区二区三区在线播放| 国产一区二区三区| 99re成人在线| 欧美剧情片在线观看| 久久蜜桃av一区精品变态类天堂| 国产欧美综合在线| 香港成人在线视频| 成人激情午夜影院| 欧美日韩国产片| 国产精品你懂的| 日本特黄久久久高潮| 97国产一区二区| 精品国产三级a在线观看| 国产超碰在线一区| 国产精品一区专区| 欧洲一区在线观看| 国产精品素人一区二区| 免费黄网站欧美| 日本道精品一区二区三区| 久久精品人人做人人综合 | 91麻豆视频网站| 日韩一区二区视频| 亚洲国产成人91porn| 免费不卡在线视频| 日本高清不卡视频| 久久久久久久久一| 精品一区二区三区免费视频| 欧美精品欧美精品系列| 国产精品动漫网站| 99视频国产精品| 中文字幕中文字幕在线一区| 麻豆视频观看网址久久| 欧美精选一区二区| 天堂成人免费av电影一区| 欧美性受极品xxxx喷水| 一区二区三区自拍| 欧美性猛交xxxxxx富婆| 亚洲精品视频在线看| 在线免费视频一区二区| 中文字幕国产一区二区| 五月激情综合网| 日韩视频一区二区三区 | 久久久久国产精品麻豆ai换脸| 久久精品国产亚洲a| 精品久久久网站| av亚洲产国偷v产偷v自拍| 亚洲色图色小说| 51午夜精品国产| 国产一区二区三区日韩| 自拍偷拍亚洲综合| 欧美日韩免费电影| 国内精品视频666| 亚洲欧美成人一区二区三区| 欧美人妖巨大在线| 国产一区二区三区美女| 亚洲男人的天堂网| 日韩一区二区不卡| 成人影视亚洲图片在线| 亚洲国产精品影院| 欧美大黄免费观看| 91电影在线观看| 国产呦萝稀缺另类资源| 亚洲一区二区三区中文字幕| 国产日韩av一区| 欧美一区三区二区| 99精品久久久久久| 国产精品99久|