extern-arm开发板lcd屏幕中怎么把一个图片的颜色改变另一个颜色

问题描述

arm开发板lcd屏幕中怎么把一个图片的颜色改变另一个颜色

以下是lcd的程序,求大神指教

/**************************************************************
The initial and control for 640×480 16Bpp TFT LCD----VGA
**************************************************************/

#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440lib.h"
#include "2440slib.h"

extern const unsigned char sunflower_240x320[];
extern const unsigned char sunflower_800x480[];
extern const unsigned char sunflower_1024x768[];
extern const unsigned char sunflower_640x480[];

#define LCD_XSIZE LCD_WIDTH
#define LCD_YSIZE LCD_HEIGHT
#define SCR_XSIZE LCD_WIDTH
#define SCR_YSIZE LCD_HEIGHT

volatile static unsigned short LCD_BUFFER[SCR_YSIZE][SCR_XSIZE];

/**************************************************************
640×480 TFT LCD数据和控制端口初始化
**************************************************************/
static void Lcd_Port_Init( void )
{
rGPCUP=0xffffffff; // Disable Pull-up register
rGPCCON=0xaaaa02a8; //Initialize VD[7:0],VM,VFRAME,VLINE,VCLK

rGPDUP=0xffffffff; // Disable Pull-up register
rGPDCON=0xaaaaaaaa; //Initialize VD[15:8]

}

/**************************************************************
640×480 TFT LCD功能模块初始化
**************************************************************/
static void LCD_Init(void)
{
#define M5D(n) ((n)&0x1fffff)
#define LCD_ADDR ((U32)LCD_BUFFER)
rLCDCON1 = (LCD_PIXCLOCK << 8) | (3 << 5) | (12 << 1);
rLCDCON2 = (LCD_UPPER_MARGIN << 24) | ((LCD_HEIGHT - 1) << 14) | (LCD_LOWER_MARGIN << 6) | (LCD_VSYNC_LEN << 0);
rLCDCON3 = (LCD_RIGHT_MARGIN << 19) | ((LCD_WIDTH - 1) << 8) | (LCD_LEFT_MARGIN << 0);
rLCDCON4 = (13 << 8) | (LCD_HSYNC_LEN << 0);

#if !defined(LCD_CON5)
#define LCD_CON5 ((1<<11) | (1 << 9) | (1 << 8) | (1 << 3) | (1 << 0))
#endif
rLCDCON5 = LCD_CON5;

rLCDSADDR1 = ((LCD_ADDR >> 22) << 21) | ((M5D(LCD_ADDR >> 1)) <<  0);
rLCDSADDR2 = M5D((LCD_ADDR + LCD_WIDTH * LCD_HEIGHT * 2) >> 1);
rLCDSADDR3 = LCD_WIDTH;        

rLCDINTMSK |= 3;
rTCONSEL   &= (~7);

rTPAL     = 0x0;
rTCONSEL &= ~((1<<4) | 1);

}

/**************************************************************
LCD视频和控制信号输出或者停止,1开启视频输出
**************************************************************/
static void Lcd_EnvidOnOff(int onoff)
{
if(onoff==1)
rLCDCON1|=1; // ENVID=ON
else
rLCDCON1 =rLCDCON1 & 0x3fffe; // ENVID Off
}

/**************************************************************
320×240 8Bpp TFT LCD 电源控制引脚使能
**************************************************************/
static void Lcd_PowerEnable(int invpwren,int pwren)
{
//GPG4 is setted as LCD_PWREN
rGPGUP = rGPGUP|(1<<4); // Pull-up disable
rGPGCON = rGPGCON|(3<<8); //GPG4=LCD_PWREN

//Enable LCD POWER ENABLE Function
rLCDCON5 = rLCDCON5&(~(1<<3))|(pwren<<3);   // PWREN
rLCDCON5 = rLCDCON5&(~(1<<5))|(invpwren<<5);   // INVPWREN

}

/**************************************************************
640×480 TFT LCD单个象素的显示数据输出
**************************************************************/
static void PutPixel(U32 x,U32 y,U16 c) //U16代表unsigned short U32代表unsigned int
{
if(x<SCR_XSIZE && y<SCR_YSIZE)
LCD_BUFFER[(y)][(x)] = c;
}

/**************************************************************
640×480 TFT LCD全屏填充特定颜色单元或清屏
**************************************************************/
static void Lcd_ClearScr( U16 c)
{
unsigned int x,y ;

for( y = 0 ; y < SCR_YSIZE ; y++ )
{
    for( x = 0 ; x < SCR_XSIZE ; x++ )
    {
        LCD_BUFFER[y][x] = c ;
    }
}

}

/**************************************************************
LCD屏幕显示垂直翻转
// LCD display is flipped vertically
// But, think the algorithm by mathematics point.
// 3I2
// 4 I 1
// --+-- <-8 octants mathematical cordinate
// 5 I 8
// 6I7
**************************************************************/
static void Glib_Line(int x1,int y1,int x2,int y2, U16 color)
{
int dx,dy,e;
dx=x2-x1;
dy=y2-y1;

if(dx>=0)
{
    if(dy >= 0) // dy>=0
    {
        if(dx>=dy) // 1/8 octant
        {
            e=dy-dx/2;
            while(x1<=x2)
            {
                PutPixel(x1,y1,color);
                if(e>0){y1+=1;e-=dx;}
                x1+=1;
                e+=dy;
            }
        }
        else        // 2/8 octant
        {
            e=dx-dy/2;
            while(y1<=y2)
            {
                PutPixel(x1,y1,color);
                if(e>0){x1+=1;e-=dy;}
                y1+=1;
                e+=dx;
            }
        }
    }
    else           // dy<0
    {
        dy=-dy;   // dy=abs(dy)

        if(dx>=dy) // 8/8 octant
        {
            e=dy-dx/2;
            while(x1<=x2)
            {
                PutPixel(x1,y1,color);
                if(e>0){y1-=1;e-=dx;}
                x1+=1;
                e+=dy;
            }
        }
        else        // 7/8 octant
        {
            e=dx-dy/2;
            while(y1>=y2)
            {
                PutPixel(x1,y1,color);
                if(e>0){x1+=1;e-=dy;}
                y1-=1;
                e+=dx;
            }
        }
    }
}
else //dx<0
{
    dx=-dx;     //dx=abs(dx)
    if(dy >= 0) // dy>=0
    {
        if(dx>=dy) // 4/8 octant
        {
            e=dy-dx/2;
            while(x1>=x2)
            {
                PutPixel(x1,y1,color);
                if(e>0){y1+=1;e-=dx;}
                x1-=1;
                e+=dy;
            }
        }
        else        // 3/8 octant
        {
            e=dx-dy/2;
            while(y1<=y2)
            {
                PutPixel(x1,y1,color);
                if(e>0){x1-=1;e-=dy;}
                y1+=1;
                e+=dx;
            }
        }
    }
    else           // dy<0
    {
        dy=-dy;   // dy=abs(dy)

        if(dx>=dy) // 5/8 octant
        {
            e=dy-dx/2;
            while(x1>=x2)
            {
                PutPixel(x1,y1,color);
                if(e>0){y1-=1;e-=dx;}
                x1-=1;
                e+=dy;
            }
        }
        else        // 6/8 octant
        {
            e=dx-dy/2;
            while(y1>=y2)
            {
                PutPixel(x1,y1,color);
                if(e>0){x1-=1;e-=dy;}
                y1-=1;
                e+=dx;
            }
        }
    }
}

}

/**************************************************************
在LCD屏幕上用颜色填充一个矩形
**************************************************************/
static void Glib_FilledRectangle(int x1,int y1,int x2,int y2, U16 color)
{
int i;

for(i=y1;i<=y2;i++)
Glib_Line(x1,i,x2,i,color);

}

/**************************************************************
在LCD屏幕上用颜色填充一个圆
**************************************************************/
static void Lcd_Circle(int r)
{
int m,n;
for(m=0;m<10000;m++)
{
for(n=0;n<1000;n++)
{
if((m-120)*(m-120)+(n-170)*(n-170)<=r*r)
{

PutPixel(m,n,600);

        }
    }
}

}
/**************************************************************
在LCD屏幕上指定坐标点画一条指定长度的直线
**************************************************************/

static void Lcd_Line(int t)
{
int m;
for(m=50;m<=t;m++)
{
PutPixel(90,m,600);
}
}

/**************************************************************
在LCD屏幕上指定坐标点画一个指定大小的图片
**************************************************************/
static void Paint_Bmp(int x0,int y0,int h,int l,const unsigned char *bmp)
{
int x,y;
U32 c;
int p = 0;

for( y = 0 ; y < l ; y++ )
{
    for( x = 0 ; x < h ; x++ )
    {
        c = bmp[p+1] | (bmp[p]<<8) ;

        if ( ( (x0+x) < SCR_XSIZE) && ( (y0+y) < SCR_YSIZE) )
            LCD_BUFFER[y0+y][x0+x] = c ;

        p = p + 2 ;
    }
}

}

/**************************************************************
**************************************************************/
void TFT_LCD_Init(void)
{

LCD_Init();
//LcdBkLtSet( 70 ) ;
Lcd_PowerEnable(0, 1);
Glib_FilledRectangle(40,50,80,100,300);
Lcd_EnvidOnOff(1);      //turn on vedio

/* Lcd_ClearScr( (0x00<<11) | (0x00<<5) | (0x00) );

#if defined(LCD_N35) || defined(LCD_T35) || defined(LCD_X35)
Paint_Bmp(0, 0, 240, 320, sunflower_240x320);
#elif defined(LCD_A70)
Paint_Bmp(0, 0, 800, 480, sunflower_800x480);
#elif defined(LCD_L80)
Paint_Bmp(0, 0, 640, 480, sunflower_640x480);
#elif defined(LCD_VGA1024768)
Paint_Bmp(0, 0, 1024, 768, sunflower_1024x768);
#endif */

}

/**************************************************************
**************************************************************/
void TFT_LCD_Test()
{

Lcd_Port_Init();// TFT LCD数据和控制端口初始化
LCD_Init();//TFT LCD功能模块初始化

Lcd_PowerEnable(0, 1);// 8Bpp TFT LCD 电源控制引脚使能
//Glib_FilledRectangle(20,30,200,200,500);//矩形
Lcd_Circle(100);
//Lcd_Line(150);

Lcd_EnvidOnOff(1);      //turn on vedio   LCD视频和控制信号输出或者停止,1开启视频输出

}
//*************************************************************

解决方案

把c的值改了就可以改变颜色,要显示简单图案可以按一定方法渐变c的值,要显示某图片,把图片转换成像素色彩数组,循环写入

LCD_BUFFER[(y)][(x)] = c;
时间: 2024-08-03 16:35:23

extern-arm开发板lcd屏幕中怎么把一个图片的颜色改变另一个颜色的相关文章

ARM开发板上QT5 中 OSD显示的问题 具体如下

问题描述 ARM开发板上QT5 中 OSD显示的问题 具体如下 各位 ,我现在做一个视频监控类的东西,在IMX6的开发板上移植了QT5.4 用于GUI界面的显示, 然后用IMX6的/dev/vidio17作为视频的输出到fb0,现在要求视频显示在底层,GUI显示在上层,GUI的背景我设置为透明的,这样可以看到后面的视频,IMX6有两层fb0和fb1 但是现在的情况视频老是挡住GUI 我明明通过 export QT_QPA_PLATFORM=linuxfb:fb=/dev/fb1指定输出到fb1

如何将sqlite数据库移植到ARM开发板上

近段时间在学数据库,因为自身需求,所以注重研究了点嵌入式sqlite数据库, SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它, 它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了.它能够支持Windows/Linux/Unix等等主流的操作系统, 同时能够跟很多程序语言相结合,比如 Tcl.C#.PHP.Java等,还有ODBC接口, 同样比起Mysql.PostgreSQL这两款开源世界著名的

arm工控板-如何实现arm开发板接并口打印机设备

问题描述 如何实现arm开发板接并口打印机设备 有款ARM工控板,板卡没有并口接口,但是想要接并口的打印机该如何操作. 解决方案 通过GPIO针脚模拟并口打印机协议即可,需要搞清楚并口打印机支持的是那种协议,比如SPP.ECP等.也需要把你用到的GPIO针脚导出到并口接口上,方便接线.

arm- 如何升级ARM开发板的安卓系统

问题描述 如何升级ARM开发板的安卓系统 是晶晨 AMLOGIC 8726M3 ARM Cortex-A9 1GHz 的开发板.原来带的系统是4.0的安卓,如何把原有系统升级. 另外,板子通过USB线与电脑连接,电脑没有任何反应,也找不到板子. 请各位大侠给个建议,先谢了! 解决方案 一般和手机类似,进入recoery模式,然后下载系统镜像.具体你的开发板怎么进recovery模式,这个要问厂家. 解决方案二: 不同的开发板,安装方式不同.和手机不同,这个需要咨询厂家,一般有单独的安装方式.例如

nginx移植到arm开发板启动时出错

问题描述 nginx移植到arm开发板启动时出错 nginx移植到arm开发板启动时显示nginx: [emerg] getgrnam("nogroup") failed (2: No such file or directory) 不知道是什么原因? 解决方案 没找到这个目录,检查下文件是否拷贝全了. 解决方案二: 你好,我也是这个错误,请问你解决了吗?请指教下,谢谢

arm-天嵌ARM开发板TQ210S5PV

问题描述 天嵌ARM开发板TQ210S5PV 谁有天嵌ARM开发板TQ210S5PV 底板的原理图,我在这先谢谢大家,请有的给传一下.

ARM 开发板嵌入式linux系统与主机PC通过串口传输文件

本文转载自http://useless20.blog.163.com/blog/static/237409982010227127576/ 嵌入式linux系统与主机通过串口传输文件      我想如果要从PC机下载东西到开发板的嵌入式linux系统里面,很多人首先会想到用tftp sftp等网络工具从网口下载.但如果网络用不了,只能通过串口下载怎么办呢?这个时候有两个工具能帮到你:一个是zmrx.zmtx,另外一个是lsz.lrz.个人觉得zmrx/zmtx没有lsz/lrz稳定,建议还是用后

点击一个图片后,弹出一个窗口,并在窗口中完成ajax的实时提示

问题描述 点击一个图片后,弹出一个窗口,并在窗口中完成ajax的实时提示 点击一个链接后,弹出一个窗口,并在窗口中完成ajax的实时提示. 在此请教各位,如何实现? $.ajax({ type:'POST', url: 'hhWebsiteInfoController.do?website-getDt', dataType:'json', data:'', success:function(json){ alert(1); var dts = json.attributes.dts; $("#n

ARM开发板嵌入式Linux修改开机启动LOGO的方法

1.嵌入式 Linux LOGO显示原理 嵌入式Linux是直接在FrameBuffer的基础上.直接显示一个ppm格式的图象.它 kernel/drivers/video/fbcon.c中的fbcon_show_logo()完成,最大颜色支持224色而不常见的255色. 默认的logo文件是 drivers/video/logo/logo_linux_clut224.ppm. 2.制作流程 因为LINUX LOGO格式需要ppm格式来显示.这种格式是一种用ASCII来描述图像数据一种格式.一般