11.1/2 鼠标显示问题(harib08a)11.2 实现画面外的支持(harib08b)
ps:能力有限,若有错误及纰漏欢迎指正、交流
- 11.1 鼠标显示问题(harib08a)
存在问题:
在harib07d中鼠标移动到最右侧后就不能再往右移了
解决办法:
将
if (mx > binfo->scrnx - 16) {
mx = binfo->scrnx - 16;
}
if (my > binfo->scrny - 16) {
my = binfo->scrny - 16;
}
修改为:
if (mx > binfo->scrnx - 1) {
mx = binfo->scrnx - 1;
}
if (my > binfo->scrny - 1) {
my = binfo->scrny - 1;
}
又出现以下问题:
图 11.1.1
- 11.2 实现画面外的支持(harib08b)
那么,为什么会画到另一边去呢,原因在于:VRAM的存储方式。由harib08a的代码,增大了mx,my的范围,使得鼠标所在的图层超出了屏幕,但sheet_refreshsub的代码决定它不会有 越界判断,而VRAM是一个一维数组,这会导致图像被写入“下一行屏幕”,即超出了改行在 一维数组中的范围。如图11.2.1
图11.2.1
经过上面的理解,便可得到下面的改进办法,即书中给出的
解决办法:
- 只有 sheet_refreshsub 是把图层内容写入VRAM,故可增加 检测,使其不会绘制超出画面的区域
void sheet_refreshsub(struct SHTCTL *ctl, int vx0, int vy0, int vx1, int vy1)
{
int h, bx, by, vx, vy, bx0, by0, bx1, by1;
unsigned char *buf, c, *vram = ctl->vram;
struct SHEET *sht;
/* 如果refresh的范围超出了画面则修正 */
if (vx0 < 0) { vx0 = 0; }
if (vy0 < 0) { vy0 = 0; }
if (vx1 > ctl->xsize) { vx1 = ctl->xsize; }
if (vy1 > ctl->ysize) { vy1 = ctl->ysize; }
for (h = 0; h <= ctl->top; h++) {
(中略)
}
return;