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;
posted @ 2023-03-02 21:45  浩泽郎  阅读(26)  评论(0编辑  收藏  举报