Basically i glued Peter Drescher and Simon Ford libs in a GraphicsDisplay class, then derived TFT or LCD class (which inherits Protocols class), then the most derived ones (Inits), which are per-display and are the only part needed to be adapted to diff hw.

Fork of UniGraphic by GraphicsDisplay

Embed: (wiki syntax)

« Back to documentation index

PAR16 Class Reference

Parallel 16bit interface. More...

#include <PAR16.h>

Inherits Protocols.

Public Member Functions

 PAR16 (PortName port, PinName CS, PinName reset, PinName DC, PinName WR, PinName RD)
 Create a PAR16 display interface with a GPIO port and 5 control pins.

Protected Member Functions

virtual void wr_cmd8 (unsigned char cmd)
 Send 8bit command to display controller.
virtual void wr_data8 (unsigned char data)
 Send 8bit data to display controller.
virtual void wr_cmd16 (unsigned short cmd)
 Send 2x8bit command to display controller.
virtual void wr_data16 (unsigned short data)
 Send 2x8bit data to display controller.
virtual void wr_gram (unsigned short data)
 Send 16bit pixeldata to display controller.
virtual void wr_gram (unsigned short data, unsigned int count)
 Send same 16bit pixeldata to display controller multiple times.
virtual void wr_grambuf (unsigned short *data, unsigned int lenght)
 Send array of pixeldata shorts to display controller.
virtual unsigned short rd_gram (bool convert)
 Read 16bit pixeldata from display controller (with dummy cycle)
virtual unsigned int rd_reg_data32 (unsigned char reg)
 Read 4x8bit register data (with dummy cycle)
virtual unsigned int rd_extcreg_data32 (unsigned char reg, unsigned char SPIreadenablecmd)
 Read 3x8bit ExtendedCommands register data.
virtual void dummyread ()
 ILI932x specific, does a dummy read cycle, number of bits is protocol dependent for PAR protocols: a signle RD bit toggle for SPI8: 8clocks for SPI16: 16 clocks.
virtual void reg_select (unsigned char reg, bool forread=false)
 ILI932x specific, select register for a successive write or read.
virtual void reg_write (unsigned char reg, unsigned short data)
 ILI932x specific, write register with data.
virtual unsigned short reg_read (unsigned char reg)
 ILI932x specific, read register.
virtual void hw_reset ()
 HW reset sequence (without display init commands)
virtual void BusEnable (bool enable)
 Set ChipSelect high or low.

Detailed Description

Parallel 16bit interface.

Definition at line 10 of file PAR16.h.


Constructor & Destructor Documentation

PAR16 ( PortName  port,
PinName  CS,
PinName  reset,
PinName  DC,
PinName  WR,
PinName  RD 
)

Create a PAR16 display interface with a GPIO port and 5 control pins.

Parameters:
portGPIO port to use
CSpin connected to CS of display
resetpin connected to RESET of display
DCpin connected to data/command of display
WRpin connected to SDI of display
RDpin connected to RS of display

Definition at line 20 of file PAR16.cpp.


Member Function Documentation

void BusEnable ( bool  enable ) [protected, virtual]

Set ChipSelect high or low.

Parameters:
enable0/1

Implements Protocols.

Definition at line 224 of file PAR16.cpp.

void dummyread (  ) [protected, virtual]

ILI932x specific, does a dummy read cycle, number of bits is protocol dependent for PAR protocols: a signle RD bit toggle for SPI8: 8clocks for SPI16: 16 clocks.

Implements Protocols.

Definition at line 167 of file PAR16.cpp.

void hw_reset (  ) [protected, virtual]

HW reset sequence (without display init commands)

Implements Protocols.

Definition at line 212 of file PAR16.cpp.

unsigned int rd_extcreg_data32 ( unsigned char  reg,
unsigned char  SPIreadenablecmd 
) [protected, virtual]

Read 3x8bit ExtendedCommands register data.

Parameters:
regthe register to read
Returns:
data as uint
Note:
EXTC regs (0xB0 to 0xFF) are read/write registers, for Parallel mode directly accessible in both directions

Implements Protocols.

Definition at line 162 of file PAR16.cpp.

unsigned short rd_gram ( bool  convert ) [protected, virtual]

Read 16bit pixeldata from display controller (with dummy cycle)

Parameters:
converttrue/false. Convert 18bit to 16bit, some controllers returns 18bit
Returns:
16bit color

Implements Protocols.

Definition at line 94 of file PAR16.cpp.

unsigned int rd_reg_data32 ( unsigned char  reg ) [protected, virtual]

Read 4x8bit register data (with dummy cycle)

Parameters:
regthe register to read
Returns:
data as uint

Implements Protocols.

Definition at line 121 of file PAR16.cpp.

unsigned short reg_read ( unsigned char  reg ) [protected, virtual]

ILI932x specific, read register.

Parameters:
regregister to be read
Returns:
16bit register value

Implements Protocols.

Definition at line 197 of file PAR16.cpp.

void reg_select ( unsigned char  reg,
bool  forread = false 
) [protected, virtual]

ILI932x specific, select register for a successive write or read.

Parameters:
regregister to be selected
forreadfalse = a write next (default), true = a read next
Note:
forread only used by SPI protocols

Implements Protocols.

Definition at line 176 of file PAR16.cpp.

void reg_write ( unsigned char  reg,
unsigned short  data 
) [protected, virtual]

ILI932x specific, write register with data.

Parameters:
regregister to write
data16bit data

Implements Protocols.

Definition at line 185 of file PAR16.cpp.

void wr_cmd16 ( unsigned short  cmd ) [protected, virtual]

Send 2x8bit command to display controller.

Parameters:
cmd,:halfword to send
Note:
2cycles using pins[7:0]

Implements Protocols.

Definition at line 47 of file PAR16.cpp.

void wr_cmd8 ( unsigned char  cmd ) [protected, virtual]

Send 8bit command to display controller.

Parameters:
cmd,:byte to send

Implements Protocols.

Definition at line 33 of file PAR16.cpp.

void wr_data16 ( unsigned short  data ) [protected, virtual]

Send 2x8bit data to display controller.

Parameters:
data,:halfword to send
Note:
2cycles using pins[7:0], only gram write cmd uses pins[15:8]

Implements Protocols.

Definition at line 58 of file PAR16.cpp.

void wr_data8 ( unsigned char  data ) [protected, virtual]

Send 8bit data to display controller.

Parameters:
data,:byte to send

Implements Protocols.

Definition at line 41 of file PAR16.cpp.

void wr_gram ( unsigned short  data ) [protected, virtual]

Send 16bit pixeldata to display controller.

Parameters:
data,:halfword to send
Note:
here using all pins[15:0]

Implements Protocols.

Definition at line 67 of file PAR16.cpp.

void wr_gram ( unsigned short  data,
unsigned int  count 
) [protected, virtual]

Send same 16bit pixeldata to display controller multiple times.

Parameters:
data,:halfword to send
count,:how many
Note:
here using all pins[15:0]

Implements Protocols.

Definition at line 73 of file PAR16.cpp.

void wr_grambuf ( unsigned short *  data,
unsigned int  lenght 
) [protected, virtual]

Send array of pixeldata shorts to display controller.

Parameters:
data,:unsigned short pixeldata array
lenght,:lenght (in shorts)
Note:
here using all pins[15:0]

Implements Protocols.

Definition at line 83 of file PAR16.cpp.