|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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。这样显存完整的偏移地址就是行数的偏移地址加上列的偏移地址。
|
|