在AM335x中,在连接显示屏的时候,存在一个问题。这个在am335x Sillicon Errata已经提到过
在RGB888模式中

 
而对于RGB565模式的硬件连接

不难看出,这个RGB是反的。
看一下我们自己硬件的连接方式
我们自己的硬件连接是RGB888

 

在模式设置成32位真彩显示时没有问题,但是一旦把32位换成32位时,就会发现图片的颜色显示异常。换一张纯色的红色bmp图片到开发板上,显示成蓝色。效果如图

 
 
 
那么如何让RGB888的硬件连接也能正常显示16位呢?
 
第一步:首先将开发板的bpp从32位改成16位
 

 
 
接下来修改驱动程序da8xx-fb.c
修改函数fb_check_var
 
实际上就是将红色与蓝色调换一下
 
static int fb_check_var(struct fb_var_screeninfo *var,
struct fb_info *info)
{
int err = 0;
struct da8xx_fb_par *par = info->par;
int bpp = var->bits_per_pixel >> 3;
unsigned long line_size = var->xres_virtual * bpp; switch (var->bits_per_pixel) {
case 1:
case 8:
var->red.offset = 0;
var->red.length = 8;
var->green.offset = 0;
var->green.length = 8;
var->blue.offset = 0;
var->blue.length = 8;
var->transp.offset = 0;
var->transp.length = 0;
break;
case 4:
var->red.offset = 0;
var->red.length = 4;
var->green.offset = 0;
var->green.length = 4;
var->blue.offset = 0;
var->blue.length = 4;
var->transp.offset = 0;
var->transp.length = 0;
break;
case 16: /* RGB 565 */
var->red.offset = 11; //改成var->blue.offset = 11;
var->red.length = 5; //改成var->blue.length = 5;
var->green.offset = 5;
var->green.length = 6;
var->blue.offset = 0; //改成var->red.offset = 0;
var->blue.length = 5; //改成var->red.length = 5;
var->transp.offset = 0;
var->transp.length = 0;
break;
case 24:
var->red.offset = 16;
var->red.length = 8;
var->green.offset = 8;
var->green.length = 8;
var->blue.offset = 0;
var->blue.length = 8;
break;
case 32:
var->transp.offset = 24;
var->transp.length = 8;
var->red.offset = 16;
var->red.length = 8;
var->green.offset = 8;
var->green.length = 8;
var->blue.offset = 0;
var->blue.length = 8;
break;
default:
err = -EINVAL;
} var->red.msb_right = 0;
var->green.msb_right = 0;
var->blue.msb_right = 0;
var->transp.msb_right = 0; if (line_size * var->yres_virtual > par->vram_size)
var->yres_virtual = par->vram_size / line_size; if (var->yres > var->yres_virtual)
var->yres = var->yres_virtual; if (var->xres > var->xres_virtual)
var->xres = var->xres_virtual; if (var->xres + var->xoffset > var->xres_virtual)
var->xoffset = var->xres_virtual - var->xres;
if (var->yres + var->yoffset > var->yres_virtual)
var->yoffset = var->yres_virtual - var->yres; return err;
}
-
 
 
x
 
 
 
1
static int fb_check_var(struct fb_var_screeninfo *var,
2
struct fb_info *info)
3
{
4
int err = 0;
5
struct da8xx_fb_par *par = info->par;
6
int bpp = var->bits_per_pixel >> 3;
7
unsigned long line_size = var->xres_virtual * bpp;
8

9
switch (var->bits_per_pixel) {
10
case 1:
11
case 8:
12
var->red.offset = 0; 
13
var->red.length = 8; 
14
var->green.offset = 0;
15
var->green.length = 8;
16
var->blue.offset = 0;
17
var->blue.length = 8;
18
var->transp.offset = 0;
19
var->transp.length = 0;
20
break;
21
case 4:
22
var->red.offset = 0;
23
var->red.length = 4;
24
var->green.offset = 0;
25
var->green.length = 4;
26
var->blue.offset = 0;
27
var->blue.length = 4;
28
var->transp.offset = 0;
29
var->transp.length = 0;
30
break;
31
case 16:/* RGB 565 */
32
var->red.offset = 11;  //改成var->blue.offset = 11;
33
var->red.length = 5;   //改成var->blue.length = 5; 
34
var->green.offset = 5;
35
var->green.length = 6;
36
var->blue.offset = 0;  //改成var->red.offset = 0; 
37
var->blue.length = 5;  //改成var->red.length = 5;
38
var->transp.offset = 0;
39
var->transp.length = 0;
40
break;
41
case 24:
42
var->red.offset = 16;
43
var->red.length = 8;
44
var->green.offset = 8;
45
var->green.length = 8;
46
var->blue.offset = 0;
47
var->blue.length = 8;
48
break;
49
case 32:
50
var->transp.offset = 24;
51
var->transp.length = 8;
52
var->red.offset = 16;
53
var->red.length = 8;
54
var->green.offset = 8;
55
var->green.length = 8;
56
var->blue.offset = 0;
57
var->blue.length = 8;
58
break;
59
default:
60
err = -EINVAL;
61
}
62

63
var->red.msb_right = 0;
64
var->green.msb_right = 0;
65
var->blue.msb_right = 0;
66
var->transp.msb_right = 0;
67

68
if (line_size * var->yres_virtual > par->vram_size)
69
var->yres_virtual = par->vram_size / line_size;
70

71
if (var->yres > var->yres_virtual)
72
var->yres = var->yres_virtual;
73

74
if (var->xres > var->xres_virtual)
75
var->xres = var->xres_virtual;
76

77
if (var->xres + var->xoffset > var->xres_virtual)
78
var->xoffset = var->xres_virtual - var->xres;
79
if (var->yres + var->yoffset > var->yres_virtual)
80
var->yoffset = var->yres_virtual - var->yres;
81

82
return err;
83
}
 
 
这样就能在开发板上正常显示颜色了

 

<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">

 
 
 
 

AM335X用RGB888连接LCD如何以16位色彩模式显示图片的更多相关文章

  1. 颜色模式中8位,16位,24位,32位色彩是什么意思?会有什么区别?计算机颜色格式( 8位 16位 24位 32位色)<转>

    颜色模式中8位,16位,24位,32位色彩是什么意思?会有什么区别简单地说这里说的位数和windows系统显示器设置中的颜色位数是一样的.表示的是能够显示出来的颜色的多少. 8位的意思是说,能够显示出 ...

  2. bmp文件格式中rgb555与rgb888之间的转换,24位与16位位图的转换

    今日,有同事问我.rgb555模式下的位图文件的格式问题,于是花了一下午的时间通过推測与測试,分析出了例如以下bmp文件在rgb555模式下的文件存储规律: 1:bmp文件的文件信息头中的biBitC ...

  3. Linux LCD 显示图片【转】

    转自:https://blog.csdn.net/niepangu/article/details/50528190 BMP和JPEG图形显示程序1)  在LCD上显示BMP或JPEG图片的主流程图首 ...

  4. 使用 GCC 和 GNU Binutils 编写能在 x86 实模式运行的 16 位代码

    不可否认,这次的标题有点长.之所以把标题写得这么详细,主要是为了搜索引擎能够准确地把确实需要了解 GCC 生成 16 位实模式代码方法的朋友带到我的博客.先说一下背景,编写能在 x86 实模式下运行的 ...

  5. STM32学习之路-LCD(3)&lt;显示图片&gt;

    祝大家端午和六一快乐!原本今天是想歇息歇息的,可是实在无奈没什么事干.所以就来学习学习LCD显示图片的函数 函数是照搬奋斗的样例,算是些笔记吧.只是奋斗的样例凝视的不是非常具体.今天去看了正点原子的论 ...

  6. Linux 桌面玩家指南:08. 使用 GCC 和 GNU Binutils 编写能在 x86 实模式运行的 16 位代码

    特别说明:要在我的随笔后写评论的小伙伴们请注意了,我的博客开启了 MathJax 数学公式支持,MathJax 使用$标记数学公式的开始和结束.如果某条评论中出现了两个$,MathJax 会将两个$之 ...

  7. 七、在U-boot中让LCD显示图片

    1. 增加Nandflash读取代码 因为要显示图片,而图片明显是放在Nandflash中比较合适,因此需要有能够操作Nandflash的函数.在U-boot中已经有能操作Nandflash的函数了, ...

  8. 四路4 GSPS@ 12 bit,四路12 GSPS@16 位4T4R 射频芯片AD9988

    一.产品概述 AD9988 是一款高度集成的套件,是北京太速最新研发的,具有四个 16 位.12 GSPS 最大采样率.RF 数模转换器 (DAC) 内核,以及四个 12 位.4 GSPS 速率.RF ...

  9. pyserial 16进制显示与发送

    pyserial 16进制显示与发送 http://www.centoscn.com/python/2013/0817/1320.html 十六进制显示的实质是把接收到的字符诸葛转换成其对应的ASCI ...

随机推荐

  1. Java - 将vCard中十六进制编码转换成Unicode

    做课程设计的时候在处理vCard格式的时候遇到过出现十六进制编码的情况,例如 QUOTED-PRINTABLE:=XX=XX=XX=XX=XX`````` 其中XX代表十六进制数,当然,也有可能在末尾 ...

  2. EXTJS之DATA PROXY READER

    这是不依赖于STORE的读取.我测试了很久,原来在新版本的EXTJS里.modelmanager.getmodel之类的不用了. 更改为静态的LOAD办法. <!DOCTYPE html> ...

  3. [Javascript Crocks] Safely Access Nested Object Properties with `propPath`

    In this lesson, we’ll look at the propPath utility function. We’ll ask for a property multiple level ...

  4. [React] Update State Based on Props using the Lifecycle Hook getDerivedStateFromProps in React16.3

    getDerivedStateFromProps is lifecycle hook introduced with React 16.3 and intended as a replacement ...

  5. Xmind8破解激活

    1.下载安装包: https://www.xmind.cn/download/ 进行安装 2.下载破解补丁: https://stormxing.oss-cn-beijing.aliyuncs.com ...

  6. hdoj--1829--A Bug's Life(带权并查集)

    A Bug's Life Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) To ...

  7. [POJ 1639] Picnic Planning

    [题目链接] http://poj.org/problem?id=1639 [算法] 首先,我们可以用深度优先遍历求出1号节点去除后有几个联通块 设共有T个联通块,若T > K则无解,否则 : ...

  8. ubantu安装jdk

    环境:ubantu16.04下安装jdk1.8 1,在当前用户根目录下创建目录,本人所用的用户为bruce: mkdir /home/bruce/jdk 2,官网下载jdk1.8,网址为http:// ...

  9. jQuery hooks源码学习

    段落不够清晰,待整理 看jQuery源码的时候,经常见到含有hooks标志的对象,如cssHooks, attrHooks, propHooks, valHooks. 下面对其中的一段进行解读. jQ ...

  10. 利用JavaScript的if语句判断元素显示隐藏

    <html> <head> <meta charset="utf-8"> <title>无标题文档</title> &l ...