版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
STM32學習筆記(6):LCD的顯示2011年4月14HLCD顯示.LCD/LCM的基本概念液晶顯示器(LiquidCrystalDisplay:LCD)的構造是在兩片平行的玻璃當中放置液態(tài)的晶體,兩片玻璃中間有許多垂直和水平的細小電線,透過通電與否來控制桿狀水晶分子改變方向,將光線折射出來產生畫面。LCM(LCDModule)即LCD顯示模組、液晶模塊,是指將液晶顯示器件,連接件,控制與驅動等外圍電路,PCB電路板,背光源,結構件等裝配在一起的組件。在平時的學習開發(fā)中,我們一般使用的是LCM,帶有驅動IC和LCD屏幕等多個模塊。.FSMC的基本概念在STM32上開發(fā)LCD顯示,可以有兩種方式來對LCD進行操作,一種是通過普通的10口,連接LCM的相應引腳來進行操作,第2種是通過FSMC來進行操作??勺冹o態(tài)存儲控制器(FlexibleStaticMemoryController:FSMC)是STM32系列中內部集成256KB以上FlaSh,后綴為xC、xD和xE的高存儲密度微控制器特有的存儲控制機制。之所以稱為“可變”,是由于通過對特殊功能寄存器的設置,F(xiàn)SMC能夠根據不同的外部存儲器類型,發(fā)出相應的數(shù)據/地址/控制信號類型以匹配信號的速度,從而使得STM32系列微控制器不僅能夠應用各種不同類型、不同速度的外部靜態(tài)存儲器,而且能夠在不增加外部器件的情況下同時擴展多種不同類型的靜態(tài)存儲器,滿足系統(tǒng)設計對存儲容量、產品體積以及本錢的綜合要求。FSMC有很多優(yōu)點:.支持多種靜態(tài)存儲器類型。STM32通過FSMC可以與SRAM、ROM、PSRAM、NORFlash和NANDFlash存儲器的引腳直接相連。.支持豐富的存儲操作方法。FSMC不僅支持多種數(shù)據寬度的異步讀/寫操作,而且支持對NOR、PSRAM、NAND存儲器的同步突發(fā)訪問方式。FSMC_ExtendedMode=FSMC_ExtendedMode_Disable;〃設置是否使用異步等待信號(No)FSMC_AsyncWait=FSMC_AsyncWait_Disable;〃設置是否使用迸發(fā)寫模式(No)FSMC_WriteBurst=FSMC_WriteBurst_Disable;〃設定讀寫時序FSMC_ReadWriteTimingStruct=&p;〃設定寫時序FSMC_WriteTimingStruct=&p;FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);〃使能Bankl中的blocklFSMC_NORSRAMCmd(FSMC_Bankl_NORSRAMl,ENABLE);)//GPIO配置voidGPIO_cfg()(GPIOJnitTypeDefGPIO_lnitStructure;〃背光控制GPIOPin=GPIOPin13;GPIO_Mode=GPIO_Mode_Out_PP;GPIO_Speed=GPIO_Speed_50MHz;GPIOJnit(GPIOD,&GPIO_lnitStructure);//LCD復位GPIO_Pin=GPIO_Pin_l;GPIOJnit(GPIOE,&GPIO_lnitStructure);〃翻開FSMC的數(shù)據端口D[15:0]GPIOPin=GPIOPin0IGPIOPin1IGOOPin8IGPIOPin9|GPIO_Pin_10|GPIO_Pin_14|GPIO_Pin_15;GPIO_Speed=GPIO_Speed_50MHz;GPIO_Mode=GPIO_Mode_AF_PP;GPIO_lnit(GPIOD,&GPIO_lnitStructure);GPIOPin=GPIOPin7IGPIOPin8IGPIOPin9IGPIOPin10|GPIOPin11IGPIOPin12IGPIOPin13IGPIOPin14|GPIO_Pin_15;GPIO_lnit(GPIOE,&GPIO_lnitStructure);〃翻開FSMC功能端口,PD.4=RD(nOE);PD.5=WR(nWE)GPIO_Pin=GPIO_Pin_4|GPIO_Pin_5;GPIO_lnit(GPIOD,&GPIO_lnitStructure);〃翻開NE1設置GPIO_Pin=GPIO_Pin_7;GRIOJnit(GPIOD,&GPIO_lnitStructure);〃翻開RS設置GPIOPin=GPIOPin11;GPIO_lnit(GPIOD,&GPIO_lnitStructure);//NE1=1GPIO_SetBits(GPIOD,GPIO_Pin_7);〃LCD_RESET=0GPIO_ResetBits(GPIOE,GPIO_Pin_l);//LCD_RD=l(nOE)GPIO_SetBits(GPIOD,GPIO_Pin_4);//LCD_WR=l(nWE)GPIO_SetBits(GPIOD,GPIO_Pin_5);〃背光LIGHT=1GPIO_SetBits(GPIOD,GPIO_Pin_13);)//LCD初始化voidLCD_cfg()(〃復位LCDLCD_rst();//LCD初始化LCD_lnit();)//LCD顯不圖片〃根據LCD_lnit里面的配置,LCD的原點在左下角,終點在右上角;先縱向增長,再橫向增長voidLCD_Show(unsignedchar*LCDJmage)(u32n=0;ul6temp=0;〃設置進入模式〃AM=1:地址在水平寫入方向上更新//l/D[l:0]=01:水平方向遞增,垂直方向遞減//BGR=1:RGB數(shù)據轉換為BGR數(shù)據//TRI=0;DFM=0;〃詳細信息參考ILI93258.2.5EntryModeLCD_WR_CMD(0x0003,0x1018);//GRAM的水平地址//8.2.18GRAMHorizontal/VerticalAddressSetLCD_WR_CMD(OxOO2O,0x0000);//GRAM的垂直地址LCD_WR_CMD(0x0021,OxO13F);〃水平方向開始地址LCD_WR_CMD(0x0050,0x0000);〃水平方向結束地址(0-239)LCD_WR_CMD(0x0051,OxOOEF);〃垂直方向開始地址LCD_WR_CMD(0x0052,0x0000);〃垂直方向結束地址(0?319)LCD_WR_CMD(0x0053,0x013F);〃寫數(shù)據地址〃因為是16bits一起寫入,而圖像數(shù)據數(shù)組中是每個數(shù)據8bits,〃所以是2個8bits的數(shù)據合并成一個16bits的數(shù)據,再寫入GRAMLCD_WR_ADD(0x0022);while(n<153600)(temp=(ul6)(LCD_lmage[n]?8)+LCD_lmage[n+l];LCD_WR_DATA(temp);n+=2;))stm32fl0x_lcd.c中的代碼#include"stm32flOx_lcd.h"〃數(shù)據區(qū)地址#defineBankl_LCD_Data((u32)0x)〃寄存器區(qū)地址#defineBankl_LCD_Reg((u32)0x)u32colorl=0;〃延時函數(shù)voidDelay(u32nCount)(for(;nCount!=0;nCount-);)//LCD復位voidLCD_rst()(〃PE.1連接LCD的reset引腳GPIO_ResetBits(GPIOE,GPIO_Pin_l);Delay(OxAFFFFf);GPIO_SetBits(GPIOE,GPIO_Pin_l);Delay(OxAFFFFf);〃LCD寫寄存器地址函數(shù)voidLCD_WR_ADD(ul6index)((vul6*)(Bankl_LCD_Reg)=index;)//LCD寫數(shù)據函數(shù)voidLCD_WR_DATA(ul6val)((vul6*)(Bankl_LCD_Data)=val;)〃LCD寫寄存器命令函數(shù),先將命令地址寫到Reg中,然后再將命令的數(shù)值寫到Data中〃具體地址和配置參照ILI9325的DatasheetvoidLCD_WR_CMD(u16index,ul6val)((vul6*)(Bankl_LCD_Reg)=index;*(vul6*)(Bankl_LCD_Data)=val;)voidLCD_lnit()(〃設置內部時鐘LCD_WR_CMD(0x00E3,0x3008);LCD_WR_CMD(0x00E7,0x0012);LCD_WR_CMD(0x00EF,0x1231);〃啟動振蕩,ILI9325可以不要這一*句LCD_WR_CMD(0x0000,0x0001);〃設置驅動器輸出控制,SS=1,SM=0〃當SS=O時,源輸出信號從S1開始至S720結束;〃當SS=1時:源輸出信號從S720開始至S1結束。//SM和GS搭配使用,具體查看ILI93258.2.3DriverOutputContorlLCD_WR_CMD(0x0001,0x0100);//LCD波形控制//B/C=l:行反轉;//EOR=1和B/C=l:設置行反轉//8.2.4LCDDrivingWaveControlLCD_WR_CMD(0x0002,0x0700);〃設置進入模式〃AM=1:地址在水平寫入方向上更新//l/D[l:0]=01:水平方向遞增,垂直方向遞減//BGR=1:RGB數(shù)據轉換為BGR數(shù)據//TRI=0;DFM=0;〃詳細信息參考ILI93258.2.5EntryModeLCD_WR_CMD(0x0003,0x1018);〃重新調整控制寄存器大小//8.2.6ResizingControlRegisterLCD_WR_CMD(0x0004,0x0000);〃顯示器控制2//FP[3:0]=0010;//BP[3:0]=0010;〃詳細信息參考ILI93258.2.8DisplayControl2LCD_WR_CMD(0x0008,0x0202);〃顯示器控制3〃設置非顯示區(qū)域刷新//8.2.9DisplayControl3LCD_WR_CMD(0x0009,0x0000);〃顯示器控制4//FMARK信號設置//8.2.10DisplayControl4LCD_WR_CMD(0x000A,0x0000);//RGB顯示接口控制1//8.2.11RGBDisplayInterfaceControl1LCD_WR_CMD(0x000C,0x0000);〃幀標記位置//8.2.12FrameMarkerPositionLCD_WR_CMD(0x000D,0x0000);//RGB顯示接口控制2//8.2.13RGBDisplayInterfaceControl2LCD_WR_CMD(0x000F,0x0000);〃功率控制1//8.2.14PowerControl1LCD_WR_CMD(0x0010,0x0000);〃功率控制2//8.2.15PowerControl2//VC[2:0]=lll:參考電壓為VciLCD_WR_CMD(0x0011,0x0007);〃功率控制3//8.2.16PowerControl3LCD_WR_CMD(0x0012,0x0000);〃功率控制4//8.2.17PowerControl4LCD_WR_CMD(0x0013,0x0000);〃延時,放電Delay(200);〃功率控制1//SAP=1:源驅動程序被啟動//BT[2:0]=110://APE=1:開始供應電力//AP[2:0]=001:伽馬驅動放大和源驅動放大LCD_WR_CMD(0x0010,0x1690);〃功率控制2//DCl[2:0]=010:選擇升壓電路2工作頻率Fosc/16//DC0[2:0]=010:選擇升壓電路1工作頻率Fosc/4//VC[2:0]=lll:參考電壓為VciLCD_WR_CMD(0x0011,0x0227);〃延時Delay(50);〃功率控制3//PON=1:控制線路3(VGL)開啟//VRH[3:0]=1100:設置外部參考電壓LCD_WR_CMD(0x0012,OxOOlC);〃延時Delay(50);〃功率控制4//VDV[4:0]=11000:設置Vcom的電壓振幅交替LCD_WR_CMD(0x0013,0x1800);〃功率控制7//8.2.21PowerControl7//VCM[5:0]=011100:設置內部VcomH電壓LCD_WR_CMD(0x0029,OxOOlC);〃幀速率和色彩控制//8.2.22FrameRateandColorControl//FRS[3:0]:1101:幀率128LCD_WR_CMD(0x002B,OxOOOD);〃延時Delay(50);//GRAM的水平地址//8.2.18GRAMHorizontal/VerticalAddressSetLCD_WR_CMD(0x0020,0x0000);//GRAM的垂直地址LCD_WR_CMD(0x0021,0x0000);〃伽馬控制//8.2.23GammaControlLCD_WR_CMD(0x0030,0x0007);LCD_WR_CMD(0x0031,0x0302);LCD_WR_CMD(0x0032,0x0105);LCD_WR_CMD(0x0035,0x0206);LCD_WR_CMD(0x0036,0x0808);LCD_WR_CMD(0x0037,0x0206);LCD_WR_CMD(0x0038,0x0504);LCD_WR_CMD(0x0039,0x0007);LCD_WR_CMD(0x003C,0x0105);LCD_WR_CMD(0x003D,0x0808);〃水平和垂直位置的RAM地址//8.2.24HorizontalandVerticalRAMAddressPosition〃水平方向開始地址LCD_WR_CMD(0x0050,0x0000);〃水平方向結束地址(0-239)LCD_WR_CMD(0x0051,OxOOEF);〃垂直方向開始地址LCD_WR_CMD(0x0052,0x0000);〃垂直方向結束地址(0?319)LCD_WR_CMD(0x0053,0x013F);〃門掃描控制//8.2.25GateScanControl〃GS=1:掃描方向是從G320至G1//NL[5:0]=100111LCD_WR_CMD(0x0060,0xA700);//NDL=0:在非顯示區(qū)域設置源驅動器的輸出極//VLE=0:垂直滾動顯示不可用//REV=1:圖像灰度反轉LCD_WR_CMD(0x0061,0x0001);//VL[8:0]=0LCD_WR_CMD(0x006A,0x0000);〃局部影像1顯示位置//8.2.26PartialImage1DisplayPositionLCD_WR_CMD(0x0080,0x0000);〃局部影像1RAM開始/結束地址//8.2.27PartialImage1RAMStart/EndAddressLCD_WR_CMD(0x0081,0x0000);LCD_WR_CMD(0x0082,0x0000);〃局部影像2顯示位置//8.2.28.PartialImage2DisplayPositionLCD_WR_CMD(0x0083,0x0000);〃局部影像2RAM開始/結束地址//8.2.29PartialImage2RAMStart/EndAddressLCD_WR_CMD(0x0084,0x0000);LCD_WR_CMD(0x0085,0x0000);〃平板接口控制1//8.2.30PanelInterfaceControl1〃RTNI[4:0]=10000:設置內部時鐘運行模式中1線時鐘的數(shù)目:〃個LCD_WR_CMD(0x0090,0x0010);〃平板接口控制2//8.2.31PanelInterfaceControl2LCD_WR_CMD(0x0092,0x0000);LCD_WR_CMD(0x0093,0x0003);〃平板接口控制4//8.2.32PanelInterfaceControl4LCD_WR_CMD(0x0095,0x0110);LCD_WR_CMD(0x0097,0x0000);LCD_WR_CMD(0x0098,0x0000);〃顯示控制1//8.2.7DisplayControl1//BASEE=1:顯示基本圖像//GON=1DTE=1:正常顯示//D[l:0]=ll:翻開顯示面板LCD_WR_CMD(0x0007,0x0133);〃GRAM寫入數(shù)據,用黑色清屏LCD_WR_ADD(0x0022);for(colorl=0;colorl<320*240;colorl++)(LCD_WR_DATA(0x0000);//)colorl=0;)stm32fl0x_lcd.h中的代碼#include"stm32fl0xJib.h"http://LCD復位函數(shù)voidLCD_rst();//LCD初始化函數(shù)voidLCD_lnit();〃延時函數(shù)voidDelay(u32nCount);〃LCD寫寄存器地址函數(shù)voidLCD_WR_ADD(ul6index);//LCD寫數(shù)據函數(shù)voidLCD_WR_DATA(ul6val);pijbit.c中的代碼和pijhit.c中的代碼由于太長了,所以并沒有貼出來,其實就是根據某一幅圖片用lmage2LCD生成的,其數(shù)組名分別叫constunsignedcharLCD_lmage_BIT[153600]constunsignedcharLCD_lmage_HIT[153600].支持同時擴展多種存儲器。FSMC的映射地址空間中,不同的BANK是獨立的,可用于擴展不同類型的存儲器。當系統(tǒng)中擴展和使用多個外部存儲器時,F(xiàn)SMC會通過總線懸空延遲時間參數(shù)的設置,防止各存儲器對總線的訪問沖突。.支持更為廣泛的存儲器型號。通過對FSMC的時間參數(shù)設置,擴大了系統(tǒng)中可用存儲器的速度范圍,為用戶提供了靈活的存儲芯片選擇空間。.支持代碼從FSMC擴展的外部存儲器中直接運行,而不需要首先調入內部SRAM。FSMC包含兩類控制器:1個NOR閃存/SRAM控制器,可以與NOR閃存、SRAM和PSRAM存儲器接口。1個NAND閃存/PC卡控制器,可以與NAND閃存、PC卡,CF卡和CF+存儲器接口??刂破鳟a生所有驅動這些存儲器的信號時序:位數(shù)據線,用于連接8位或16位的存儲器;位地址線,最多可連續(xù)64MB的存儲器(這里不包括片選線);5位獨立的片選信號線;組適合不同類型存儲器的控制信號線:控制讀/寫操作與存儲器通信,提供就緒/繁忙信號和中斷信號與所用配置的PC卡接口:PC存儲卡、PCI/O卡和真正的IDE接口從FSMC的角度看,可以把外部存儲器劃分為固定大小為256MB的4個存儲塊?存儲塊I用于訪問最多4個NOR閃存或者PSRAM存儲設備。這個存儲區(qū)被劃分為4個NOR/PSRAM區(qū),并有4個專用的片選。?存儲塊2和3用于訪問NAND閃存設備,每個存儲塊連接一個NAND閃存。?存儲塊4用于訪問PC卡設備每一個存儲塊上.的存儲器類型是由用戶在配置寄存器中定義的。注意:FSMC只是提供了一個控制器,并不提供相應的存儲設備,至于外設接的是什么設備,完全是由用戶自己選擇,只要能用于FSMC控制,就可以,像本次實驗中,我們接的就是LCM。3.本例中FSMC的使用由于本例只是利用FSMC對LCM進行操作,因此不用完全懂得FSMC的所有功能,而是懂得一局部相應的操作即可。LFSMC包括哪幾個局部FSMC包含以下4個模塊:AHB接口(包含F(xiàn)SMC配置寄存器)NOR閃存和PSRAM控制器NAND閃存和PC卡控制器外部設備接口需要注意的是,F(xiàn)SMC可以請求AHB進行數(shù)據寬度操作。如果AHB操作的數(shù)據寬度大于外部設備(NOR或NAND或LCD)的寬度,此時FSMC將AHB操作分割成幾個連續(xù)的較小的數(shù)據寬度,以適應外部設備的數(shù)據寬度。FSMC對外部設備的地址映像FSMC對外部設備的地址映像從0x600000()()開始,至U0x9FFFFFFF結束,一共4個地址塊,每個地址塊256MB,而每個地址塊又分成4個分地址塊,大小為64MB。對于NOR的地址映像來說,我們可以通過選擇HADDR[27:26]來確定當前使用的是哪個64M的分地址塊。而這四個分存儲塊的片選,那么使用NE[4:1]來選擇。數(shù)據線/地址線/控制線是共享的。這里的HADDR是需要轉換到外部設備的內部AHB地址線,每個地址對應一個字節(jié)單元。因此,假設外部設備的地址寬度是8位的,那么HADDR[25:0]與STM32的CPU引腳FSMC_A[25:0]一一對應,最大可以訪問64M字節(jié)的空間。假設外部設備的地址寬度是16位的,那么是HADDR[25:1]與STM32的CPU引腳FSMC_A[24:0]對應。在應用的時候,可以將FSMC_A總線連接到存儲器或其他外設的地址總線引腳上。.ILI9325由于我們使用的是奮斗STM32V3開發(fā)板,其內部自帶的是一個LCM,產品的編號是:QD024CPS25-36AV0,其中的詳細規(guī)格參數(shù)可以參考QD024CPS25-36AV0規(guī)格書中的記載。而LCM中的驅動IC就是采用的IL19325。ILI9325的功能很多,在此無法一一說明,但是參考ILI9325的Dalasheel我們發(fā)現(xiàn)有幾個引腳還是非常重要的,而只要操作好了這幾個引腳,基本上就可以實現(xiàn)簡單的對LCM的控制了。nCS:IC的片選信號。如果是低電平,貝UILI9325是被選中,并且可以進行操作,如果是高電平,這不被選中。RS:寄存器選擇信號。如果是低電平,那么選擇的是索引或者狀態(tài)寄存器,如果是高電平,那么選擇控制寄存器。nWR/SCL:寫使能信號,低電平有效。nRD:讀使能信號,低電平有效。以上內容是從ILI9325的Datasheet里面找到的,但是根據我的實際操作發(fā)現(xiàn),似乎高電平也是有效的。而且,不管是高電平還是低電平,都可以成功驅動LCD,如果有了解情況的可以討論一下。ILI9325的寄存器非常多,詳細的各個寄存器的功能請參考HJ9325的Datasheet。在對ILI9325進行操作時,應該先寫地址,然后再寫數(shù)據,設置好各個寄存器之后,ILI9325就可以開始工作了。.電路設計.信號線的連接STM32F10xFSMC有4個不同的banks,每一個64MB,可支持NOR以及其他類似的存儲器。這些外部設備的地址線、數(shù)據線和控制線是共享的。每個設備的訪問時通過片選信號來決定的,而每次只能訪問一個設備。我們的LCM就是連接在NOR的bank上面。FSMC_D[15:0]:16bit的數(shù)據總線,連接ILI9325的數(shù)據線;FSMC_NEx:分配給NOR的256MB的地址空間還可以分為4個banks,每一個區(qū)用來分配一個外設,這4個外設分別就是NE1-NE4;FSMC.NOE:輸出使能,連接ILI9325的nRD引腳;FSMC_NWE:寫使能,連接ILI9325的nWR引腳;FSMC_Ax:用在LCD顯示RAM和寄存器之間進行選擇的地址線,這個和ILI9325的RS引腳相連。該線可用任意一根地址線,范圍是FSMC_A[25:0]。當RS=0時,表示讀寫寄存器,RS=1時,表示讀寫數(shù)據RAM。其實關于RS的表述也并不完全準確,應該這么理解,RS=0的時候,向這個地址寫的數(shù)表示了選擇什么寄存器進行操作,然而要對寄存器進行什么操作,那么要看當RS=1時,送入的數(shù)據了。關于地址的計算,如果我們選擇NOR的第一個存儲區(qū),并且使用FSMC_A16來控制ILI9325的RS引腳,那么如果要訪問寄存器地址(RS=0),那么地址是0x60000000(起始地址),如果要訪問數(shù)據區(qū)(RS=1),那么基地址應該是0x60020000。有人會問,為什么不是()x60010000呢?因為FSMC_A16=1。因為在前文中已經說過,假設外部設備的地址寬度是16位的,那么是HADDR[25:1]與STM32的CPU引腳FSMC_A[24:0]對應。也就是說,內部產生的地址應該要左移一位,F(xiàn)SMC_A16=1,代表著第17位為1,而不是第16位為1。如果外部設備的地址寬度是8位的話,那么不會出現(xiàn)這個問題。再舉一個例子,如果選擇NOR的第4個存儲區(qū),使用FSMC_A0來控制RS引腳,那么訪問數(shù)據區(qū)的地址為0x60000002,訪問LCD寄存器的地址為:0x60000000o.時序問題一般使用模式2來做LCD的接口控制,不使用外擴模式。并且讀寫操作的時序一樣。此種情況下,我們需要使用3個參數(shù):ADDSET、DATAST.ADDHOLDo時序的計算需要根據NOR閃存存儲器的特性和STM32F10x的時鐘HCLK來計算這些參數(shù)。寫或讀訪問時序是存儲器片選信號的下降沿與上升沿之間的時間,這個時間可以由FSMC時序參數(shù)的函數(shù)計算得到:寫/讀訪問時間=((ADDSET+1)+(DATAST+1))XHCLK在寫操作中,DATAST用于衡量寫信號的下降沿與上升沿之間的時間參數(shù):寫使能信號從低變高的時間=tWP=DATASTXHCLK為了得到正確的FSMC時序配置,以下時序應予以考慮:最大的讀/寫訪問時間、不同的FSMC內部延遲、不同的存儲器內部延遲因此得到:((ADDSET+1)+(DATAST+l))xHCLK=max(tWC,IRC)DATASTxHCLK=tWPDATAST必須滿足:DATAST=(tAVQV+tsu(Data_NE)+tv(A_NE))/HCLK-ADDSET-4由于我沒有找到ILI9325的這些時序的參數(shù),所以就參考了一些以前別人寫的程序里面的時序配置:當HCLK的頻率是72MHZ,使用模式B,那么有如下時序:地址建立時間:0x1地址保持時間:0x()數(shù)據建立時間:()x5.程序編寫步驟對于程序的編寫,一般步驟是:.初始化RCC;.初始化GPIO;.初始化FSMC;.初始化LCD;.往GRAM里面寫入顯示數(shù)據。其中RCC、GPIO、FSMC的初始化函數(shù)在STM32的固件庫中已經有相應的函數(shù),在此就不贅述了,如果有不懂的,可以參考以前我寫的學習筆記。FSMC的初始化參數(shù)很多,而且基本上可以通用,因此在此也不對每一個參數(shù)具體有什么用進行解釋了,一般來說,用通用參數(shù)就足夠普通的開發(fā)了。而對LCD的初始化,那么需要自己編寫相應的代碼?;驹敲词?,首先向寄存器地址寫入需要操作的寄存器地址(代碼),然后再根據Datasheet,向數(shù)據區(qū)地址寫入相應的數(shù)據,以實現(xiàn)某些操作。具體的操作在ILI9325的Datasheet第8節(jié)RegisterDescriptions中,有詳細的解釋。而LCD的初始化只要按照Datasheet里面的,把每一個寄存器都給配置好了,就沒有問題了。而這些寄存器的配置,大局部都是通用的,只是有一些屏幕方向選擇,坐標系等會略有差異。LCD配置好之后,就可以往GRAM里面寫入圖像數(shù)據了,在這里推薦一個軟件“Image2LCD”,這個軟件能讀取圖像,然后生成C代碼的數(shù)據,只要將這些生成的代碼直接寫入GRAM中,就可以顯示出圖像了。不過要記住,在圖像轉換的時候,輸出數(shù)據類型選擇“C語言數(shù)組”,掃描模式選擇“水平掃描”,輸出灰度“16位真彩色”,最大寬度和高度“320”“240”勾選“高位在前(MSBFirst)”。這些配置都是和ILI9325的寄存器配置相對應的,如果說ILI9325的配置和本文中的不一樣,那么需要相應的選擇其他的選項。.程序源代碼main.c文件中的代碼:ftinclude"stm32fl0x_lib.h"#include"stm32fl0x_lcd.h"externunsignedcharLCD_lmage_BIT[];externunsignedcharLCD_lmage_HIT[];voidRCC_cfg();voidFSMC_cfg();voidLCD_cfg();voidGPIO_cfg();voidLCD_Show(unsignedchar*LCD_lmage);intmain()(RCC_cfg();GPIO_cfg();FSMC_cfg();LCD_cfg();while(l)(LCD_Show(LCD_lmage_HIT);Delay();LCD_Show(LCDJmage_BIT);Delay();)//RCC時鐘配置voidRCC_cfg()(〃定義錯誤狀態(tài)變量ErrorStatusHSEStartUpStatus;〃將RCC寄存器重新設置為默認值RCC_Delnit();〃翻開外部高速時鐘晶振RCC_HSEConfig(RCC_HSE_ON);〃等待外部高速時鐘晶振工作HSEStartUpStatus=RCC_WaitForHSEStartUp();if(HSEStartUpStatus==SUCCESS)(〃設置AHB時鐘(HCLK)為系統(tǒng)時鐘RCC_HCLKConfig(RCC_SYSCLK_Divl);〃設置高速AHB時鐘(APB2)為HCLK時鐘RCC_PCLK2Config(RCC_HCLK_Divl);〃設置低速AHB時鐘(APB1)為HCLK的2分頻RCC_PCLKlConfig(RCC_HCLK_Div2);〃設置FLASH代碼延時FLASH_SetLatency(FLASH_Latency_2);〃使能預取指緩存FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);〃設置PLL時鐘,為HSE的9倍頻8MHz*9=72MHzRCC_PLLConfig(RCC_PLLSource_HSE_Divl,RCC_PLLMul_9);〃使能PLLRCC_PLLCmd(ENABLE);〃等待PLL準備就緒while(RCC_GetFlagSt
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024幼兒教育機構教師勞動合同范本3篇
- 2024年防火門質量保障體系合同
- 2024年高端汽車零部件技術保密與全球銷售代理合同3篇
- 2024私人住宅施工項目協(xié)議范本版B版
- 營銷策劃方案模板合集五篇(可編輯)
- 2025年度金融科技解決方案合同3篇
- 月考分析發(fā)言稿(15篇)
- 2025年度廠區(qū)食堂承包合同:綠色環(huán)保食材采購協(xié)議3篇
- 2024年鋁制品供貨條款
- 鄭州信息工程職業(yè)學院《燃燒理論》2023-2024學年第一學期期末試卷
- 防爆電話施工方案
- 廉潔廉政朗誦稿演講3篇
- 《項目交付管理》課件
- 家長會課件:高三上學期期末家長會課件
- 軟件無線電原理與應用第3版 課件 【ch03】軟件無線電體系結構
- 石油化工裝置火炬系統(tǒng)堵塞風險分析
- 花卉學學習通超星課后章節(jié)答案期末考試題庫2023年
- 漢字課第一課(漢語國際教育)課件
- 浙大中控DCS形化編程講義課件
- 單相橋式整流電路說課公開課一等獎市優(yōu)質課賽課獲獎課件
- 防突抽采隊202年度工作總結
評論
0/150
提交評論