鱼C论坛

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

[技术交流] 实验十第一题。分享给大家。

[复制链接]
发表于 2011-7-11 10:14:54 | 显示全部楼层 |阅读模式

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

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

x
assume cs:code 

data segment
db'wlecome to masm!',0
data ends ;定义数据段

code segment ;定义代码段
start: mov dh,8
mov dl,3
mov cl,2
mov ax,data
mov ds,ax
mov si,0
call show_str

mov ax,4c00h
int 21h

show_str: push dx
push cx ;将dx,cx入栈。保存。以免破坏掉主程序的数据。
mov ax,0b800h
mov es,ax ;定义显存段的段地址。

mov al,160
mov ah,00h
mul dh ;行与显存行数的对应关系为x=y*160,计算某一行需要将行号*160转化为
;显存中的行号。
mov bx,ax ;将行数偏移存入bx中。

mov al,2
mov ah,00h
mul dl
mov di,ax ;用di存放列数偏移。

mov al,cl ;用al存放颜色。
s: mov cx,ds:[si]
jcxz ok
mov ah,ds:[si]
mov es:[bx+di],ah ;高位是要输出字符的ascii码。
mov es:[bx+di+1],al ;将颜色码放入下个字节单元中。
inc si
add di,2
jmp s

ok: pop cx
pop dx
ret ;返回

code ends
end start
这个题目的关键在于,如何将行数,列数与显存的行数列数联系起来。我在网上找了一些资料。才搞明白。显存的行数=行数*160
因为80*25色一行是160个字节。一共25列。比如说第5行第3列。5*160就是显存行数的偏移地址。每两列第一个存放字符的ASCII码,第二列存放颜色的代码。把两个字节看成一列。列的对应关系就是3*2。这样显存完整的偏移地址就是行数的偏移地址加上列的偏移地址。

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-11-19 00:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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