framebuffer开发有我想象的那么简单吗

简介: 版权声明:您好,转载请留下本人博客的地址,谢谢 https://blog.csdn.net/hongbochen1223/article/details/49301177 (一):写...
版权声明:您好,转载请留下本人博客的地址,谢谢 https://blog.csdn.net/hongbochen1223/article/details/49301177

(一):写在前面

在这个小节中,主要介绍了frame buffer中的R,G,B以及透明度的位域属性.由于在上一个小节当中,我自私的以为这几个位域能够获得相应的R,G,B以及透明度的数值,然后再将其转化为图像,但是,经过我后来的学习,发现我错了.正确的将frame buffer读取并转换为图像的方法是首先读取(read)frame buffer,然后,再将读取的char数组转换为相应的图片.所以,后面,着重学习如何读取frame buffer,以及如何将其转化为图片.

(二):R,G,B以及透明度位域

在fb.h头文件中的结构 fb_var_screeninfo中定义了R,G,B以及透明度的位域,他们都是一个结构体fb_bitfield的一个实例.下面我们来看一下bitfield的定义:

struct fb_bitfield {
    __u32 offset;           /* 位域的开始    */
    __u32 length;           /* length of bitfield 位域的长度 */
    __u32 msb_right;        /* != 0 : Most significant bit is right 不等于0,大多数重要的位是右边的 */ 
};

那么如果要打印该值的话,我们就需要使用该结构体.

(三):完善上一节中的p_rgbt(PFBDEV pFbdev)函数

在我们的上一节中,我们留下了这个函数而没有去实现,这个来源于我的无知.所以,现在我们来完善一下这个函数.在上面我们知道这个关系之后,这个函数的实现就显得相对简单了.

//打印R,G,B和透明度
void p_rgbt(PFBDEV pFbdev)
{
    //R位域
    printf("R位域:\n");
    struct fb_bitfield bf = pFbdev->fb_var.red;
    printf("\t开始:%d\n",bf.offset);
    printf("\t长度:%d\n",bf.length);
    printf("\tMSB:%d\n",bf.msb_right);

    //G位域
    printf("G位域:\n");
    bf = pFbdev->fb_var.green;
    printf("\t开始:%d\n",bf.offset);
    printf("\t长度:%d\n",bf.length);
    printf("\tMSB:%d\n",bf.msb_right);

    // B位域
    printf("B位域:\n");
    bf = pFbdev->fb_var.blue;
    printf("\t开始:%d\n",bf.offset);
    printf("\t长度:%d\n",bf.length);
    printf("\tMSB:%d\n",bf.msb_right);

    // 透明度位域
    printf("透明度位域:\n");
    bf = pFbdev->fb_var.transp;
    printf("\t开始:%d\n",bf.offset);
    printf("\t长度:%d\n",bf.length);
    printf("\tMSB:%d\n",bf.msb_right);
}

(四):编译运行方法

编译和运行方法和上一节的编译运行方法是一样的.

(五):运行结果展示

下面我们来看一下我们的运行结果:

frame buffer所占内存的开始地址为:-1341710336
frame buffer 的类型为:0
frame buffer的可见清晰度为:
    x = 1366
    y = 768
frame buffer的虚拟清晰度为:
    x = 1366
    y = 768
frame buffer的虚拟分辨率到可见分辨率的偏移量为:
    x = 0
    y = 0
frame buffer的BPP为:32
R位域:
    开始:16
    长度:8
    MSB:0
G位域:
    开始:8
    长度:8
    MSB:0
B位域:
    开始:0
    长度:8
    MSB:0
透明度位域:
    开始:0
    长度:0
    MSB:0
frame buffer在内存中所占的高度和宽度分别是:
    宽度 = -1
    高度 = -1
R位域:
    开始:16
    长度:8
    MSB:0
G位域:
    开始:8
    长度:8
    MSB:0
B位域:
    开始:0
    长度:8
    MSB:0
透明度位域:
    开始:0
    长度:0
    MSB:0

(六):写在后面

今天很残酷,明天很残酷,后天很没有,但是绝大多数人死在了明天晚上.----马云

注意:源代码我已经长传到github中,下面是地址:

源代码下载

目录
相关文章
|
8月前
|
编解码 Ubuntu Linux
Linux应用开发基础知识——Framebuffer 应用编程(四)
Linux应用开发基础知识——Framebuffer 应用编程(四)
141 0
Linux应用开发基础知识——Framebuffer 应用编程(四)
|
3月前
|
编译器 程序员 C语言
精简函数栈帧:优化创建和销毁过程的完全解析(建议收藏,提升内功)
精简函数栈帧:优化创建和销毁过程的完全解析(建议收藏,提升内功)
|
2月前
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
7月前
|
编解码 算法 程序员
老程序员分享:OpenGL学习进程(10)第七课:四边形绘制与动画基础
老程序员分享:OpenGL学习进程(10)第七课:四边形绘制与动画基础
指针引导:掌握C++内存操控的艺术 1
指针引导:掌握C++内存操控的艺术
|
小程序 C++ 索引
学习OpenGL之准备工作
学习OpenGL之准备工作
121 0
学习OpenGL之准备工作
|
图形学
从0开发游戏引擎之游戏引擎中2D序列帧动画控制器的实现
需要的图片类似图1.1 会把所有的动作拼接到一张图上,这样做也是为了节省内存和减少DrawCall,切换动作的时候只需要重新计算图片的UV,然后把算出来的UV作为新区域贴在原来的那张纹理面片上即可。
从0开发游戏引擎之游戏引擎中2D序列帧动画控制器的实现
|
图形学 机器人
带你读《Unity游戏开发(原书第3版)》之三:模型、材质和纹理
本书主要介绍Unity2018的使用和游戏开发流程中涉及的各种知识。每一章的结构特别清晰,先综述该章要介绍的内容,然后一步步深入讲解,中间穿插着很多动手做的实践操作,可以让读者加深对某个概念、方法的理解,每章的最后还有一个小测验和一个稍微大一点的实践练习,用于巩固该章的学习内容。