|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
以下为使用4个寄存器,两个循环的实现方式;因为文本与颜色的循环次数不一样,所以便用了2个寄存器;然后目的显存的定位也用了两个寄存器,一个定位行,一个定位列;犹如在一个平面坐标系中,x、y的值能定位坐标系中的精确点。初学者初步实现,还请各位大哥多多指教;以下为代码:- assume cs:codesg,ds:datasg,ss:stacksg
- datasg segment
- db 'welcome to masm!'
- db 02h,24h,71h
- datasg ends
- stacksg segment
- dw 8 dup(0)
- stacksg ends
- codesg segment
- start:
- mov ax, datasg
- mov ds, ax
- mov ax, stacksg
- mov ss, ax
- mov ax, 0b872h ;定位第12行中间位置
- mov es, ax
- mov sp, 10h
- mov di, 10h ;di寄存器用作颜色的索引,不用16[bx]作为颜色索引,是因为颜色只需循环3次;而[bx]作为文本索引需循环16次
- mov bp, 0 ;bp用于定位目的显存位置每行的第一个地址
- mov cx ,3 ;行数循环3次(三行)
- s1:
- push cx ;推入栈,避免被里层循环cx覆盖
- mov si, 0 ;si用于定位目的显存位置每行中的行内地址,每一行循环完后重置;bp+si便能实现目的显存地址的精确定位;
- mov bx, 0 ;每一行循环完之后,bx都需进行重置
- mov cx, 16
- s2:
- mov al, [bx]
- mov es:[bp+si], al ;将文本覆盖至目的显存位置
- inc si ;si+1,显存下一位置为颜色属性位置
- mov al, ds:[di]
- mov es:[bp+si], al ;将颜色属性覆盖至目的显存位置
- inc si ;si+1,下一次循环又是文本覆盖
- inc bx ;准备索引下一文本
- loop s2
- add bp,160 ;目的显存位置换行
- inc di ;下一颜色属性
- pop cx ;取出栈中cx外层循环
- loop s1
- mov ax, 4c00h
- int 21h
- codesg ends
- end start
复制代码
|
|