⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hw_ili9320.c

📁 RK27驱动
💻 C
📖 第 1 页 / 共 5 页
字号:
	Mcupanel_RegSet(0x0036,0x0302);
	Mcupanel_RegSet(0x0037,0x0407);
	Mcupanel_RegSet(0x0038,0x0004);
	Mcupanel_RegSet(0x0039,0x0204);
	Mcupanel_RegSet(0x003C,0x0307);
	Mcupanel_RegSet(0x003D,0x000C);
	
	delay_nops(40);
	Mcupanel_RegSet(0x0050,0x0000);
	Mcupanel_RegSet(0x0051,0x00EF);
	Mcupanel_RegSet(0x0052,0x0000);
	Mcupanel_RegSet(0x0053,0x013F);
	
	Mcupanel_RegSet(0x0060,0xA700);
	Mcupanel_RegSet(0x0061,0x0001);
	Mcupanel_RegSet(0x006A,0x0000);
	
	Mcupanel_RegSet(0x0080,0x0000);
	Mcupanel_RegSet(0x0081,0x0000);
	Mcupanel_RegSet(0x0082,0x0000);
	Mcupanel_RegSet(0x0083,0x0000);
	Mcupanel_RegSet(0x0084,0x0000);
	Mcupanel_RegSet(0x0085,0x0000);
	
	Mcupanel_RegSet(0x0090,0x0010);
	Mcupanel_RegSet(0x0092,0x0600);
	Mcupanel_RegSet(0x0093,0x0003);
	Mcupanel_RegSet(0x0095,0x0110);
	Mcupanel_RegSet(0x0097,0x0000);
	Mcupanel_RegSet(0x0098,0x0000);
	delay_nops(40);
	Mcupanel_RegSet(0x0007,0x0133);
	delay_nops(100);
	
#endif
//------------------------------------------------------------------------------------
#if	(LCM_9320 == 15)
	delay_nops(200);
	Mcupanel_RegSet(0x00E5, 0x8000); 	 // Set the internal vcore voltage
	Mcupanel_RegSet(0x0000, 0x0001); 	 // Start internal OSC.
	delay_nops(40);
	Mcupanel_RegSet(0x0001, 0x0000);	 // set SS and SM bit
	Mcupanel_RegSet(0x0002, 0x0700);	 // set 1 line inversion
	Mcupanel_RegSet(0x0003, 0x1038);	 // set GRAM write direction and BGR=1.
	Mcupanel_RegSet(0x0004, 0x0000);	 // Resize register

	Mcupanel_RegSet(0x0008, 0x0202);	 // set the back porch and front porch
	Mcupanel_RegSet(0x0009, 0x0000);	 // set non-display area refresh cycle ISC[3:0]
	Mcupanel_RegSet(0x000A, 0x0000);	 // FMARK function
	Mcupanel_RegSet(0x000C, 0x0000);		 // RGB interface setting
	Mcupanel_RegSet(0x000D, 0x0000);	 // Frame marker Position
	Mcupanel_RegSet(0x000F, 0x0000);		 // RGB interface polarity
    Mcupanel_RegSet(0x002b,0x0020);   //frame rate and color control(0x0000)

	//*************Power On sequence ****************
	Mcupanel_RegSet(0x0010, 0x0000);		 // SAP, BT[3:0], AP, DSTB, SLP, STB
	Mcupanel_RegSet(0x0011, 0x0007);		 // DC1[2:0], DC0[2:0], VC[2:0]
	Mcupanel_RegSet(0x0012, 0x0000);		 // VREG1OUT voltage
	Mcupanel_RegSet(0x0013, 0x0000);		 // VDV[4:0] for VCOM amplitude
	delay_nops(200);				// Dis-charge capacitor power voltage

	Mcupanel_RegSet(0x0010, 0x17B0);		 // SAP, BT[3:0], AP, DSTB, SLP, STB
	Mcupanel_RegSet(0x0011, 0x0007);		 // DC1[2:0], DC0[2:0], VC[2:0]
	delay_nops(50);					 // Delay 50ms
	Mcupanel_RegSet(0x0012, 0x0139);		 // VREG1OUT voltage
	delay_nops(50);					 // Delay 50ms
	Mcupanel_RegSet(0x0013, 0x1400);		 // VDV[4:0] for VCOM amplitude
	Mcupanel_RegSet(0x0029, 0x000c);		 // VCM[4:0] for VCOMH
	delay_nops(50);

	Mcupanel_RegSet(0x0020, 0x0000);		 // GRAM horizontal Address
	Mcupanel_RegSet(0x0021, 0x0000);		 // GRAM Vertical Address

	// ----------- Adjust the Gamma	Curve ----------//
	Mcupanel_RegSet(0x0030, 0x0002);
	Mcupanel_RegSet(0x0031, 0x0606);
	Mcupanel_RegSet(0x0032, 0x0501);


	Mcupanel_RegSet(0x0035, 0x0206);
	Mcupanel_RegSet(0x0036, 0x0504);
	Mcupanel_RegSet(0x0037, 0x0707);
	Mcupanel_RegSet(0x0038, 0x0306);
	Mcupanel_RegSet(0x0039, 0x0007);

	Mcupanel_RegSet(0x003C, 0x0700);
	Mcupanel_RegSet(0x003D, 0x0700);

	//------------------ Set GRAM area ---------------//
	Mcupanel_RegSet(0x0050, 0x0000);		// Horizontal GRAM Start Address
	Mcupanel_RegSet(0x0051, 0x00EF);		// Horizontal GRAM End Address
	Mcupanel_RegSet(0x0052, 0x0000);		// Vertical GRAM Start Address
	Mcupanel_RegSet(0x0053, 0x013F);		// Vertical GRAM Start Address


	Mcupanel_RegSet(0x0060, 0x2700);		// Gate Scan Line
	Mcupanel_RegSet(0x0061, 0x0001);		// NDL,VLE, REV
	Mcupanel_RegSet(0x006A, 0x0000);		// set scrolling line

	//-------------- Partial Display Control ---------//
	Mcupanel_RegSet(0x0080, 0x0000);
	Mcupanel_RegSet(0x0081, 0x0000);
	Mcupanel_RegSet(0x0082, 0x0000);
	Mcupanel_RegSet(0x0083, 0x0000);
	Mcupanel_RegSet(0x0084, 0x0000);
	Mcupanel_RegSet(0x0085, 0x0000);

	//-------------- Panel Control -------------------//
	Mcupanel_RegSet(0x0090, 0x0010);
	Mcupanel_RegSet(0x0092, 0x0000);
	Mcupanel_RegSet(0x0093, 0x0003);
	Mcupanel_RegSet(0x0095, 0x0110);
	Mcupanel_RegSet(0x0097, 0x0000);
	Mcupanel_RegSet(0x0098, 0x0000);


	Mcupanel_RegSet(0x0007, 0x0173);		// 262K color and display ON
	Mcupanel_Command(0x0022);
#endif

//------------------------------------------------------------------------------------
#if	(LCM_9320 == 16)
	Mcupanel_RegSet(0x00E3, 0x3008); // Set internal timing
	Mcupanel_RegSet(0x00E7, 0x0012); // Set internal timing
	Mcupanel_RegSet(0x00EF, 0x1231); // Set internal timing
	Mcupanel_RegSet(0x0001, 0x0000); // set SS and SM bit
	Mcupanel_RegSet(0x0002, 0x0700); // set 1 line inversion
	Mcupanel_RegSet(0x0003, 0x1038); // set GRAM write direction and BGR=1.
	Mcupanel_RegSet(0x0004, 0x0000); // Resize register
	Mcupanel_RegSet(0x0008, 0x0207); // set the back porch and front porch
	Mcupanel_RegSet(0x0009, 0x0000); // set non-display area refresh cycle ISC[3:0]
	Mcupanel_RegSet(0x000A, 0x0000); // FMARK function
	Mcupanel_RegSet(0x000C, 0x0000); // RGB interface setting
	Mcupanel_RegSet(0x000D, 0x0000); // Frame marker Position
	Mcupanel_RegSet(0x000F, 0x0000); // RGB interface polarity
//*************Power On sequence ****************//
	Mcupanel_RegSet(0x0010, 0x0000); // SAP, BT[3:0], AP, DSTB, SLP, STB
	Mcupanel_RegSet(0x0011, 0x0001); // DC1[2:0], DC0[2:0], VC[2:0]
	Mcupanel_RegSet(0x0012, 0x0000); // VREG1OUT voltage
	Mcupanel_RegSet(0x0013, 0x0000); // VDV[4:0] for VCOM amplitude
	delay_nops(100); // Dis-charge capacitor power voltage
	Mcupanel_RegSet(0x0010, 0x1790); // SAP, BT[3:0], AP, DSTB, SLP, STB
	Mcupanel_RegSet(0x0011, 0x0221); // DC1[2:0], DC0[2:0], VC[2:0]
	delay_nops(50); // Delay 50ms
	Mcupanel_RegSet(0x0012, 0x001D); // Internal reference voltage= Vci;
	delay_nops(50); // Delay 50ms
	Mcupanel_RegSet(0x0013, 0x0800); // Set VDV[4:0] for VCOM amplitude
	Mcupanel_RegSet(0x0029, 0x001b); // Set VCM[5:0] for VCOMH
	Mcupanel_RegSet(0x002B, 0x000D); // Set Frame Rate
	delay_nops(50); // Delay 50ms
	Mcupanel_RegSet(0x0020, 0x0000); // GRAM horizontal Address
	Mcupanel_RegSet(0x0021, 0x0000); // GRAM Vertical Address
// ----------- Adjust the Gamma Curve ----------//
	Mcupanel_RegSet(0x0030, 0x0007);
	Mcupanel_RegSet(0x0031, 0x0303);
	Mcupanel_RegSet(0x0032, 0x0003);
	Mcupanel_RegSet(0x0035, 0x0704);
	Mcupanel_RegSet(0x0036, 0x1F04);
	Mcupanel_RegSet(0x0037, 0x1014);
	Mcupanel_RegSet(0x0038, 0x0a0a);
	Mcupanel_RegSet(0x0039, 0x0706);
	Mcupanel_RegSet(0x003C, 0x0701);
	Mcupanel_RegSet(0x003D, 0x001F);
//------------------ Set GRAM area ---------------//
	Mcupanel_RegSet(0x0050, 0x0000); // Horizontal GRAM Start Address
	Mcupanel_RegSet(0x0051, 0x00EF); // Horizontal GRAM End Address
	Mcupanel_RegSet(0x0052, 0x0000); // Vertical GRAM Start Address
	Mcupanel_RegSet(0x0053, 0x013F); // Vertical GRAM Start Address
	Mcupanel_RegSet(0x0060, 0xA700); // Gate Scan Line
	Mcupanel_RegSet(0x0061, 0x0001); // NDL,VLE, REV
	Mcupanel_RegSet(0x006A, 0x0000); // set scrolling line
//-------------- Partial Display Control ---------//
	Mcupanel_RegSet(0x0080, 0x0000);
	Mcupanel_RegSet(0x0081, 0x0000);
	Mcupanel_RegSet(0x0082, 0x0000);
	Mcupanel_RegSet(0x0083, 0x0000);
	Mcupanel_RegSet(0x0084, 0x0000);
	Mcupanel_RegSet(0x0085, 0x0000);
//-------------- Panel Control -------------------//
	Mcupanel_RegSet(0x0090, 0x0010);
	Mcupanel_RegSet(0x0092, 0x0600);
	Mcupanel_RegSet(0x0093, 0x0003);
	Mcupanel_RegSet(0x0095, 0x0110);
	Mcupanel_RegSet(0x0097, 0x0000);
	Mcupanel_RegSet(0x0098, 0x0000);
	Mcupanel_RegSet(0x0007, 0x0133); // 262K color and display ON

	Mcupanel_Command(0x0022);

#endif

//############################MFC-S07001 V04##########################################
#if	(LCM_9320 == 17)

	delay_nops(10);
	//************* Start Initial Sequence **********//
	Mcupanel_RegSet(0x00, 0x0001);		// Start internal OSC.
	Mcupanel_RegSet(0x01, 0x0000); //0x0100);		// set SS and SM bit
	Mcupanel_RegSet(0x02, 0x0400);		// set 1 line inversion
	Mcupanel_RegSet(0x03, 0x10b8); //0x1038); //0x1028); //0x1038);		// set GRAM write direction and BGR=1.
	Mcupanel_RegSet(0x04, 0x0000);		// Resize register
	Mcupanel_RegSet(0x08, 0x0202);		// set the back porch and front porch
	Mcupanel_RegSet(0x09, 0x0000);		// set non-display area refresh cycle ISC[3:0]
	Mcupanel_RegSet(0x0A, 0x0000);		// FMARK function
	Mcupanel_RegSet(0x0C, 0x0000);		// RGB interface setting
	Mcupanel_RegSet(0x0D, 0x0000);		// Frame marker Position
	Mcupanel_RegSet(0x0F, 0x0000);		// RGB interface polarity

	//*************Power On sequence ****************//    WCOM(0x51, 0x00, 0xEF);
	Mcupanel_RegSet(0x10, 0x0000);                // SAP, BT[3:0], AP, DSTB, SLP, STB
	Mcupanel_RegSet(0x11, 0x0007);                // DC1[2:0], DC0[2:0], VC[2:0]
	Mcupanel_RegSet(0x12, 0x0000);                // VREG1OUT voltage
	Mcupanel_RegSet(0x13, 0x0000);                // VDV[4:0] for VCOM amplitude
	delay_nops(50);

	//*************Power On sequence ****************//    WCOM(0x51, 0x00, 0xEF);
	Mcupanel_RegSet(0x10, 0x17B0); //0000);     // SAP, BT[3:0], AP, DSTB, SLP, STB
	Mcupanel_RegSet(0x11, 0x0007);              // DC1[2:0], DC0[2:0], VC[2:0]
	delay_nops(50);
	Mcupanel_RegSet(0x12, 0x013f); //0000);     // VREG1OUT voltage
	delay_nops(50);
	Mcupanel_RegSet(0x13, 0x2f00); //0000);     // VDV[4:0] for VCOM amplitude
	Mcupanel_RegSet(0x29, 0x002b); //B);
	delay_nops(50);

	Mcupanel_RegSet(0x20, 0x0000);                // GRAM horizontal Address
	Mcupanel_RegSet(0x21, 0x0000);                // GRAM Vertical Address
	Mcupanel_RegSet(0x2B, 0x0020);		// Frame Rate and Color Control-----16M_EN, Dither, FR_SEL[1:0]


	// ---------- Gamma Control  ---------- //
  	Mcupanel_RegSet(0x30, 0x0102);
  	Mcupanel_RegSet(0x31, 0x0C1B);
  	Mcupanel_RegSet(0x32, 0x121F);
  	Mcupanel_RegSet(0x33, 0x391A);
  	Mcupanel_RegSet(0x34, 0x380B);
  	Mcupanel_RegSet(0x35, 0x1004);
  	Mcupanel_RegSet(0x36, 0x1701);
  	Mcupanel_RegSet(0x37, 0x0A1E);
  	Mcupanel_RegSet(0x38, 0x0007);
  	Mcupanel_RegSet(0x39, 0x0101);
  	Mcupanel_RegSet(0x3A, 0x0C06);
  	Mcupanel_RegSet(0x3B, 0x0F03);
  	Mcupanel_RegSet(0x3C, 0x000C);
  	Mcupanel_RegSet(0x3D, 0x0D0C);
  	Mcupanel_RegSet(0x3E, 0x0504);
  	Mcupanel_RegSet(0x3F, 0x0601);


	// ---------- Window Address Area  ---------- //
	Mcupanel_RegSet(0x50, 0x0000);		// Horizontal GRAM Start Address-----HSA[7:0]
	Mcupanel_RegSet(0x51, 0x00EF);		// Horizontal GRAM End Address-----HEA[7:0]
	Mcupanel_RegSet(0x52, 0x0000);		// Vertical GRAM Start Address-----VSA[8:0]
	Mcupanel_RegSet(0x53, 0x013F);		// Vertical GRAM Start Address-----VEA[8:0]

	// ---------- Gate Scan Control  ---------- //
	Mcupanel_RegSet(0x60, 0x2700);		// GS, NL[5:0], SCN[5:0]
	Mcupanel_RegSet(0x61, 0x0001);		// NDL,VLE, REV
	Mcupanel_RegSet(0x6A, 0x0000);		// VL[8:0]

	// ---------- Partial Display Control  ---------- //
	Mcupanel_RegSet(0x80, 0x0000);		// Partial Image 1 Display Position-----PTDP0[8:0]
	Mcupanel_RegSet(0x81, 0x0000);		// Partial Image 1 Start Address-----PTSA0[8:0]
	Mcupanel_RegSet(0x82, 0x0000);		// Partial Image 1 End Address-----PTEA0[8:0]
	Mcupanel_RegSet(0x83, 0x0000);		// Partial Image 2 Display Position-----PTDP1[8:0]
	Mcupanel_RegSet(0x84, 0x0000);		// Partial Image 2 Start Address-----PTSA1[8:0]
	Mcupanel_RegSet(0x85, 0x0000);		// Partial Image 2 Start Address-----PTEA1[8:0]

	// ---------- Panel Interface Control  ---------- //
	Mcupanel_RegSet(0x90, 0x0013);		// Panel Interface Control 1-----DIVI[1:0], RTNI[4:0]
	Mcupanel_RegSet(0x92, 0x0000);		// Panel Interface Control 2-----NOWI[2:0]
	Mcupanel_RegSet(0x93, 0x0003);		// Panel Interface Control 3-----MCPI[2:0]
	Mcupanel_RegSet(0x95, 0x0110);		// Panel Interface Control 4-----DIVE[1:0], RTNE[5:0]
	Mcupanel_RegSet(0x97, 0x0000);		// Panel Interface Control 5-----NOWE[3:0]
	Mcupanel_RegSet(0x98, 0x0000);		// Panel Interface Control 6-----MCPE[2:0]

	Mcupanel_RegSet(0x07, 0x0001);		// Display Control 1
	delay_nops(50);
	Mcupanel_RegSet(0x07, 0x0021);		// Display Control 1
	Mcupanel_RegSet(0x07, 0x0023);		// Display Control 1
	delay_nops(50);
	Mcupanel_RegSet(0x07, 0x0173);		// Display Control 1-----262K color and display ON
#endif

//############################T-0038A##########################################
#if	(LCM_9320 == 18)
	delay_nops(200);
	Mcupanel_RegSet(0x00E5, 0x8000); 	 // Set the internal vcore voltage
	Mcupanel_RegSet(0x0000, 0x0001); 	 // Start internal OSC.
	delay_nops(40);
	Mcupanel_RegSet(0x0001, 0x0000);	 // set SS and SM bit
	Mcupanel_RegSet(0x0002, 0x0700);	 // set 1 line inversion
	Mcupanel_RegSet(0x0003, 0x1038);	 // set GRAM write direction and BGR=1.
	Mcupanel_RegSet(0x0004, 0x0000);	 // Resize register

	Mcupanel_RegSet(0x0008, 0x0202);	 // set the back porch and front porch
	Mcupanel_RegSet(0x0009, 0x0000);	 // set non-display area refresh cycle ISC[3:0]
	Mcupanel_RegSet(0x000A, 0x0000);	 // FMARK function
	Mcupanel_RegSet(0x000C, 0x0000);		 // RGB interface setting
	Mcupanel_RegSet(0x000D, 0x0000);	 // Frame marker Position
	Mcupanel_RegSet(0x000F, 0x0000);		 // RGB interface polarity
    Mcupanel_RegSet(0x002b, 0x0020);   //frame rate and color control(0x0000)

	//*************Power On sequence ****************
	Mcupanel_RegSet(0x0010, 0x0000);		 // SAP, BT[3:0], AP, DSTB, SLP, STB
	Mcupanel_RegSet(0x0011, 0x0007);		 // DC1

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -