for TFT2P0327 aitendo.com 128*160 TFT LCD. LCD driver is S6D0151 Sumsung.

Dependents:   FRDM_tocos_x2_FIXED

Committer:
king33jp
Date:
Sun Oct 02 13:20:50 2016 +0000
Revision:
5:18920a7a693e
Parent:
4:648a364412e4
all change fixed.; rectfill modify; reverse fix; and; orientation command added.; onley 0 and 2 is valid.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
king33jp 1:a3651128e297 1 /* mbed library for 128*160 pixel display TFT based on S6D0151 LCD Controller
king33jp 1:a3651128e297 2 *
king33jp 1:a3651128e297 3 */
king33jp 0:de7db46990d0 4
king33jp 0:de7db46990d0 5 #include "S6D0151_TFT.h"
king33jp 0:de7db46990d0 6 #include "mbed.h"
king33jp 0:de7db46990d0 7
king33jp 0:de7db46990d0 8 #define BPP 16 // Bits per pixel
king33jp 0:de7db46990d0 9
king33jp 0:de7db46990d0 10 S6D0151_TFT::S6D0151_TFT(PinName mosi, PinName miso, PinName sclk, PinName cs, PinName reset, const char *name)
king33jp 0:de7db46990d0 11 : _spi(mosi, miso, sclk), _cs(cs), _reset(reset),GraphicsDisplay(name) {
king33jp 0:de7db46990d0 12 tft_reset();
king33jp 4:648a364412e4 13 orientation = 0;
king33jp 0:de7db46990d0 14 char_x = 0;
king33jp 0:de7db46990d0 15 }
king33jp 0:de7db46990d0 16
king33jp 0:de7db46990d0 17
king33jp 0:de7db46990d0 18 int S6D0151_TFT::width() {
king33jp 0:de7db46990d0 19 if (orientation == 0 || orientation == 2) return 128;
king33jp 0:de7db46990d0 20 else return 160;
king33jp 0:de7db46990d0 21 }
king33jp 0:de7db46990d0 22
king33jp 0:de7db46990d0 23
king33jp 0:de7db46990d0 24 int S6D0151_TFT::height() {
king33jp 0:de7db46990d0 25 if (orientation == 0 || orientation == 2) return 160;
king33jp 0:de7db46990d0 26 else return 128;
king33jp 0:de7db46990d0 27 }
king33jp 0:de7db46990d0 28
king33jp 0:de7db46990d0 29
king33jp 0:de7db46990d0 30 void S6D0151_TFT::set_orientation(unsigned int o) {
king33jp 0:de7db46990d0 31 orientation = o;
king33jp 4:648a364412e4 32 /* I can't understand rotation methods.
king33jp 4:648a364412e4 33 Maybe , S6D0151 can NOT conversion row and column.
king33jp 4:648a364412e4 34 but i can conversion up and down.
king33jp 4:648a364412e4 35 orientation=0 : Normal FPC side bottom.
king33jp 4:648a364412e4 36 orientation=2 ; Reverse FPC side is Top.
king33jp 4:648a364412e4 37 */
king33jp 0:de7db46990d0 38 switch (orientation) {
king33jp 0:de7db46990d0 39 case 0:
king33jp 4:648a364412e4 40 regwr(0x0001,0x0014); //DRIVER OUTPUT CONTROL (R01h)
king33jp 0:de7db46990d0 41 break;
king33jp 0:de7db46990d0 42 case 1:
king33jp 4:648a364412e4 43 //wr_reg(ST7735_MADCTL, 0x0060);
king33jp 0:de7db46990d0 44 break;
king33jp 0:de7db46990d0 45 case 2:
king33jp 4:648a364412e4 46 regwr(0x0001,0x0314); //DRIVER OUTPUT CONTROL (R01h)
king33jp 0:de7db46990d0 47 break;
king33jp 0:de7db46990d0 48 case 3:
king33jp 4:648a364412e4 49 //wr_reg(ST7735_MADCTL, 0x00A0);
king33jp 0:de7db46990d0 50 break;
king33jp 0:de7db46990d0 51 }
king33jp 0:de7db46990d0 52 }
king33jp 0:de7db46990d0 53
king33jp 0:de7db46990d0 54 void S6D0151_TFT::wr_dat_start(void) {
king33jp 0:de7db46990d0 55 // _rs = 1; // rs high, cs low for transmitting data
king33jp 0:de7db46990d0 56 _cs = 0;
king33jp 0:de7db46990d0 57 _spi.write( 0x72 ); // Start byte
king33jp 0:de7db46990d0 58 }
king33jp 0:de7db46990d0 59
king33jp 0:de7db46990d0 60
king33jp 0:de7db46990d0 61
king33jp 0:de7db46990d0 62 void S6D0151_TFT::wr_dat_stop (void) {
king33jp 0:de7db46990d0 63 _cs = 1;
king33jp 0:de7db46990d0 64 }
king33jp 0:de7db46990d0 65
king33jp 0:de7db46990d0 66
king33jp 0:de7db46990d0 67 void S6D0151_TFT::set_start_address(int left,int top){
king33jp 0:de7db46990d0 68 unsigned short addr;
king33jp 0:de7db46990d0 69 addr = (((top&0xff)<<8)|(left&0xff));
king33jp 0:de7db46990d0 70
king33jp 0:de7db46990d0 71 regwr( 0x0021 , addr );
king33jp 0:de7db46990d0 72 }
king33jp 0:de7db46990d0 73
king33jp 5:18920a7a693e 74 void S6D0151_TFT::reverse(int rev){
king33jp 5:18920a7a693e 75 if(rev == TFT_REVERSE_ON){
king33jp 5:18920a7a693e 76 regwr(0x0007,0x0033); //DISPLAY CONTROL (R07h)
king33jp 5:18920a7a693e 77 } else {
king33jp 5:18920a7a693e 78 regwr(0x0007,0x0037); //DISPLAY CONTROL (R07h)
king33jp 5:18920a7a693e 79 }
king33jp 5:18920a7a693e 80 // X X X PT1 PT0 X X SPT X X GON DTE CL REV D1 D0
king33jp 5:18920a7a693e 81 //GON=1,DTE=1 VGH/VGL Normal operation
king33jp 5:18920a7a693e 82 //Rev bit mean Color reverse.
king33jp 5:18920a7a693e 83 //REV=1 Displays all character and graphics display sections with Reverse
king33jp 5:18920a7a693e 84 //D[1:0]=11 Display is RAM data
king33jp 5:18920a7a693e 85 }
king33jp 0:de7db46990d0 86
king33jp 0:de7db46990d0 87 /**
king33jp 0:de7db46990d0 88 */
king33jp 0:de7db46990d0 89 void S6D0151_TFT::regwr(unsigned short reg,unsigned short dat){
king33jp 0:de7db46990d0 90 int data;
king33jp 0:de7db46990d0 91 _cs = 0;
king33jp 0:de7db46990d0 92 _spi.write(0x70); // RW=0,ID=0,RS=0(Index Register write)
king33jp 0:de7db46990d0 93 data = (reg>>8)&0x00ff;
king33jp 0:de7db46990d0 94 _spi.write( data );
king33jp 0:de7db46990d0 95 data = (reg )&0x00ff;
king33jp 0:de7db46990d0 96 _spi.write( data );
king33jp 0:de7db46990d0 97 _cs = 1;
king33jp 1:a3651128e297 98 wait_us(1); // cs=high Time has not been defined.
king33jp 0:de7db46990d0 99 _cs = 0;
king33jp 0:de7db46990d0 100 _spi.write(0x72); // RW=0,ID=0,RS=1(data write)
king33jp 0:de7db46990d0 101 data = (dat>>8)&0x00ff;
king33jp 0:de7db46990d0 102 _spi.write( data );
king33jp 0:de7db46990d0 103 data = (dat )&0x00ff;
king33jp 0:de7db46990d0 104 _spi.write( data );
king33jp 0:de7db46990d0 105 _cs = 1;
king33jp 0:de7db46990d0 106 }
king33jp 0:de7db46990d0 107 void S6D0151_TFT::reg0(unsigned short reg){
king33jp 0:de7db46990d0 108 int data;
king33jp 0:de7db46990d0 109 _cs = 0;
king33jp 0:de7db46990d0 110 _spi.write(0x70); // RW=0,ID=0,RS=0(Index Register write)
king33jp 0:de7db46990d0 111 data = (reg>>8)&0x00ff;
king33jp 0:de7db46990d0 112 _spi.write( data );
king33jp 0:de7db46990d0 113 data = (reg )&0x00ff;
king33jp 0:de7db46990d0 114 _spi.write( data );
king33jp 0:de7db46990d0 115 _cs = 1;
king33jp 0:de7db46990d0 116 }
king33jp 0:de7db46990d0 117
king33jp 0:de7db46990d0 118 void S6D0151_TFT::tft_reset() {
king33jp 0:de7db46990d0 119 // init SPI
king33jp 0:de7db46990d0 120 _spi.format(8,3); // 8 bit spi mode 3
king33jp 1:a3651128e297 121 _spi.frequency(6000000); // 6Mhz SPI clock ... 10Mhz is maximum for display
king33jp 0:de7db46990d0 122
king33jp 0:de7db46990d0 123 _cs = 0;
king33jp 1:a3651128e297 124 _reset = 1;
king33jp 0:de7db46990d0 125 wait_ms(500);
king33jp 0:de7db46990d0 126 _reset = 0; // reset
king33jp 0:de7db46990d0 127 wait_ms(500);
king33jp 1:a3651128e297 128 _reset = 1;
king33jp 0:de7db46990d0 129 wait_ms(500);
king33jp 0:de7db46990d0 130
king33jp 0:de7db46990d0 131 /* Start Initial Sequence ----------------------------------------------------*/
king33jp 1:a3651128e297 132 /* follow code is aitendo demo-code...........................................*/
king33jp 1:a3651128e297 133 /* I have changed the part in the demo code to reference----------------------*/
king33jp 0:de7db46990d0 134 regwr(0x0007,0x0020); //DISPLAY CONTROL (R07h)
king33jp 0:de7db46990d0 135 // X X X PT1 PT0 X X SPT X X GON DTE CL REV D1 D0
king33jp 0:de7db46990d0 136 //PT[1:0]=00 V63/V0 Normal Drive
king33jp 0:de7db46990d0 137 //SPT=0 Split Screen Driving Function is Not performed
king33jp 0:de7db46990d0 138 //GON=1,DTE=0 Normal operation
king33jp 0:de7db46990d0 139 //CL=0 262,144 colors / 65,536 colors
king33jp 0:de7db46990d0 140 //REV=0 Displays all character and graphics display sections with Normal
king33jp 0:de7db46990d0 141 //D[1:0]=00 the internal display operation halts and the display is off.
king33jp 0:de7db46990d0 142
king33jp 0:de7db46990d0 143 regwr(0x00b6,0x013f); //Module Vendor (RB6h)
king33jp 0:de7db46990d0 144 // TEST_IN4 TEST_IN3 X X X X PSMD1(0) PSM D0(1) X X 1 1 1 1 1 1
king33jp 0:de7db46990d0 145 //TEST_IN4,TEST_IN3 User can know the Module Vendor through this register is accessed.
king33jp 0:de7db46990d0 146 //PSMD[1:0]=01 5680*(1/fosc) Select the power on time delay of step-up circuit.
king33jp 0:de7db46990d0 147
king33jp 0:de7db46990d0 148 regwr(0x00b4,0x0010); //MTP CONTROL (RB4h)
king33jp 0:de7db46990d0 149 // X X X MTP_SEL X X X MTP_INIT X X X MTP_WRB X X X MTP_LOAD
king33jp 0:de7db46990d0 150 //MTP_SEL=0 VCOMH Control Data is VCM Register
king33jp 0:de7db46990d0 151 //MTP_INIT=0
king33jp 0:de7db46990d0 152 //MTP_WRB=1 Cannot write MTP data
king33jp 0:de7db46990d0 153 //MTP_LOAD=0
king33jp 0:de7db46990d0 154
king33jp 0:de7db46990d0 155 regwr(0x0012,0x00b2); //POWER CONTROL 2 (R12h)
king33jp 0:de7db46990d0 156 // X X X X X X X X SVC3 SVC2 SVC1 SVC0 X 0 VRH5 VRH4
king33jp 0:de7db46990d0 157 //SVC Adjust reference voltage of AVDD, VGH, VGL and VCL
king33jp 0:de7db46990d0 158 // SVC[3:0]=1011 VCI1=2.76V
king33jp 0:de7db46990d0 159
king33jp 0:de7db46990d0 160 regwr(0x0013,0x080e); //POWER CONTROL 3 (R13h)
king33jp 0:de7db46990d0 161 // X X X X VCMR X X X X X X PON VRH3 VRH2 VRH1 VRH0
king33jp 0:de7db46990d0 162 //PON=0 The operational amplifier is stop.
king33jp 0:de7db46990d0 163 //VCMR=1 VCOMH voltage=Internal electronic volume
king33jp 0:de7db46990d0 164 //VRH[5:0]=1e=011110 VCIR_EXIN X 2.250 = 4.50V
king33jp 0:de7db46990d0 165
king33jp 0:de7db46990d0 166 regwr(0x0014,0x5bca); //POWER CONTROL 4 (R14h)
king33jp 0:de7db46990d0 167 // X VDV6 VDV5 VDV4 VDV3 VDV2 VDV1 VDV0 VCOMG VCM6 VCM5 VCM4 VCM3 VCM2 VCM1 VCM0
king33jp 0:de7db46990d0 168 //VDV Set the alternating amplitudes of Vcom at the Vcom alternating drive.
king33jp 0:de7db46990d0 169 // VDV[6:0]=5b=1011011 GVDD x 0.984
king33jp 0:de7db46990d0 170 //VCOMG=1 VcomL voltage can output to negative voltage.
king33jp 0:de7db46990d0 171 //Set the VcomH voltage (a high-level voltage at the Vcom alternating drive).
king33jp 0:de7db46990d0 172 // VCM[6:0]=1001010 GVDD x 0.8085
king33jp 0:de7db46990d0 173
king33jp 0:de7db46990d0 174 regwr(0x0061,0x0018); //OSCILLATOR CONTROL (R61h)
king33jp 0:de7db46990d0 175 // X X X X X X X X X X X RADJ4 RADJ3 RADJ2 RADJ1 RADJ0
king33jp 0:de7db46990d0 176 //RADJ[4:0]=11000 Oscillation Speed=x 1.000 Default
king33jp 0:de7db46990d0 177
king33jp 0:de7db46990d0 178 regwr(0x0010,0x190c); //POWER CONTROL 1 (R10h)
king33jp 0:de7db46990d0 179 // DSTB X SAP2 SAP1 SAP0 BT2 BT1 BT0 DC2 DC1 DC0 AP2 AP1 AP0 SLP STB
king33jp 0:de7db46990d0 180 //DSTB=0 Noraml
king33jp 0:de7db46990d0 181 //Adjust the slew-rate of the operational amplifier for the source driver.
king33jp 0:de7db46990d0 182 // SAP[2:0]=011 Medium Medium
king33jp 0:de7db46990d0 183 //BT[2:0]=001 VGH=AVDDx3 VGL=-(AVDDx2) VGH = Vci1 X six times
king33jp 0:de7db46990d0 184 //DC[2:0]=000 AVDD,VCL=DCCLK/1 VGH,VGL=DCCLK/2
king33jp 0:de7db46990d0 185 //AP[2:0]=011 Amount of Current in Operational Amplifier=Medium
king33jp 0:de7db46990d0 186 //SLP=0 setting Sleep. Normal mode
king33jp 0:de7db46990d0 187 //STB=0 setting standby. normal mode
king33jp 0:de7db46990d0 188 wait_ms(80);
king33jp 0:de7db46990d0 189
king33jp 0:de7db46990d0 190 regwr(0x0013,0x081e); //POWER CONTROL 3 (R13h)
king33jp 0:de7db46990d0 191 // X X X X VCMR X X X X X X PON VRH3 VRH2 VRH1 VRH0
king33jp 0:de7db46990d0 192 //PON=1 The operational amplifier is Start.
king33jp 0:de7db46990d0 193 //VCMR=1 VCOMH voltage=Internal electronic volume
king33jp 0:de7db46990d0 194 //VRH[5:0]=1e=011110 VCIR_EXIN X 2.250 = 4.50V
king33jp 0:de7db46990d0 195 wait_ms(20);
king33jp 0:de7db46990d0 196
king33jp 0:de7db46990d0 197 regwr(0x0001,0x0014); //DRIVER OUTPUT CONTROL (R01h)
king33jp 0:de7db46990d0 198 // X X X DPL EPL SM GS SS X X X NL4 NL3 NL2 NL1 NL0
king33jp 1:a3651128e297 199 // demo code was 0x0114,SS bit=1 is reverse horizontal.
king33jp 0:de7db46990d0 200 //DPL=0,EPL=0
king33jp 0:de7db46990d0 201 //SM=0 even/odd division is selected
king33jp 0:de7db46990d0 202 //GS=0 G1 is output first and G160 is finally output.
king33jp 0:de7db46990d0 203 //SS=1 Select the direction of the source driver channel in pixel unit.
king33jp 0:de7db46990d0 204 //NL[4:0]=10100 Drive Duty=384 X 160 dots 160 G1 to G160
king33jp 0:de7db46990d0 205
king33jp 0:de7db46990d0 206 regwr(0x0002,0x0100); //LCD INVERSION CONTROL (R02h)
king33jp 0:de7db46990d0 207 // X X X X X X FL1 FL0 X X X FLD X X X X
king33jp 0:de7db46990d0 208 //FL[1:0]=01 FLD=0 Line Inversion-1 field interlace
king33jp 0:de7db46990d0 209
king33jp 0:de7db46990d0 210 regwr(0x0003,0x0030); //ENTRY MODE (R03h)
king33jp 0:de7db46990d0 211 // X X X BGR X X MDT1 MDT0 X X ID1 ID0 AM X X X
king33jp 0:de7db46990d0 212 //BGR=0 assigned to {R, G, B}.When 18-bit data is written to GRAM through DB bus
king33jp 0:de7db46990d0 213 //MDT[1:0]=00 260k color data is transferred by 3or2-times(setting for IM) Data Transfer.
king33jp 0:de7db46990d0 214 // When user wants to transfer 260k color data on 8/16-bit parallel bus
king33jp 0:de7db46990d0 215 //ID[1:0]=11 When ID[1], ID[0] = 1, the address counter (AC) is automatically increased by 1 after the data is written to the GRAM
king33jp 0:de7db46990d0 216 //AM=0 the data is continuously written in horizontally.
king33jp 0:de7db46990d0 217
king33jp 0:de7db46990d0 218 regwr(0x0008,0x0202); //BLANK PERIOD CONTROL 1 (R08h)
king33jp 0:de7db46990d0 219 // X X X X FP3 FP2 FP1 FP0 X X X X BP3 BP2 BP1 BP0
king33jp 0:de7db46990d0 220 //FP[3:0]=0010
king33jp 0:de7db46990d0 221 //BP[3:0]=0010
king33jp 0:de7db46990d0 222 //Number of Raster Periods In Front (Back) Porch Default=2;
king33jp 0:de7db46990d0 223
king33jp 0:de7db46990d0 224 regwr(0x000b,0x0000); //FRAME CYCLE CONTROL (R0Bh)
king33jp 0:de7db46990d0 225 // X X X X X X DIV1 DIV0 X X X X RTN3 RTN2 RTN1 RTN0
king33jp 0:de7db46990d0 226 //DIV[1:0]=00 Division Ratio=1 Internal operation clock frequency=fosc/1
king33jp 0:de7db46990d0 227 //RTN[3:0]=Clock Cycles per horizontal Line= 16 (INCLKs)
king33jp 0:de7db46990d0 228
king33jp 0:de7db46990d0 229 regwr(0x000c,0x0000); //EXTERNAL DISPLAY INTERFACE CONTROL (R0Ch)
king33jp 0:de7db46990d0 230 // X X X X X X X RM X X DM1 DM0 X X RIM1 RIM0
king33jp 0:de7db46990d0 231 //RM=0 GRAM Access Interface=System interface
king33jp 0:de7db46990d0 232 //DM[1:0]=00 Display operation mode = Internal clock operation
king33jp 0:de7db46990d0 233
king33jp 0:de7db46990d0 234 regwr(0x0061,0x0018); //OSCILLATOR CONTROL (R61h)
king33jp 0:de7db46990d0 235 // X X X X X X X X X X X RADJ4 RADJ3 RADJ2 RADJ1 RADJ0
king33jp 0:de7db46990d0 236 //RADJ[4:0]=11000 Oscillation Speed=x 1.000 Default
king33jp 0:de7db46990d0 237
king33jp 0:de7db46990d0 238 regwr(0x0069,0x0000); //DC/DC CONVERT LOW POWER MODE SETTING (R69h)
king33jp 0:de7db46990d0 239 // 0 0 0 0 0 0 0 0 0 0 0 NLDC3 NLDC2 NLDC1 NLDC0 NLPM
king33jp 0:de7db46990d0 240 //NLPM=0 Normal operation mode
king33jp 0:de7db46990d0 241 //NLDC[1:0]=00 DCCLK/1
king33jp 0:de7db46990d0 242 //NLDC[3:2]=00 DCCLK/2
king33jp 0:de7db46990d0 243
king33jp 0:de7db46990d0 244 regwr(0x0070,0x0000); //SOURCE DRIVER PRE-DRIVING PERIOD SETTING (R70h)
king33jp 0:de7db46990d0 245 // X X X X X X X X SDT1 SDT0 X X X X EQ1 EQ0
king33jp 0:de7db46990d0 246 //STD[1:0]=00 Source Output Delay Control=1 DISP_CK
king33jp 0:de7db46990d0 247 //EQ=00 No Equalization Control
king33jp 0:de7db46990d0 248 regwr(0x0071,0x0000); //GATE OUTPUT PERIOD CONTROL (R71h)
king33jp 0:de7db46990d0 249 // X X X X GNO1 GNO0 X X X X X X X X X X
king33jp 0:de7db46990d0 250 //GN)=00 Non-Overlap Period Control =2 DISP_CKs
king33jp 0:de7db46990d0 251
king33jp 0:de7db46990d0 252 regwr(0x0011,0x0000); //GAMMA CONTROL 1 (R11h)
king33jp 0:de7db46990d0 253 // VR1C X X VRN14 VRN13 VRN12 VRN11 VRN10 X X X VRP14 VRP13 VRP12 VRP11 VRP10
king33jp 0:de7db46990d0 254 //VR1C=0 Control step of amplitude positive and negative of 64-grayscale.
king33jp 0:de7db46990d0 255 //VRP1[4:0]=00000 Control amplitude positive polarity of 64-grayscale.
king33jp 0:de7db46990d0 256 //VRN1[4:0]=00000 Control amplitude negative polarity of 64-grayscale.
king33jp 0:de7db46990d0 257
king33jp 0:de7db46990d0 258 /* Gamma settings -----------------------------------------------------------*/
king33jp 0:de7db46990d0 259 ///////r CONTROL
king33jp 0:de7db46990d0 260 regwr(0x0030,0x0303); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 261 regwr(0x0031,0x0303); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 262 regwr(0x0032,0x0303); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 263 regwr(0x0033,0x0000); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 264 regwr(0x0034,0x0404); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 265 regwr(0x0035,0x0404); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 266 regwr(0x0036,0x0404); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 267 regwr(0x0037,0x0000); //GAMMA CONTROL 2 (R30h to R37h)
king33jp 0:de7db46990d0 268 regwr(0x0038,0x0707); //GAMMA CONTROL 2 (R38h)
king33jp 0:de7db46990d0 269 ///////Coordinatioontrol setting
king33jp 0:de7db46990d0 270 regwr(0x0040,0x0000); // GATE SCAN POSITION (R40h)
king33jp 0:de7db46990d0 271 // 1 X X X X X X X X X X X SCN4 SCN3 SCN2 SCN1 SCN0
king33jp 0:de7db46990d0 272 //Set the scanning starting position of the gate driver.
king33jp 0:de7db46990d0 273
king33jp 0:de7db46990d0 274 regwr(0x0042,0x9f00); //1st SCREEN DRIVING POSITION (R42h)
king33jp 0:de7db46990d0 275 // SE17 SE16 SE15 SE14 SE13 SE12 SE11 SE10 SS17 SS16 SS15 SS14 SS13 SS12 SS11 SS10
king33jp 0:de7db46990d0 276
king33jp 0:de7db46990d0 277 regwr(0x0043,0x0000); //2nd SCREEN DRIVING POSITION (R43h)
king33jp 0:de7db46990d0 278 // SE27 SE26 SE25 SE24 SE23 SE22 SE21 SE20 SS27 SS26 SS25 SS24 SS23 SS22 SS21 SS20
king33jp 0:de7db46990d0 279 regwr(0x0044,0x7f00); //HORIZONTAL RAM ADDRESS POSITION (R44h)
king33jp 0:de7db46990d0 280
king33jp 0:de7db46990d0 281 regwr(0x0045,0x9f00); //VERTICAL RAM ADDRESS POSITION (R45h)
king33jp 0:de7db46990d0 282
king33jp 0:de7db46990d0 283 regwr(0x0069,0x0000); //DC/DC CONVERT LOW POWER MODE SETTING (R69h)
king33jp 0:de7db46990d0 284 // 0 0 0 0 0 0 0 0 0 0 0 NLDC3 NLDC2 NLDC1 NLDC0 NLPM
king33jp 0:de7db46990d0 285 //NLPM=0 Normal operation mode
king33jp 0:de7db46990d0 286 //NLDC[1:0]=00 DCCLK/1
king33jp 0:de7db46990d0 287 //NLDC[3:2]=00 DCCLK/2
king33jp 0:de7db46990d0 288
king33jp 0:de7db46990d0 289 regwr(0x0070,0x0000); //SOURCE DRIVER PRE-DRIVING PERIOD SETTING (R70h)
king33jp 0:de7db46990d0 290 // X X X X X X X X SDT1 SDT0 X X X X EQ1 EQ0
king33jp 0:de7db46990d0 291 //STD[1:0]=00 Source Output Delay Control=1 DISP_CK
king33jp 0:de7db46990d0 292 //EQ=00 No Equalization Control
king33jp 0:de7db46990d0 293
king33jp 0:de7db46990d0 294 regwr(0x0071,0x0000); //GATE OUTPUT PERIOD CONTROL (R71h)
king33jp 0:de7db46990d0 295 // X X X X GNO1 GNO0 X X X X X X X X X X
king33jp 0:de7db46990d0 296 //GNO=00 Non-Overlap Period Control =2 DISP_CKs
king33jp 0:de7db46990d0 297
king33jp 0:de7db46990d0 298 regwr(0x0073,0x0000); //TEST_KEY (R73h)
king33jp 0:de7db46990d0 299 // X X X X X X X X TEST_KEY[7:0]
king33jp 0:de7db46990d0 300 //When you want to update MTP data, “A5” should be written to this register.
king33jp 0:de7db46990d0 301
king33jp 0:de7db46990d0 302 regwr(0x00B3,0x0000); //PUMPING CLOCK SOURCE SELECTION (RB3h)
king33jp 0:de7db46990d0 303 // X 0 0 0 X 0 1 0 X X X DCR_EX X X X 1
king33jp 0:de7db46990d0 304 //Select the source of pumping clock.
king33jp 0:de7db46990d0 305 //In RGB mode, DCR_EX should be set before power setting.
king33jp 0:de7db46990d0 306
king33jp 0:de7db46990d0 307 regwr(0x00BD,0x0000); //MTP DATA READ (RBDh)
king33jp 0:de7db46990d0 308 // X X X X X X X DISEN X MTP_DOUT[6:0]
king33jp 0:de7db46990d0 309 //DISEN=0 Standby mode discharge circuit operation stop.
king33jp 0:de7db46990d0 310 //MTP_DOUT MTP data read using MTP_READ register.
king33jp 0:de7db46990d0 311
king33jp 0:de7db46990d0 312 regwr(0x00BE,0x0000); //INTERFACE MODE SELECTION (RBEh)
king33jp 0:de7db46990d0 313 // X X X X X X X X X X X IM_SEL IM_3 X X FLM_MSK
king33jp 0:de7db46990d0 314 //IM_SEL register selects interface mode.
king33jp 0:de7db46990d0 315 //IM_SEL=0 is IM[3:0] setting
king33jp 0:de7db46990d0 316
king33jp 0:de7db46990d0 317 regwr(0x0021,0x0000); //GRAM ADDRESS SET (R21h)
king33jp 0:de7db46990d0 318 // AD15 AD14 AD13 AD12 AD11 AD10 AD9 AD8 AD7 AD6 AD5 AD4 AD3 AD2 AD1 AD0
king33jp 0:de7db46990d0 319 // You can write initial GRAM address into internal Address Counter (AC).
king33jp 0:de7db46990d0 320
king33jp 0:de7db46990d0 321 reg0(0x0022); //WRITE DATA TO GRAM (R22h)
king33jp 0:de7db46990d0 322 // RAM write data (WD17 ~ WB0). Interface mode controls the width of WD
king33jp 0:de7db46990d0 323 // Data on DB bus is expanded to 18-bits before being written to GRAM and the data determines grayscale level of S6D0151’s source output.
king33jp 0:de7db46990d0 324 wait_ms(20);
king33jp 0:de7db46990d0 325
king33jp 0:de7db46990d0 326 regwr(0x0007,0x0020); //DISPLAY CONTROL (R07h)
king33jp 0:de7db46990d0 327 // X X X PT1 PT0 X X SPT X X GON DTE CL REV D1 D0
king33jp 0:de7db46990d0 328 //PT[1:0]=00 V63/V0 Normal Drive
king33jp 0:de7db46990d0 329 //SPT=0 Split Screen Driving Function is Not performed
king33jp 0:de7db46990d0 330 //GON=1,DTE=0 Normal operation
king33jp 0:de7db46990d0 331 //CL=0 262,144 colors / 65,536 colors
king33jp 0:de7db46990d0 332 //REV=0 Displays all character and graphics display sections with Normal
king33jp 0:de7db46990d0 333 //D[1:0]=00 the internal display operation halts and the display is off.
king33jp 0:de7db46990d0 334 wait_ms(5);
king33jp 0:de7db46990d0 335
king33jp 0:de7db46990d0 336 regwr(0x0007,0x0021); //DISPLAY CONTROL (R07h)
king33jp 0:de7db46990d0 337 // X X X PT1 PT0 X X SPT X X GON DTE CL REV D1 D0
king33jp 0:de7db46990d0 338 //D[1:0]=01 the internal display operation halts and the display is off.
king33jp 0:de7db46990d0 339
king33jp 0:de7db46990d0 340 regwr(0x0007,0x0027); //DISPLAY CONTROL (R07h)
king33jp 0:de7db46990d0 341 // X X X PT1 PT0 X X SPT X X GON DTE CL REV D1 D0
king33jp 0:de7db46990d0 342 //REV=1 Displays all character and graphics display sections with Reverse
king33jp 0:de7db46990d0 343 //D[1:0]=11 the internal display operation halts and the display is off.
king33jp 0:de7db46990d0 344
king33jp 0:de7db46990d0 345 wait_ms(50);
king33jp 0:de7db46990d0 346 regwr(0x0007,0x0037); //DISPLAY CONTROL (R07h)
king33jp 0:de7db46990d0 347 // X X X PT1 PT0 X X SPT X X GON DTE CL REV D1 D0
king33jp 0:de7db46990d0 348 //GON=1,DTE=1 VGH/VGL Normal operation
king33jp 1:a3651128e297 349 //Rev bit mean Color reverse.
king33jp 0:de7db46990d0 350 //REV=1 Displays all character and graphics display sections with Reverse
king33jp 0:de7db46990d0 351 //D[1:0]=11 Display is RAM data
king33jp 0:de7db46990d0 352
king33jp 1:a3651128e297 353 /* Up to here, demo code reference partsas ------------------------------*/
king33jp 1:a3651128e297 354
king33jp 0:de7db46990d0 355 WindowMax ();
king33jp 0:de7db46990d0 356 }
king33jp 0:de7db46990d0 357
king33jp 0:de7db46990d0 358
king33jp 0:de7db46990d0 359 void S6D0151_TFT::pixel(int x, int y, int color) {
king33jp 0:de7db46990d0 360 if ((x >= width()) || (y >= height())) return;
king33jp 0:de7db46990d0 361
king33jp 0:de7db46990d0 362 window(x,y,1,1);
king33jp 0:de7db46990d0 363
king33jp 0:de7db46990d0 364 wr_dat_start();
king33jp 0:de7db46990d0 365 _spi.write(color >> 8);
king33jp 0:de7db46990d0 366 _spi.write(color & 0xFF);
king33jp 0:de7db46990d0 367 wr_dat_stop();
king33jp 0:de7db46990d0 368
king33jp 0:de7db46990d0 369 }
king33jp 0:de7db46990d0 370
king33jp 0:de7db46990d0 371 void S6D0151_TFT::window (unsigned int x, unsigned int y, unsigned int w, unsigned int h) {
king33jp 0:de7db46990d0 372 unsigned int hea,hsa,vea,vsa,dd;
king33jp 0:de7db46990d0 373 hea=x+w-1;
king33jp 0:de7db46990d0 374 hsa=x;
king33jp 0:de7db46990d0 375 vea=y+h-1;
king33jp 0:de7db46990d0 376 vsa=y;
king33jp 0:de7db46990d0 377
king33jp 0:de7db46990d0 378 dd=((hea&0xff)<<8)|(hsa&0xff);
king33jp 0:de7db46990d0 379 regwr(0x0044, dd ); //HORIZONTAL RAM ADDRESS POSITION (R44h)
king33jp 0:de7db46990d0 380 dd=((vea&0xff)<<8)|(vsa&0xff);
king33jp 0:de7db46990d0 381 regwr(0x0045, dd ); //VERTICAL RAM ADDRESS POSITION (R45h)
king33jp 0:de7db46990d0 382
king33jp 1:a3651128e297 383 // set_start_address(hea,vea);
king33jp 1:a3651128e297 384 set_start_address(hsa,vsa);
king33jp 0:de7db46990d0 385 reg0(0x0022); //Write data to GRAM
king33jp 0:de7db46990d0 386 }
king33jp 0:de7db46990d0 387
king33jp 0:de7db46990d0 388
king33jp 0:de7db46990d0 389 void S6D0151_TFT::WindowMax (void) {
king33jp 0:de7db46990d0 390 window (0, 0, width(), height());
king33jp 0:de7db46990d0 391 }
king33jp 0:de7db46990d0 392
king33jp 0:de7db46990d0 393
king33jp 0:de7db46990d0 394 void S6D0151_TFT::cls (void) {
king33jp 0:de7db46990d0 395 unsigned int i;
king33jp 0:de7db46990d0 396 WindowMax();
king33jp 0:de7db46990d0 397
king33jp 0:de7db46990d0 398 wr_dat_start();
king33jp 0:de7db46990d0 399 for (i = 0; i < ( (width()+1) * (height()+3)); i++) {
king33jp 0:de7db46990d0 400 _spi.write(_background >> 8);
king33jp 0:de7db46990d0 401 _spi.write(_background & 0xFF);
king33jp 0:de7db46990d0 402 }
king33jp 0:de7db46990d0 403 wr_dat_stop();
king33jp 0:de7db46990d0 404 }
king33jp 0:de7db46990d0 405
king33jp 0:de7db46990d0 406
king33jp 0:de7db46990d0 407 void S6D0151_TFT::circle(int x0, int y0, int r, int color) {
king33jp 0:de7db46990d0 408
king33jp 0:de7db46990d0 409 int draw_x0, draw_y0;
king33jp 0:de7db46990d0 410 int draw_x1, draw_y1;
king33jp 0:de7db46990d0 411 int draw_x2, draw_y2;
king33jp 0:de7db46990d0 412 int draw_x3, draw_y3;
king33jp 0:de7db46990d0 413 int draw_x4, draw_y4;
king33jp 0:de7db46990d0 414 int draw_x5, draw_y5;
king33jp 0:de7db46990d0 415 int draw_x6, draw_y6;
king33jp 0:de7db46990d0 416 int draw_x7, draw_y7;
king33jp 0:de7db46990d0 417 int xx, yy;
king33jp 0:de7db46990d0 418 int di;
king33jp 0:de7db46990d0 419 WindowMax();
king33jp 0:de7db46990d0 420 if (r == 0) { /* no radius */
king33jp 0:de7db46990d0 421 return;
king33jp 0:de7db46990d0 422 }
king33jp 0:de7db46990d0 423
king33jp 0:de7db46990d0 424 draw_x0 = draw_x1 = x0;
king33jp 0:de7db46990d0 425 draw_y0 = draw_y1 = y0 + r;
king33jp 0:de7db46990d0 426 if (draw_y0 < height()) {
king33jp 0:de7db46990d0 427 pixel(draw_x0, draw_y0, color); /* 90 degree */
king33jp 0:de7db46990d0 428 }
king33jp 0:de7db46990d0 429
king33jp 0:de7db46990d0 430 draw_x2 = draw_x3 = x0;
king33jp 0:de7db46990d0 431 draw_y2 = draw_y3 = y0 - r;
king33jp 0:de7db46990d0 432 if (draw_y2 >= 0) {
king33jp 0:de7db46990d0 433 pixel(draw_x2, draw_y2, color); /* 270 degree */
king33jp 0:de7db46990d0 434 }
king33jp 0:de7db46990d0 435
king33jp 0:de7db46990d0 436 draw_x4 = draw_x6 = x0 + r;
king33jp 0:de7db46990d0 437 draw_y4 = draw_y6 = y0;
king33jp 0:de7db46990d0 438 if (draw_x4 < width()) {
king33jp 0:de7db46990d0 439 pixel(draw_x4, draw_y4, color); /* 0 degree */
king33jp 0:de7db46990d0 440 }
king33jp 0:de7db46990d0 441
king33jp 0:de7db46990d0 442 draw_x5 = draw_x7 = x0 - r;
king33jp 0:de7db46990d0 443 draw_y5 = draw_y7 = y0;
king33jp 0:de7db46990d0 444 if (draw_x5>=0) {
king33jp 0:de7db46990d0 445 pixel(draw_x5, draw_y5, color); /* 180 degree */
king33jp 0:de7db46990d0 446 }
king33jp 0:de7db46990d0 447
king33jp 0:de7db46990d0 448 if (r == 1) {
king33jp 0:de7db46990d0 449 return;
king33jp 0:de7db46990d0 450 }
king33jp 0:de7db46990d0 451
king33jp 0:de7db46990d0 452 di = 3 - 2*r;
king33jp 0:de7db46990d0 453 xx = 0;
king33jp 0:de7db46990d0 454 yy = r;
king33jp 0:de7db46990d0 455 while (xx < yy) {
king33jp 0:de7db46990d0 456
king33jp 0:de7db46990d0 457 if (di < 0) {
king33jp 0:de7db46990d0 458 di += 4*xx + 6;
king33jp 0:de7db46990d0 459 } else {
king33jp 0:de7db46990d0 460 di += 4*(xx - yy) + 10;
king33jp 0:de7db46990d0 461 yy--;
king33jp 0:de7db46990d0 462 draw_y0--;
king33jp 0:de7db46990d0 463 draw_y1--;
king33jp 0:de7db46990d0 464 draw_y2++;
king33jp 0:de7db46990d0 465 draw_y3++;
king33jp 0:de7db46990d0 466 draw_x4--;
king33jp 0:de7db46990d0 467 draw_x5++;
king33jp 0:de7db46990d0 468 draw_x6--;
king33jp 0:de7db46990d0 469 draw_x7++;
king33jp 0:de7db46990d0 470 }
king33jp 0:de7db46990d0 471 xx++;
king33jp 0:de7db46990d0 472 draw_x0++;
king33jp 0:de7db46990d0 473 draw_x1--;
king33jp 0:de7db46990d0 474 draw_x2++;
king33jp 0:de7db46990d0 475 draw_x3--;
king33jp 0:de7db46990d0 476 draw_y4++;
king33jp 0:de7db46990d0 477 draw_y5++;
king33jp 0:de7db46990d0 478 draw_y6--;
king33jp 0:de7db46990d0 479 draw_y7--;
king33jp 0:de7db46990d0 480
king33jp 0:de7db46990d0 481 if ( (draw_x0 <= width()) && (draw_y0>=0) ) {
king33jp 0:de7db46990d0 482 pixel(draw_x0, draw_y0, color);
king33jp 0:de7db46990d0 483 }
king33jp 0:de7db46990d0 484
king33jp 0:de7db46990d0 485 if ( (draw_x1 >= 0) && (draw_y1 >= 0) ) {
king33jp 0:de7db46990d0 486 pixel(draw_x1, draw_y1, color);
king33jp 0:de7db46990d0 487 }
king33jp 0:de7db46990d0 488
king33jp 0:de7db46990d0 489 if ( (draw_x2 <= width()) && (draw_y2 <= height()) ) {
king33jp 0:de7db46990d0 490 pixel(draw_x2, draw_y2, color);
king33jp 0:de7db46990d0 491 }
king33jp 0:de7db46990d0 492
king33jp 0:de7db46990d0 493 if ( (draw_x3 >=0 ) && (draw_y3 <= height()) ) {
king33jp 0:de7db46990d0 494 pixel(draw_x3, draw_y3, color);
king33jp 0:de7db46990d0 495 }
king33jp 0:de7db46990d0 496
king33jp 0:de7db46990d0 497 if ( (draw_x4 <= width()) && (draw_y4 >= 0) ) {
king33jp 0:de7db46990d0 498 pixel(draw_x4, draw_y4, color);
king33jp 0:de7db46990d0 499 }
king33jp 0:de7db46990d0 500
king33jp 0:de7db46990d0 501 if ( (draw_x5 >= 0) && (draw_y5 >= 0) ) {
king33jp 0:de7db46990d0 502 pixel(draw_x5, draw_y5, color);
king33jp 0:de7db46990d0 503 }
king33jp 0:de7db46990d0 504 if ( (draw_x6 <=width()) && (draw_y6 <= height()) ) {
king33jp 0:de7db46990d0 505 pixel(draw_x6, draw_y6, color);
king33jp 0:de7db46990d0 506 }
king33jp 0:de7db46990d0 507 if ( (draw_x7 >= 0) && (draw_y7 <= height()) ) {
king33jp 0:de7db46990d0 508 pixel(draw_x7, draw_y7, color);
king33jp 0:de7db46990d0 509 }
king33jp 0:de7db46990d0 510 }
king33jp 0:de7db46990d0 511 return;
king33jp 0:de7db46990d0 512 }
king33jp 0:de7db46990d0 513
king33jp 0:de7db46990d0 514 void S6D0151_TFT::fillcircle(int x, int y, int r, int color) {
king33jp 0:de7db46990d0 515 int i;
king33jp 0:de7db46990d0 516 for (i = 0; i <= r; i++)
king33jp 0:de7db46990d0 517 circle(x,y,i,color);
king33jp 0:de7db46990d0 518 }
king33jp 0:de7db46990d0 519
king33jp 0:de7db46990d0 520 void S6D0151_TFT::fillcircle2(int x0, int y0, int r, int color){
king33jp 0:de7db46990d0 521 int x = -r, y = 0, err = 2-2*r, e2;
king33jp 0:de7db46990d0 522 do {
king33jp 0:de7db46990d0 523 vline(x0-x, y0-y, y0+y, color);
king33jp 0:de7db46990d0 524 vline(x0+x, y0-y, y0+y, color);
king33jp 0:de7db46990d0 525 e2 = err;
king33jp 0:de7db46990d0 526 if (e2 <= y) {
king33jp 0:de7db46990d0 527 err += ++y*2+1;
king33jp 0:de7db46990d0 528 if (-x == y && e2 <= x) e2 = 0;
king33jp 0:de7db46990d0 529 }
king33jp 0:de7db46990d0 530 if (e2 > x) err += ++x*2+1;
king33jp 0:de7db46990d0 531 } while (x <= 0);
king33jp 0:de7db46990d0 532 }
king33jp 0:de7db46990d0 533
king33jp 0:de7db46990d0 534 void S6D0151_TFT::hline(int x0, int x1, int y, int color) {
king33jp 0:de7db46990d0 535 int w;
king33jp 0:de7db46990d0 536 w = x1 - x0 + 1;
king33jp 0:de7db46990d0 537 window(x0,y,w,1);
king33jp 0:de7db46990d0 538 wr_dat_start();
king33jp 0:de7db46990d0 539 for (int x=0; x<w; x++) {
king33jp 0:de7db46990d0 540 _spi.write(color >> 8);
king33jp 0:de7db46990d0 541 _spi.write(color);
king33jp 0:de7db46990d0 542 }
king33jp 0:de7db46990d0 543 wr_dat_stop();
king33jp 0:de7db46990d0 544 return;
king33jp 0:de7db46990d0 545 }
king33jp 0:de7db46990d0 546
king33jp 0:de7db46990d0 547
king33jp 0:de7db46990d0 548
king33jp 0:de7db46990d0 549 void S6D0151_TFT::vline(int x, int y0, int y1, int color) {
king33jp 0:de7db46990d0 550 int h;
king33jp 0:de7db46990d0 551 h = y1 - y0 + 1;
king33jp 0:de7db46990d0 552 window(x,y0,1,h);
king33jp 0:de7db46990d0 553 wr_dat_start();
king33jp 0:de7db46990d0 554 for (int y=0; y<h; y++) {
king33jp 0:de7db46990d0 555 _spi.write(color >> 8);
king33jp 0:de7db46990d0 556 _spi.write(color);
king33jp 0:de7db46990d0 557 }
king33jp 0:de7db46990d0 558 wr_dat_stop();
king33jp 0:de7db46990d0 559 return;
king33jp 0:de7db46990d0 560 }
king33jp 0:de7db46990d0 561
king33jp 0:de7db46990d0 562
king33jp 0:de7db46990d0 563
king33jp 0:de7db46990d0 564 void S6D0151_TFT::line(int x0, int y0, int x1, int y1, int color) {
king33jp 0:de7db46990d0 565 WindowMax();
king33jp 0:de7db46990d0 566 int dx = 0, dy = 0;
king33jp 0:de7db46990d0 567 int dx_sym = 0, dy_sym = 0;
king33jp 0:de7db46990d0 568 int dx_x2 = 0, dy_x2 = 0;
king33jp 0:de7db46990d0 569 int di = 0;
king33jp 0:de7db46990d0 570
king33jp 0:de7db46990d0 571 dx = x1-x0;
king33jp 0:de7db46990d0 572 dy = y1-y0;
king33jp 0:de7db46990d0 573
king33jp 0:de7db46990d0 574 if (dx == 0) { /* vertical line */
king33jp 0:de7db46990d0 575 if (y1 > y0) vline(x0,y0,y1,color);
king33jp 0:de7db46990d0 576 else vline(x0,y1,y0,color);
king33jp 0:de7db46990d0 577 return;
king33jp 0:de7db46990d0 578 }
king33jp 0:de7db46990d0 579
king33jp 0:de7db46990d0 580 if (dx > 0) {
king33jp 0:de7db46990d0 581 dx_sym = 1;
king33jp 0:de7db46990d0 582 } else {
king33jp 0:de7db46990d0 583 dx_sym = -1;
king33jp 0:de7db46990d0 584 }
king33jp 0:de7db46990d0 585 if (dy == 0) { /* horizontal line */
king33jp 0:de7db46990d0 586 if (x1 > x0) hline(x0,x1,y0,color);
king33jp 0:de7db46990d0 587 else hline(x1,x0,y0,color);
king33jp 0:de7db46990d0 588 return;
king33jp 0:de7db46990d0 589 }
king33jp 0:de7db46990d0 590
king33jp 0:de7db46990d0 591 if (dy > 0) {
king33jp 0:de7db46990d0 592 dy_sym = 1;
king33jp 0:de7db46990d0 593 } else {
king33jp 0:de7db46990d0 594 dy_sym = -1;
king33jp 0:de7db46990d0 595 }
king33jp 0:de7db46990d0 596
king33jp 0:de7db46990d0 597 dx = dx_sym*dx;
king33jp 0:de7db46990d0 598 dy = dy_sym*dy;
king33jp 0:de7db46990d0 599
king33jp 0:de7db46990d0 600 dx_x2 = dx*2;
king33jp 0:de7db46990d0 601 dy_x2 = dy*2;
king33jp 0:de7db46990d0 602
king33jp 0:de7db46990d0 603 if (dx >= dy) {
king33jp 0:de7db46990d0 604 di = dy_x2 - dx;
king33jp 0:de7db46990d0 605 while (x0 != x1) {
king33jp 0:de7db46990d0 606
king33jp 0:de7db46990d0 607 pixel(x0, y0, color);
king33jp 0:de7db46990d0 608 x0 += dx_sym;
king33jp 0:de7db46990d0 609 if (di<0) {
king33jp 0:de7db46990d0 610 di += dy_x2;
king33jp 0:de7db46990d0 611 } else {
king33jp 0:de7db46990d0 612 di += dy_x2 - dx_x2;
king33jp 0:de7db46990d0 613 y0 += dy_sym;
king33jp 0:de7db46990d0 614 }
king33jp 0:de7db46990d0 615 }
king33jp 0:de7db46990d0 616 pixel(x0, y0, color);
king33jp 0:de7db46990d0 617 } else {
king33jp 0:de7db46990d0 618 di = dx_x2 - dy;
king33jp 0:de7db46990d0 619 while (y0 != y1) {
king33jp 0:de7db46990d0 620 pixel(x0, y0, color);
king33jp 0:de7db46990d0 621 y0 += dy_sym;
king33jp 0:de7db46990d0 622 if (di < 0) {
king33jp 0:de7db46990d0 623 di += dx_x2;
king33jp 0:de7db46990d0 624 } else {
king33jp 0:de7db46990d0 625 di += dx_x2 - dy_x2;
king33jp 0:de7db46990d0 626 x0 += dx_sym;
king33jp 0:de7db46990d0 627 }
king33jp 0:de7db46990d0 628 }
king33jp 0:de7db46990d0 629 pixel(x0, y0, color);
king33jp 0:de7db46990d0 630 }
king33jp 0:de7db46990d0 631 return;
king33jp 0:de7db46990d0 632 }
king33jp 0:de7db46990d0 633
king33jp 0:de7db46990d0 634
king33jp 0:de7db46990d0 635
king33jp 0:de7db46990d0 636
king33jp 0:de7db46990d0 637 void S6D0151_TFT::rect(int x0, int y0, int x1, int y1, int color) {
king33jp 0:de7db46990d0 638
king33jp 0:de7db46990d0 639 if (x1 > x0) hline(x0,x1,y0,color);
king33jp 0:de7db46990d0 640 else hline(x1,x0,y0,color);
king33jp 0:de7db46990d0 641
king33jp 0:de7db46990d0 642 if (y1 > y0) vline(x0,y0,y1,color);
king33jp 0:de7db46990d0 643 else vline(x0,y1,y0,color);
king33jp 0:de7db46990d0 644
king33jp 0:de7db46990d0 645 if (x1 > x0) hline(x0,x1,y1,color);
king33jp 0:de7db46990d0 646 else hline(x1,x0,y1,color);
king33jp 0:de7db46990d0 647
king33jp 0:de7db46990d0 648 if (y1 > y0) vline(x1,y0,y1,color);
king33jp 0:de7db46990d0 649 else vline(x1,y1,y0,color);
king33jp 0:de7db46990d0 650
king33jp 0:de7db46990d0 651 return;
king33jp 0:de7db46990d0 652 }
king33jp 0:de7db46990d0 653
king33jp 0:de7db46990d0 654
king33jp 0:de7db46990d0 655
king33jp 0:de7db46990d0 656 void S6D0151_TFT::fillrect(int x0, int y0, int x1, int y1, int color) {
king33jp 0:de7db46990d0 657
king33jp 0:de7db46990d0 658 int h = y1 - y0 + 1;
king33jp 0:de7db46990d0 659 int w = x1 - x0 + 1;
king33jp 0:de7db46990d0 660 int pixel = h * w;
king33jp 0:de7db46990d0 661 window(x0,y0,w,h);
king33jp 0:de7db46990d0 662 wr_dat_start();
king33jp 0:de7db46990d0 663 for (int p=0; p<pixel; p++) {
king33jp 0:de7db46990d0 664 _spi.write(color >> 8);
king33jp 5:18920a7a693e 665 _spi.write(color & 0xFF);
king33jp 0:de7db46990d0 666 }
king33jp 0:de7db46990d0 667 wr_dat_stop();
king33jp 0:de7db46990d0 668 return;
king33jp 0:de7db46990d0 669 }
king33jp 0:de7db46990d0 670
king33jp 0:de7db46990d0 671
king33jp 0:de7db46990d0 672
king33jp 0:de7db46990d0 673 void S6D0151_TFT::locate(int x, int y) {
king33jp 0:de7db46990d0 674 char_x = x;
king33jp 0:de7db46990d0 675 char_y = y;
king33jp 0:de7db46990d0 676 }
king33jp 0:de7db46990d0 677
king33jp 0:de7db46990d0 678
king33jp 0:de7db46990d0 679
king33jp 0:de7db46990d0 680 int S6D0151_TFT::columns() {
king33jp 0:de7db46990d0 681 return width() / font[1];
king33jp 0:de7db46990d0 682 }
king33jp 0:de7db46990d0 683
king33jp 0:de7db46990d0 684
king33jp 0:de7db46990d0 685
king33jp 0:de7db46990d0 686 int S6D0151_TFT::rows() {
king33jp 0:de7db46990d0 687 return height() / font[2];
king33jp 0:de7db46990d0 688 }
king33jp 0:de7db46990d0 689
king33jp 0:de7db46990d0 690
king33jp 0:de7db46990d0 691
king33jp 0:de7db46990d0 692 int S6D0151_TFT::_putc(int value) {
king33jp 0:de7db46990d0 693 if (value == '\n') { // new line
king33jp 0:de7db46990d0 694 char_x = 0;
king33jp 0:de7db46990d0 695 char_y = char_y + font[2];
king33jp 0:de7db46990d0 696 if (char_y >= height() - font[2]) {
king33jp 0:de7db46990d0 697 char_y = 0;
king33jp 0:de7db46990d0 698 }
king33jp 0:de7db46990d0 699 } else {
king33jp 0:de7db46990d0 700 character(char_x, char_y, value);
king33jp 0:de7db46990d0 701 }
king33jp 0:de7db46990d0 702 return value;
king33jp 0:de7db46990d0 703 }
king33jp 0:de7db46990d0 704
king33jp 0:de7db46990d0 705
king33jp 0:de7db46990d0 706
king33jp 0:de7db46990d0 707
king33jp 0:de7db46990d0 708 void S6D0151_TFT::character(int x, int y, int c) {
king33jp 0:de7db46990d0 709 unsigned int hor,vert,offset,bpl,j,i,b;
king33jp 0:de7db46990d0 710 unsigned char* zeichen;
king33jp 0:de7db46990d0 711 unsigned char z,w;
king33jp 0:de7db46990d0 712
king33jp 0:de7db46990d0 713 if ((c < 31) || (c > 156)) return; // test char range
king33jp 0:de7db46990d0 714
king33jp 0:de7db46990d0 715 // read font parameter from start of array
king33jp 0:de7db46990d0 716 offset = font[0]; // bytes / char
king33jp 0:de7db46990d0 717 hor = font[1]; // get hor size of font
king33jp 0:de7db46990d0 718 vert = font[2]; // get vert size of font
king33jp 0:de7db46990d0 719 bpl = font[3]; // bytes per line
king33jp 0:de7db46990d0 720
king33jp 0:de7db46990d0 721 if (char_x + hor > width()) {
king33jp 0:de7db46990d0 722 char_x = 0;
king33jp 0:de7db46990d0 723 char_y = char_y + vert;
king33jp 0:de7db46990d0 724 if (char_y >= height() - font[2]) {
king33jp 0:de7db46990d0 725 char_y = 0;
king33jp 0:de7db46990d0 726 }
king33jp 0:de7db46990d0 727 }
king33jp 0:de7db46990d0 728
king33jp 0:de7db46990d0 729 window(char_x, char_y,hor,vert); // char box
king33jp 0:de7db46990d0 730 wr_dat_start();
king33jp 0:de7db46990d0 731 zeichen = &font[((c -32) * offset) + 4]; // start of char bitmap
king33jp 0:de7db46990d0 732 w = zeichen[0]; // width of actual char
king33jp 0:de7db46990d0 733
king33jp 0:de7db46990d0 734 for (j=0; j<vert; j++) { // vert line
king33jp 0:de7db46990d0 735 for (i=0; i<hor; i++) { // horz line
king33jp 0:de7db46990d0 736 z = zeichen[bpl * i + ((j & 0xF8) >> 3)+1];
king33jp 0:de7db46990d0 737 b = 1 << (j & 0x07);
king33jp 0:de7db46990d0 738 if (( z & b ) == 0x00) {
king33jp 0:de7db46990d0 739 _spi.write(_background >> 8);
king33jp 0:de7db46990d0 740 _spi.write(_background & 0xff);
king33jp 0:de7db46990d0 741 } else {
king33jp 0:de7db46990d0 742 _spi.write(_foreground >> 8);
king33jp 0:de7db46990d0 743 _spi.write(_foreground & 0xff);
king33jp 0:de7db46990d0 744 }
king33jp 0:de7db46990d0 745 }
king33jp 0:de7db46990d0 746 }
king33jp 0:de7db46990d0 747 wr_dat_stop();
king33jp 0:de7db46990d0 748 if ((w + 2) < hor) { // x offset to next char
king33jp 0:de7db46990d0 749 char_x += w + 2;
king33jp 0:de7db46990d0 750 } else char_x += hor;
king33jp 0:de7db46990d0 751 }
king33jp 0:de7db46990d0 752
king33jp 0:de7db46990d0 753 void S6D0151_TFT::set_font(unsigned char* f) {
king33jp 0:de7db46990d0 754 font = f;
king33jp 0:de7db46990d0 755 }
king33jp 0:de7db46990d0 756
king33jp 0:de7db46990d0 757
king33jp 0:de7db46990d0 758
king33jp 0:de7db46990d0 759 void S6D0151_TFT::Bitmap(unsigned int x, unsigned int y, unsigned int w, unsigned int h,unsigned char *bitmap) {
king33jp 0:de7db46990d0 760 unsigned int i,j;
king33jp 0:de7db46990d0 761 unsigned short *bitmap_ptr = (unsigned short *)bitmap;
king33jp 0:de7db46990d0 762 window(x, y, w, h);
king33jp 0:de7db46990d0 763 wr_dat_start();
king33jp 0:de7db46990d0 764 for (j = 0; j < h; j++) { //Lines
king33jp 0:de7db46990d0 765 for (i = 0; i < w; i++) { // copy pixel data to TFT
king33jp 0:de7db46990d0 766
king33jp 0:de7db46990d0 767 _spi.write(*bitmap_ptr >> 8);
king33jp 0:de7db46990d0 768 _spi.write(*bitmap_ptr); // one line
king33jp 0:de7db46990d0 769
king33jp 0:de7db46990d0 770 bitmap_ptr++;
king33jp 0:de7db46990d0 771 }
king33jp 0:de7db46990d0 772 }
king33jp 0:de7db46990d0 773 wr_dat_stop();
king33jp 0:de7db46990d0 774 }
king33jp 0:de7db46990d0 775
king33jp 0:de7db46990d0 776