基于OLED液晶显示器的显示系统(共24页).docx





《基于OLED液晶显示器的显示系统(共24页).docx》由会员分享,可在线阅读,更多相关《基于OLED液晶显示器的显示系统(共24页).docx(24页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上基于OLED液晶显示器的显示系统 姓名:唐旭晴学号:班级:11电子2班一、实习目的(1)了解飞思卡尔单片机的基本原理,掌握其基本的工作流程。(2)了解OLED液晶显示屏的基本原理及用法。(3)能够熟练使用CodeWarrior软件编写C语言程序,使用BDM仿真器下载程序。(4)能够熟练焊接电路板。二、实验设备与器件CodeWarrior软件,BDM仿真器,万用电路板,飞思卡尔单片机,OLED液晶显示器三、实验内容内容:利用飞思卡尔单片机制作基于OLED液晶显示器的显示系统要求:用四个按键控制,按下第一个按键显示“北”,按下第二个按键显示“京”,按下第三个按键显示“印刷
2、”,按下第四个按键显示“学院”。(1)OLED,即有机发光二极管(Organic Light-Emitting Diode),又称为有机电激光显示(Organic Electroluminesence Display, OELD)。OLED由于同时具备自发光,不需背光源、对比度高、厚度薄、视角广、反应速度快、可用于挠曲性面板、使用温度范围广、构造及制程较简单等优异之特性,被认为是下一代的平面显示器新兴应用技术。LCD都需要背光,而OLED不需要,因为它是自发光的。这样同样的显示,OLED效果要来得好一些。以目前的技术,OLED的尺寸还难以大型化,但是分辨率确可以做到很高。我们使用的是ALINE
3、TEK的OLED显示模块,该模块有以下特点:1)模块有单色和双色两种可选,单色为纯蓝色,而双色则为黄蓝双色。2)尺寸小,显示尺寸为0.96寸,而模块的尺寸仅为27mm*26mm大小。3)高分辨率,该模块的分辨率为128*64。4)多种接口方式,该模块提供了总共4种接口包括:6800、8080两种并行接口方式、4线SPI接口方式以及IIC接口方式。5)不需要高压,直接接3.3V就可以工作了。这里我们采用的是4线串行(SPI)方式,4先串口模式使用的信号线有如下几条:CS:OLED片选信号。RST(RES):硬复位OLED。DC:命令/数据标志(0,读写命令;1,读写数据)。SCLK:串行时钟线。
4、在4线串行模式下,D0信号线作为串行时钟线SCLK。SDIN:串行数据线。在4线串行模式下,D1信号线作为串行数据线SDIN。模块的D2需要悬空,其他引脚可以接到GND。在4线串行模式下,只能往模块写数据而不能读数据。在4线SPI模式下,每个数据长度均为8位,在SCLK的上升沿,数据从SDIN移入到SSD1306,并且是高位在前的。DC线还是用作命令/数据的标志线。在4线SPI模式下,写操作的时序如图17.1.6所示: 4线SPI写操作时序图模块的显存:SSD1306的显存总共为128*64bit大小,SSD1306将这些显存分为了8页,其对应关系如下表所示:SSD1306显存与屏幕对应关系表
5、(2)飞思卡尔单片机的功能及特点:MC9S12XS128 是 16 位单片机,由 16 位中央处理单元(CPU12X)、128KB 程序、Flash(P-lash)、8KB RAM、8KB 数据 Flash(D-lash)组成片内存储器。主要功能模块包括:内部存储器, 内部 PLL 锁相环模块 ,2 个异步串口通讯 SCI ,1个串行外设接口 SPI MSCAN 模块 ,1 个 8 通道输入/输出比较定时器模块 TIM ,周期中断定时器模块 PIT ,16 通道 A/D 转换模块 ADC ,1 个 8 通道脉冲宽度调制模块 PWM ,输入/输出数字 I/O 口。本次设计中主要用到PORTA,P
6、ORTB端口:PORTA:PORTA 为通用 I/O 口, 共 8 个,作为通用数字 I/O 口使用,未集成特殊功能.主要配置寄存器有:数据寄存器 PORTA、数据方向寄存 DDRA、上拉电阻控制寄存器PUCR 和驱动控制寄存器 RDR。a. 数据寄存器 PORTA通过写 1/0 使单片机对应引脚输出高低电平,或通过读取数据寄存器获得对应引脚的高低电平值 。例:PORTA_PB0=1b. 数据方向寄存器 DDRADDRA 寄存器配置引脚为输出口还是输入口,“0”,输入口;“1”,输出口。MCU 复位后,DDRA 值为 0x00, 引脚默认为输入口。例:DDRA=0xFF /配置 PORTA 口
7、为输出 PORTB:PORTB 为通用数字 I/O 口, 共 8 个。其使用与 PORTA 基本一样。主要配置寄存器有:数据寄存器 PORTB、数据方向寄存 DDRB。上拉电阻控制寄存器 PUCR 和驱动控制寄存器 RDR 与 PORTA 、PORTB、PORTE、PORTK 共用。a.数据寄存器 PORTBb.数据方向寄存器 DDRB四、原理图: 器件说明:OLED液晶显示器(8管脚), 4个1k电阻,4个按键 ,飞思卡尔芯片(64管脚) 管脚连接:GNDGNDFMQAN07VCCVCCKEYMOSI0D0PB4PA1PA1D1PB3PA2PA2RSTPB1PA3PA3DCPB2PA4PA4
8、五、流程图 复位SSD1306驱动IC初始代码开启显示清0显存开始显示六、程序设计1. void pll_set(void):内部锁相环模块,单片机使用PLL功能能够获得更高的总线频率,这对于需要提高单片机运行速度的应用场合非常必要。2. void OLED_Init(void):初始化OLED液晶显示屏 3. void LCD_WrCmd(byte cmd):写指令函数4. void LCD_WrDat(byte data):写数据函数5.void LCD_PutPixel(byte x,byte y):填充一个点6. void LCD_P6x8Str(byte x,byte y,byte
9、ch):显示字符串函数7. void main(void):主函数#include main.h /所有头文件已包含在在include.h里 unsigned char ch_data= -By tangxuqing; /显示数组/* 延时函数*/void delayms(unsigned long ms) unsigned int ii,jj; if(ms1) ms=1; for(ii=0;iims;ii+) for(jj=0;jj3338*2;jj+); /80MHz-1ms /* 时钟设置 * 通过锁相环(PLL)设置系统时钟为56M */void pll_set(void) CLKSE
10、L=0X00; PLLCTL_PLLON=1; SYNR =0xc0 | 0x06; REFDV=0x80 | 0x01; POSTDIV=0x00; _asm(nop); _asm(nop); _asm(nop); _asm(nop); while(!(CRGFLG_LOCK=1); CLKSEL_PLLSEL =1; /* 对I/O口的初定义 * */void init_IO(void) DDRA = 0xff; PORTA = 0xfb; /* 主函数 * */void main(void) /* put your own code here */ _DISABLE_COP(); /关看
11、门狗 DisableInterrupts; /关中断 pll_set(); /锁相环初始化56MHz uart_init(); /串口初始化(中断,9600) OLED_Init(); /OLED初始化 sound_init(); /声音初始化 init_IO(); /通用I/O口初始化 LCD_P6x8Str(1,6,ch_data); /显示开机界面 kaiji_fmq();/开机声音 DDRA_DDRA1 = 0; DDRA_DDRA2 = 0; DDRA_DDRA3 = 0; DDRA_DDRA4 = 0; /SET PORTA I/O INPUT PORTAB_PA1 = 1; PO
12、RTAB_PA2 = 1; PORTAB_PA3 = 1; PORTAB_PA4 = 1;EnableInterrupts; for(;) /_FEED_COP(); /* feeds the dog */ /* for(i=0;i32;i+) /扫描显示点 for(j=0;j128;j+) LCD_PutPixel(j,i); delayms(1); */ / LCD_P6x8Str(0,0,ch_data); if(!PORTA_PA1) LCD_P6x8Str(1,2,1); if(!PORTA_PA2) LCD_P6x8Str(1,3,2); if(!PORTA_PA3) LCD_P6
13、x8Str(1,4,3); if(!PORTA_PA4) LCD_P6x8Str(1,5,4); /* loop forever */ /* please make sure that you never leave main */OLED.c函数(子程序函数) #define OLED_GLO#include oled.h#define XLevelL0x00#define XLevelH0x10#define XLevel(XLevelH&0x0F)*16+XLevelL)#define Max_Column128#define Max_Row 64#defineBrightness0xC
14、F/*4线SPI使用说明:VBT 供内部DC-DC电压,3.34.3V,如果使用5V电压,为保险起见串一个100500欧的电阻VCC 供内部逻辑电压 1.86VGND 地BS0 低电平BS1 低电平BS2 低电平CS 片选管脚DC 命令数据选择管脚RES 模块复位管脚D0(SCLK) ,时钟脚,由MCU控制D1(MOSI) ,主输出从输入数据脚,由MCU控制D2 悬空D3-D7 , 低电平 , 也可悬空,但最好设为低电平RD 低电平 ,也可悬空,但最好设为低电平RW 低电平 ,也可悬空,但最好设为低电平RD 低电平 ,也可悬空,但最好设为低电平C7-D0(SCLK)时钟脚,由MCU控制C6-D
15、1(MOSI)主输出从输入数据脚,由MCU控制C0-RST 模块复位管脚C4-DC 命令数据选择管脚*/* 引脚定义 *PB1 RSTPB2 DCPB3 D1PB4 D0*/ #define X_WIDTH 128#define Y_WIDTH 64/=const byte F6x86 = 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 , / sp 0x00, 0x00, 0x00, 0x2f, 0x00, 0x00 , / ! 0x00, 0x00, 0x07, 0x00, 0x07, 0x00 , / 0x00, 0x14, 0x7f, 0x14, 0x7f, 0x
16、14 , / # 0x00, 0x24, 0x2a, 0x7f, 0x2a, 0x12 , / $ 0x00, 0x62, 0x64, 0x08, 0x13, 0x23 , / % 0x00, 0x36, 0x49, 0x55, 0x22, 0x50 , / & 0x00, 0x00, 0x05, 0x03, 0x00, 0x00 , / 0x00, 0x00, 0x1c, 0x22, 0x41, 0x00 , / ( 0x00, 0x00, 0x41, 0x22, 0x1c, 0x00 , / ) 0x00, 0x14, 0x08, 0x3E, 0x08, 0x14 , / * 0x00,
17、0x08, 0x08, 0x3E, 0x08, 0x08 , / + 0x00, 0x00, 0x00, 0xA0, 0x60, 0x00 , / , 0x00, 0x08, 0x08, 0x08, 0x08, 0x08 , / - 0x00, 0x00, 0x60, 0x60, 0x00, 0x00 , / . 0x00, 0x20, 0x10, 0x08, 0x04, 0x02 , / / 0x00, 0x3E, 0x51, 0x49, 0x45, 0x3E , / 0 0x00, 0x00, 0x42, 0x7F, 0x40, 0x00 , / 1 0x00, 0x42, 0x61, 0
18、x51, 0x49, 0x46 , / 2 0x00, 0x21, 0x41, 0x45, 0x4B, 0x31 , / 3 0x00, 0x18, 0x14, 0x12, 0x7F, 0x10 , / 4 0x00, 0x27, 0x45, 0x45, 0x45, 0x39 , / 5 0x00, 0x3C, 0x4A, 0x49, 0x49, 0x30 , / 6 0x00, 0x01, 0x71, 0x09, 0x05, 0x03 , / 7 0x00, 0x36, 0x49, 0x49, 0x49, 0x36 , / 8 0x00, 0x06, 0x49, 0x49, 0x29, 0x
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 OLED 液晶显示器 显示 系统 24

限制150内