暑假学习小日本的那本书:30天自制操作系统

qq交流群:122358078    ,更多学习中的问题、资料,群里分享

environment:开发环境:ubuntu

第八天的学习思考:

关于鼠标是怎么移动怎来的 思考过程。
现在忘掉作者的代码思路,如果是我们自己写代码,鼠标指针应该怎么样才能动起来呢?
我的思路:
其实让鼠标指针动起来真的非常简单,只需要改变下面函数中的mx,my变量,也就是鼠标的position变量,鼠标指针就会移动了。但是在移动前一定要把原来鼠标指针出现的位置填充为背景
色,这样就不出现鼠标移动的轨迹了。

display_mouse(bootp->vram,bootp->xsize,16,16,mx,my,mousepic,16);

这个函数就可以把鼠标原来出现过的地方填充为背景色,白色。
 boxfill(white,mx,my,mx+15,my+15);

我们可以写这样的函数:
for(i=0;i++;i<8)
{
display_mouse(bootp->vram,bootp->xsize,16,16,mx,my,mousepic,16);
sleep(1);/sleep 1 second
boxfill(white,mx,my,mx+15,my+15);
mx=mx+15;
}

//上面的函数就会使 鼠标的函数指针每过1s,就在x方向移动15个像素点

所以移动鼠标的基本思想就是 1:用背景色把原来鼠标出现过的位置填充掉
                                                2:改变mx,my(就是表示鼠标位置的变量),然后用display_mouse(bootp->vram,bootp->xsize,16,16,mx,my,mousepic,16);函数重新显示鼠标指针

但是现在有个难点就是我们手上的硬件左移时,怎么得到左移这个变量,然后把这个变量反应到mx变化上面。

当我们手上的鼠标移动时,会产生中断,然后我们从中断服务程序中得到鼠标硬件产生的数据,鼠标比较特别,需要从三个中断服务程序中得三个有效的数据,才能正确的反应出鼠标当前的位置信息。

当我们用某种方法得到三个字节的鼠标信息后(保存在buffer[0],buffer[1],buffer[2]),只要对这三个字节的内容进行正确的解读,就能得到鼠标是否有左右键按下,是向哪个方向移动了。

对于buffer[0] 低4位主要反应按键 按下情况:0:no key press     1:left key press     2:right key press

3:both left right key press     4:middle key press
                     高4位中低2位与x,y的移动方向有关,当bit4为1时,表示鼠标向-x方向移动,当bit5为1时表示鼠标向-y方向移动

对于buffer[1]就是包含了在x方向上移动的增量,移动的快,这个增量就大,移动慢,这个增量就小.一定注意这是一个增量。例如:当buffer[1]=4时,表示在x方向移动的速度增量只有4,再结合buffer[0]的bit4位,就可以知道是向x正方向移动(bit4=0),还是x负方向移动(bit4=1)

对于buffer[2]就是包含了在y方向上移动的增量,移动的快,这个增量就大,移动慢,这个增量就小.一定注意这是一个增量。

所以只需要把有方向量的buffer[1]增量,加在mx上;mx=mx+buffer[1](mx=mx+dx),就可以根据硬件上鼠标的移动,来反应到屏幕上鼠标指针位置的改变。

这样就把从三个中断服务程序中,硬件鼠标得到三个字节的数据buffer[0],buffer[1],buffer[2] 与 屏幕上鼠标指针位置mx,my联系起来,每次根据新的mx,my重绘鼠标指针之前,需要把原来鼠标出现的位置填充为背景色,以免出现鼠标运行的轨迹。

整个思路有了,就是程序上如何实现了。

mouse_decode(struct MOUSE_DEC *mdec,unsigned char data)这个函数就是从得到三个字节数据中解读出dx,dy 还有button的情况。
 
 下面的几个if判断完全是为了防止鼠标指针跑出了屏幕的边界。
       if(mx<0)
          {
        mx=0;
          }
          if(my<0)
          {
        my=0;
          }
          
          
          if(mx>bootp->xsize-16)
          {
        mx=bootp->xsize-16;
          }
          
          if(my>bootp->ysize-16)
          {
        my=bootp->ysize-16;
          }
 
 
//其它的部分也就顺理成章了。

代码下载页面:http://download.csdn.net/detail/h397916230/5996057

从u盘启动后移动鼠标指针图片:


30天自制操作系统第八天学习笔记(u盘软盘双启动版本)的更多相关文章

  1. 30天自制操作系统第九天学习笔记(u盘软盘双启动版本)

    暑假学习小日本的那本书:30天自制操作系统 qq交流群:122358078    ,更多学习中的问题.资料,群里分享 environment:开发环境:ubuntu 第九天的课程已学完,确实有点不想写 ...

  2. 《30天自制操作系统》19_day_学习笔记

    harib16a: 这一部分,我们在系统中实现读取文件内容的命令type.在windows中,输入“type 文件名”,在Linux中,输入“cat 文件名”都可以显示文件的内容.我们先来看看如何读取 ...

  3. 《30天自制操作系统》12_day_学习笔记

    harib09a: 定时器:(Timer)每隔一段时间,会向CPU发送一个中断.这样CPU不用记住每一条指令的执行时间.没有定时器很多指令CPU都很难执行.例如HLT指令,这个指令的执行时间不是个固定 ...

  4. 《30天自制操作系统》09_day_学习笔记

    harib06a: 在昨天的最后一部分,我们已经变成了32位的模式,目的就是希望能够使用电脑的全部内存. 虽然鼠标的显示处理有一些叠加问题,不过笔者为了不让我们感到腻烦,先带我们折腾一下内存 这里笔者 ...

  5. 《30天自制操作系统》05_day_学习笔记

    //bootpack.c 完整代码 #include <stdio.h> void io_hlt(void); void io_cli(void); void io_out8(int po ...

  6. 《30天自制操作系统》03_day_学习笔记

    harib00a: 添加的部分从P46开始,制作IPL准备开始从磁盘装载程序了 笔者讲解了软盘的驱动的构造,以及汇编语言读取软盘的方法 MOV AX,0x0820 MOV ES,AX ; 柱面0 ; ...

  7. 《30天自制操作系统》17_day_学习笔记

    harib14a: 接着上一天的内容,我们来思考一个问题:当所有的LEVEL中都没有任务的时候怎么办?采用前面定时器链表中加入“哨兵”的思路,我们加入一个idle任务,去执行HLT.接下来我们只需要将 ...

  8. 《30天自制操作系统》18_day_学习笔记

    harib15a: 到这里为止,我们已经能实现窗口的切换了.我们发现所有的窗口都有光标闪烁,而我们只希望可以接受输入的窗口有光标闪烁.这里我们先来修改任务A中的光标闪烁,当按下TAB时,如果让A不现实 ...

  9. 《30天自制操作系统》16_day_学习笔记

    harib13a: 今天我们要继续折腾多任务,任务的高效管理是操作系统的一个重要的任务.在今天,我们将为系统创建更加完善的任务管理系统,其中包括优先级,任务等级等. 1.任务管理结构体 #define ...

随机推荐

  1. css复合属性的写法

    # 复合属性也称为 "shortcut" property (快捷属性),它作用是为了简化代码,提高页面运行的效率. # 下面的内容会介绍 2 个比较常用的复合属性 "f ...

  2. php数组array,知道键名如何提取键值

    如果是知道键值,需要查找键名,直接使用array_search()即可.现在反过来,如何操作?   (1)array_walk_recursive()加自定义函数查找   $arr=array( 'n ...

  3. 这才是正确删除 office 的方式

    https://support.office.com/zh-cn/article/%E9%80%9A%E8%BF%87%E5%9C%A8%E9%87%8D%E6%96%B0%E5%AE%89%E8%A ...

  4. Genymotion中SD卡目录在Eclipse中查看,以及创建SDCard

    咦?这后面似乎指向一个目录,我就去找/mnt/shell/emulated/0 Wow~好熟悉的目录..不熟悉的同学可以打开android模拟器的File Manger App 里面就是这些目录了,然 ...

  5. Android软件版本更新

     转的:适合新手学习,但在实际项目中不可这么做. 以下是我转的内容: ================================================================= ...

  6. cdoj 韩爷的情书 有向图 欧拉路径

    //欧拉回路 解法:首先判断欧拉回路存在性:1.连通 2.没有出度入度相差大于1的点 3.如果有出度入度相差等于1的点那么必须有两个,一个出度大于入度作为起点,一个入度大于出度作为终点. 在确定了起点 ...

  7. uvalive5818 uva12376 As Long as I Learn, I Live

    题意:给出一个又向图每个图有权值和编号(正方形里的是编号),从第0号节点开始每次向当前节点所连的点中权值最大的节点移动(不会存在权值相同的节点),问最后所在的节点编号和经过的节点的权值之和. 解:模拟 ...

  8. POJ 2342 树形DP入门题

    有一个大学的庆典晚会,想邀请一些在大学任职的人来參加,每一个人有自己的搞笑值,可是如今遇到一个问题就是假设两个人之间有直接的上下级关系,那么他们中仅仅能有一个来參加,求请来一部分人之后,搞笑值的最大是 ...

  9. 一步一步学c#(四):继承

    继承 1·继承的类型 在面向对象的编程中,有两种截然不同的继承类型,实现继承和接口继承. 实现继承:表示一个类型派生于一个基类型,它拥有该基类型的所有成员字段和函数. 接口继承:表示一个类型只继承了函 ...

  10. 前端新人学习笔记-------html/css/js基础知识点

    即将毕业的软件工程大学生一枚,秋季招聘应聘的是Android,今年来到公司实习,要求做前端开发,所以一切只有现学,现在根据视频来学习,然后开这个博客记录一下自己的学习过程,废话不多说,开写. 4月6日 ...