鱼C论坛

 找回密码
 立即注册
查看: 2132|回复: 0

[汇编作业] 实验九实现

[复制链接]
发表于 2019-1-16 16:12:54 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-24 11:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表