s3c2440之LCD字符显示

发布者:LIGANG888最新更新时间:2016-08-14 来源: eefocus关键字:s3c2440  LCD字符显示 手机看文章 扫描二维码
随时随地手机看文章

#define U32 unsigned int

#define M5D(n) ((n) & 0x1fffff)


#define rGPCCON (*(volatile unsigned *)0x56000020)
#define rGPCDAT (*(volatile unsigned *)0x56000024)
#define rGPCUP (*(volatile unsigned *)0x56000028)



#define rGPDCON (*(volatile unsigned *)0x56000030)

#define rGPDDAT (*(volatile unsigned *)0x56000034)

#define rGPDUP (*(volatile unsigned *)0x56000038)



#define rGPGCON (*(volatile unsigned *)0x56000060)

#define rGPGDAT (*(volatile unsigned *)0x56000064)

#define rGPGUP (*(volatile unsigned *)0x56000068)



#define rLCDCON1 (*(volatile unsigned *)0x4d000000)

#define rLCDCON2 (*(volatile unsigned *)0x4d000004)

#define rLCDCON3 (*(volatile unsigned *)0x4d000008)

#define rLCDCON4 (*(volatile unsigned *)0x4d00000c)

#define rLCDCON5 (*(volatile unsigned *)0x4d000010)

#define rLCDSADDR1 (*(volatile unsigned *)0x4d000014)

#define rLCDSADDR2 (*(volatile unsigned *)0x4d000018)

#define rLCDSADDR3 (*(volatile unsigned *)0x4d00001c)

#define rLCDINTMSK (*(volatile unsigned *)0x4d00005c)

#define rTCONSEL (*(volatile unsigned *)0x4d000060)



#define LCD_WIDTH 320

#define LCD_HEIGHT 240



#define VSPW (3-1)

#define VBPD (15-1)

#define VFPD (12-1)



#define HSPW (30-1)

#define HBPD (38-1)

#define HFPD (20-1)



#define LINEVAL (LCD_HEIGHT-1)

#define HOZVAL (LCD_WIDTH-1)



/*for LCDCON1*/

#define CLKVAL_TFT 6

#define MVAL_USED 0

#define PNRMODE_TFT 3

#define BPPMODE_TFT 13





/*for LCDCON5*/

#define BPP24BL 0

#define INVVCLK 0

#define INVVLINE 1

#define INVVFRAME 1

#define INVVD 0

#define INVVDEN 0

#define PWREN 1

#define BSWP 0

#define HWSWP 0



volatile U32 LCD_BUFFER[LCD_HEIGHT][LCD_WIDTH];



unsigned char ning[]= /*宁*/

{
0x00,0x60,0x00,0x00,0x30,0x00,0x00,0x18,0x00,0x10,0x10,0x0C,0x1F,0xFF,0xFE,0x30,0x00,0x18,0x30,0x00,0x10,0x60,0x00,0x20,
0x00,0x00,0x00,0x00,0x00,0x18,0x7F,0xFF,0xFC,0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,
0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,0x01,0xF8,0x00,0x00,0x70,0x00,0x00,0x20,0x00
};

unsigned char bo[]= /*波*/

{

0x00,0x02,0x00,0x30,0x03,0x80,0x18,0x03,0x00,0x0C,0x03,0x00,0x08,0x83,0x0C,0x00,0xFF,0xFE,0x42,0xC3,0x0C,0x62,0xC3,0x18,
0x32,0xC3,0x20,0x34,0xC3,0x00,0x14,0xC3,0x10,0x04,0xFF,0xF8,0x08,0xC8,0x30,0x08,0xC8,0x60,0x18,0xC4,0x60,0x78,0xC4,0xC0,
0x18,0xC2,0xC0,0x18,0xC3,0x80,0x31,0x83,0x80,0x31,0x86,0xC0,0x33,0x0C,0x70,0x12,0x30,0x3E,0x04,0xC0,0x18,0x09,0x00,0x00

};

unsigned char da[]= /*大*/

{

0x00,0x20,0x00,0x00,0x38,0x00,0x00,0x30,0x00,0x00,0x30,0x00,0x00,0x30,0x00,0x00,0x30,0x00,0x00,0x30,0x10,0x00,0x30,0x38,
0x3F,0xFF,0xFC,0x00,0x38,0x00,0x00,0x68,0x00,0x00,0x64,0x00,0x00,0x64,0x00,0x00,0xC6,0x00,0x00,0xC2,0x00,0x01,0x83,0x00,
0x01,0x81,0x80,0x03,0x00,0xC0,0x06,0x00,0xF0,0x0C,0x00,0x78,0x18,0x00,0x3E,0x20,0x00,0x18,0x40,0x00,0x00,0x00,0x00,0x00,

};
unsigned char xue[]= /*学*/
{

0x00,0x20,0x00,0x08,0x30,0x40,0x04,0x10,0xF0,0x06,0x18,0xC0,0x03,0x18,0x80,0x03,0x11,0x80,0x12,0x01,0x0C,0x1F,0xFF,0xFE,
0x30,0x00,0x0C,0x70,0x00,0x18,0x60,0x00,0xD0,0x07,0xFF,0xE0,0x00,0x01,0x80,0x00,0x16,0x00,0x00,0x18,0x00,0x00,0x18,0x0C,
0x7F,0xFF,0xFE,0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,0x00,0x18,0x00,0x01,0xF8,0x00,0x00,0x70,0x00,0x00,0x20,0x00

};

unsigned char ASCII_A[]= /*A*/

{
0x00, 0x00, 0x00, 0x10, 010, 0x18, 0x28, 0x28, 0x24, 0x3C, 0x44, 0x42, 0x42, 0xE7, 0x00, 0x00

};

unsigned char ASCII_R[]= /*R*/

{

0x00, 0x00, 0x00, 0xFC, 0x42, 0x42, 0x42, 0x7C, 0x48, 0x48, 0x44, 0x44, 0x42, 0xE3, 0x00, 0x00

};

unsigned char ASCII_M[]= /*M*/

{

0x00, 0x00, 0x00, 0xEE, 0x6C, 0x6C, 0x6C, 0x6C, 0x54, 0x54, 0x54, 0x54, 0x54, 0xD6, 0x00, 0x00

};



/*绘制背景*/

void Brush_Background( U32 c)

{

int x,y ;

for( y = 0 ; y < LCD_HEIGHT ; y++ )

{

for( x = 0 ; x < LCD_WIDTH ; x++ )

{

LCD_BUFFER[y][x] = c ;

}

}

}



/*绘制像素点*/

void PutPixel(U32 x,U32 y, U32 c )

{

LCD_BUFFER[y][x] = c;

}



/*绘制大小为24×24的中文字符*/
/*把LCD看成点阵,将数组char[]中的数据读出,即点亮像素点,像素点颜色有自己来定,即通过PutPixel()函数来给要显示的文字上色。每一个中文字符都是由24×24个像素点(可以认为是点阵),本代码逐行扫描每行,先从左到右,在从上到下扫描点亮像素点。中文字符的宽度与ASCII码字符宽度不同,一般ASCII字符宽度是中文字符的一半。在字符取模的时候,尽量宽和高都取成8的倍数,这样读取字符2进制数组时比较容易

*/
void Draw_Text24(U32 x,U32 y,U32 color,const unsigned char ch[])

{

unsigned short int i,j;

unsigned char mask,buffer;



for(i=0;i<24;i++)

{

mask=0x80; /*掩码*/

buffer=ch[i*3]; /*提取一行的第一个字节*/

for(j=0;j<8;j++)

{

if(buffer&mask)

{

PutPixel(x+j,y+i,color); /*为笔画上色*/

}

mask=mask>>1;

}

mask=0x80; /*掩码*/

buffer=ch[i*3+1]; /*提取一行的第二个字节*/

for(j=0;j<8;j++)

{

if(buffer&mask)

{

PutPixel(x+j+8,y+i,color); /*为笔画上色*/

}

mask=mask>>1;

}
mask=0x80;
buffer=ch[i*3+2];
for(j=0;j<8;j++)

{

if(buffer&mask)

{

PutPixel(x+j+16,y+i,color); /*为笔画上色*/

}

mask=mask>>1;

}

}

}



/*绘制大小为8×16的ASCII码*/

void Draw_ASCII(U32 x,U32 y,U32 color,const unsigned char ch[])

{

unsigned short int i,j;

unsigned char mask,buffer;



for(i=0;i<16;i++)

{

mask=0x80;

buffer=ch[i];

for(j=0;j<8;j++)

{

if(buffer&mask)

{

PutPixel(x+j,y+i,color);

}

mask=mask>>1;

}

}

}



/*LCD初始化*/

void LCD_Init()

{
/*设置LCD引脚*/
rGPCUP = 0x00000000;

rGPCCON = 0xaaaa02a9;

rGPDUP = 0x00000000;

rGPDCON=0xaaaaaaaa;



rLCDCON1=(CLKVAL_TFT<<8)|(MVAL_USED<<7)|(PNRMODE_TFT<<5)|(BPPMODE_TFT<<1)|0;

rLCDCON2=(VBPD<<24)|(LINEVAL<<14)|(VFPD<<6)|(VSPW);

rLCDCON3=(HBPD<<19)|(HOZVAL<<8)|(HFPD);

rLCDCON4=(HSPW);

rLCDCON5 = (BPP24BL<<12) | (INVVCLK<<10) | (INVVLINE<<9) | (INVVFRAME<<8) | (0<<7) | (INVVDEN<<6) | (PWREN<<3) |(BSWP<<1) | (HWSWP);



rLCDSADDR1=(((U32)LCD_BUFFER>>22)<<21)|M5D((U32)LCD_BUFFER>>1);

rLCDSADDR2=M5D( ((U32)LCD_BUFFER+(LCD_WIDTH*LCD_HEIGHT*4))>>1 );

rLCDSADDR3=LCD_WIDTH*4/2;

rLCDINTMSK|=(3);

rTCONSEL = 0;



rGPGUP=rGPGUP&(~(1<<4))|(1<<4);

rGPGCON=rGPGCON&(~(3<<8))|(3<<8);

rGPGDAT = rGPGDAT | (1<<4) ;

rLCDCON5=rLCDCON5&(~(1<<3))|(1<<3);

rLCDCON5=rLCDCON5&(~(1<<5))|(0<<5);

}



void Main(void)

{



LCD_Init();



rLCDCON1|=1; /*开启LCD显示*/



Brush_Background(0xFFFFFF); /*绘制白色背景*/



/*绘制黑色字符*/

Draw_Text16(50,100,0xff,ning);

Draw_Text16(74,100,0xff00,bo);

Draw_Text16(96,100,0xffff00,da);

Draw_Text16(120,100,0xff0000,xue);

Draw_ASCII(50,130,0x0,ASCII_A);

Draw_ASCII(62,130,0x0,ASCII_R);

Draw_ASCII(74,130,0x0,ASCII_M);

while(1)

{

;

}

}
 


效果图:
s3c2440之LCD字符显示 - 成 - 学海泛舟
关键字:s3c2440  LCD字符显示 引用地址:s3c2440之LCD字符显示

上一篇:ARM裸机程序——跑马灯
下一篇:基于s3c2440实现的裸机数码相框

推荐阅读最新更新时间:2024-03-16 15:04

05-S3C2440学习之内核(移植)linux3.4.2移植(1) 简单移植+修改MTD分区+制作jffs2文件系统
一、框架介绍及简单修改 1.1 Bootloader如何引导内核 Bootloader的工作: (1)讲内核读入内存中 (2)存一些内核启动参数到指定位置,内核启动时去解析 (3)启动内核,传入机器ID 1.2、内核的启动流程: 首先 内核的最终目的是挂接根文件系统,并启动应用程序。 想启动应用程序—需要挂接根文件系统—装载驱动程序(flash、网卡)--要解析参数(文件系统在哪)--根据R1判断内核是否支持该ID—支持调用初始化相关函数 每个开发板都有不同的硬件参数 内核移植过程中要决定我这个内核支持哪些硬件开发板 我在内核里针对这个开发板给他一个ID。Uboot启动的时候传入和内核中设置好的匹配
[单片机]
05-S3C2440学习之内核(移植)linux3.4.2移植(1) 简单移植+修改MTD分区+制作jffs2文件系统
uboot-2011.12移植到S3C2440(三)——硬件初始化:看门狗、中断、时钟
/* * turn off dog, see C18P3 */ ldr r0, =pWTCON mov r1, #0x0 str r1, /* * C14 * mask all IRQs by setting all bits in the INTMR - default */ mov r1, #0xffffffff ldr r0, =INTMSK str r1, ldr r1, =0x7fff ldr r0, =INTSUBMSK str r1, /* * FCLK:HCLK:P
[单片机]
基于S3C2440嵌入式系统主板的电磁兼容性设计
    随着电子设备的频率越来越高,世界各国对电子产品电磁辐射标准的执行变得越来越严格,如何保证能在有限时间很好地在设计阶段发现并解决EMI/EMC问题非常重要,而PCB往往是一个电子系统的核心构成部分,一个经仔细电磁干扰设计的PCB板,能大幅度降低阻抗不匹配、传输线问题、信号互相耦合等现象引发的信号反射、延迟等线路不稳定因素,同时也可达到降低电磁辐射发射干扰,大大提高系统的稳定性和可靠性。本文将以嵌入式系统主板为平台,运用 EMIStream仿真软件,并采用源端串联端接阻抗的方法分析了解决嵌入式高速主板存在的电磁干扰问题。 1 电磁兼容性 1.1 电磁兼容和电磁干扰     电磁兼容(electro magnetic
[嵌入式]
S3C2440芯片的时钟体系结构
下图是S3C2440芯片的整体架构图: 其中, AHB BUS为高速设备的总线,H即为high的意思。 APB BUS为低速设备的总线,P为英文单词peripheral(外围设备)。 不同的总线,挂载在上面的设备运行的频率肯定是不一样的,在我们这款S3C2440芯片中: Fclk就是CPU的运行频率,最高可达400MHz Hclk为高速设备的运行频率,最高可达136MHz Pclk为低速设备的运行频率,最高可达68MHz 那么这三种时钟频率是怎么得到的,他们又是什么关系呢? S3C2440这款芯片的时钟源为一个12M的晶振,再配合PLL(锁相环)就可以获得相应的频率。这里我们不对PLL的工作原理
[单片机]
<font color='red'>S3C2440</font>芯片的时钟体系结构
s3c2440裸机-异常中断(四. irq之外部中断)
中断前: 中断产生后: 问题案例: 我们想实现一个按键点灯程序,我们知道有以下两种方案: 1.轮询方案:轮询检测按键的电平状态,当检测到被按下后,对应的gpio会拉低,点亮对应的led;(略) 2.中断方案:将按键配置成外部中断源,当有按键按下,触发中断,在中断服务程序(isr)中去完成点灯。 下面开始写代码: 一.中断初始化 1)中断源设置 我们用按键作为外部中断源,我们把按键对应的gpio配置成中断引脚,当按键按下,相应的gpio产生了电平跳变,就会触发外部中断。 我们想达到按下按键灯亮,松开按键灯灭这种效果(配成双边沿触发,按下的时候产生下降沿中断,进行点亮,松开产生上升沿中断,进行熄灭)。当然也可做成按一下
[单片机]
<font color='red'>s3c2440</font>裸机-异常中断(四. irq之外部中断)
三 ARM9(S3C2440)的串口UART——程序实例讲解
串口通信程序编写步骤 UART通信程序可以采用查询、中断和DMA模式。我们通过使用较多的中断方式来介UART通信程序的编写。简单做法是,UART通信程序的编写参照例子程序。 选通道,通过函数Uart_Select();选UART0~UART2; 选波特率和波特率发生器时钟,选波特率通过函数Uart_Pclk_En(int ch, int baud)或Uart_Pclk_En(int ch, int baud)来进行。时钟选UCLK ,rUCON0|=0x400;时钟选PCLK ,rUCON0&=0x3ff。 通信协议(rULCON0)设定,如果正常通信,一位停止位,8位数据位,无奇偶效验: rULCON0=(0 6)|(0
[单片机]
S3C2440之ADC
S3C2440包含一个8通道A/D转换器,有10位分辨率下面简要介绍一下S3C2440中ADC的用法: 用到的寄存器: ADCCON:ADC控制寄存器 ADCDAT0:ADC转换数据寄存器 SUBSRCPND:次级源挂起寄存器 INTSUBMSK:中断次级屏蔽寄存器 SRCPND:源挂起寄存器 INTPND:中断挂起寄存器 INTMSK:中断屏蔽寄存器 ADCCON:AD控制寄存器 ADCDAT0:AD转换数据寄存器 1,首先设置控制寄存器ADCCON的相应位来选择频率和通道: view plain copy rADCCON = (1 14)|(preScale
[单片机]
<font color='red'>S3C2440</font>之ADC
基于Linux NFS的Web数码相框设计
   O 引言   随着数码相机和互联网的普及,越来越多的家庭拥有自己的媒体库。媒体库中既包含有自己拍摄的影像文件,也有从网络上下载的影像资料。然而展示影像资料的手段单一,主要通过PC来实现。因此未来构建以媒体库为中心的家庭多媒体网络,把多媒体资料在各式各样的家庭网络媒体终端上展示出来,将成为一种必然的趋势。媒体终端包括Web数码相框、网络数字电视等。   Web数码相框的提出正是为了设计一种家庭嵌入式网络媒体终端,但目前市场上常见的数码相框的网络可扩展性差,本设计方案的提出正是为了能够弥补这方面的不足,提高网络可扩展性。并在本设计方案的基础上构建网络数字电视等其他多功能终端实体。    1 技术方案   Web数
[嵌入式]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved