MARMEX_VB test application program. This application works on "mbed NXP LPC1768" only. This application expects to have the MARMEX_VB module on a "MAPLE mini type-B (MARM03-BASE)" baseboard (slot2) with MARMEX_OB module (on slot1)
Dependencies: MARMEX_VB NokiaLCD mbed
This is the library test program.
The program can test features of the library (refer to MARMEX-VB's API document) and can save captured data into BMP file.
Warning!
This test program can run on "mbed NXP LPC1768" only.
Picture : sample of test program operation
The modules of MARMEX-VB and MARMEX-OB are set on the "MAPLE mini type-B (MARM03-BASE)" baseboard.
The image data from camera is mirrored and alpha graphics added by software.
MARMEX_OB_oled.h@1:dbe2dc31542d, 2014-06-09 (annotated)
- Committer:
- nxpfan
- Date:
- Mon Jun 09 19:42:34 2014 +0000
- Revision:
- 1:dbe2dc31542d
- Parent:
- 0:343c01965543
- Child:
- 5:ac4f0c5d1c6f
MARMEX-VB test version 0.2 (mbed_NXP_LPC1768 optimization added)
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
nxpfan | 0:343c01965543 | 1 | /** MARMEX_OB OLED screen drawing library |
nxpfan | 0:343c01965543 | 2 | * |
nxpfan | 0:343c01965543 | 3 | * @class MARMEX_OB_oled |
nxpfan | 0:343c01965543 | 4 | * @author tedd |
nxpfan | 1:dbe2dc31542d | 5 | * @version 0.52 (optimized for "mbed NXP LPC1768") |
nxpfan | 1:dbe2dc31542d | 6 | * @date 06-Jun-2014 |
nxpfan | 0:343c01965543 | 7 | * |
nxpfan | 0:343c01965543 | 8 | * Released under the MIT License: http://mbed.org/license/mit |
nxpfan | 0:343c01965543 | 9 | * |
nxpfan | 0:343c01965543 | 10 | * MARMEX_OB_oled OLED screen drawing library for mbed |
nxpfan | 0:343c01965543 | 11 | * This code has been written based on sample code and advises |
nxpfan | 0:343c01965543 | 12 | * from Ochiai-san (Marutsu-Elec). Thank you! |
nxpfan | 0:343c01965543 | 13 | * |
nxpfan | 0:343c01965543 | 14 | * SPI mode: |
nxpfan | 0:343c01965543 | 15 | * 9bit or 8bit SPI mode can be selected by disabling/enabling "#define MARMEX_OB_SPI_8BIT_MODE". |
nxpfan | 0:343c01965543 | 16 | * See source code in this (MARMEX_OB_oled.h) file. |
nxpfan | 0:343c01965543 | 17 | */ |
nxpfan | 0:343c01965543 | 18 | |
nxpfan | 0:343c01965543 | 19 | #ifndef MBED_MARMEX_OB_OLED |
nxpfan | 0:343c01965543 | 20 | #define MBED_MARMEX_OB_OLED |
nxpfan | 0:343c01965543 | 21 | |
nxpfan | 0:343c01965543 | 22 | #include "mbed.h" |
nxpfan | 0:343c01965543 | 23 | #include "NokiaLCD.h" |
nxpfan | 0:343c01965543 | 24 | |
nxpfan | 0:343c01965543 | 25 | /** @def MARMEX_OB_SPI_8BIT_MODE |
nxpfan | 0:343c01965543 | 26 | * |
nxpfan | 0:343c01965543 | 27 | * MARMEX_OB_oled_oled OLED screen SPI access length setting |
nxpfan | 0:343c01965543 | 28 | * Enabling "MARMEX_OB_SPI_8BIT_MODE" makes 9bit SPI access by 8bit * 2 times. |
nxpfan | 0:343c01965543 | 29 | * This may be useful if other 8bit access SPI device on same SPI bus. |
nxpfan | 0:343c01965543 | 30 | * |
nxpfan | 0:343c01965543 | 31 | * If disabled (just coment out the "#define MARMEX_OB_SPI_8BIT_MODE"), SPI access willbe done by 9 bit format. |
nxpfan | 0:343c01965543 | 32 | */ |
nxpfan | 1:dbe2dc31542d | 33 | //#define MARMEX_OB_SPI_8BIT_MODE |
nxpfan | 0:343c01965543 | 34 | |
nxpfan | 0:343c01965543 | 35 | /** MARMEX_OB_oled OLED screen drawing class |
nxpfan | 0:343c01965543 | 36 | * |
nxpfan | 0:343c01965543 | 37 | * This is a driver code for MARMEX_OB_oled board OLED screen. |
nxpfan | 0:343c01965543 | 38 | * This class inherits NokiaLCD class of mbed.org. |
nxpfan | 0:343c01965543 | 39 | * To use this class, import the NokiaLCD class from here.. |
nxpfan | 0:343c01965543 | 40 | * http://mbed.org/users/simon/libraries/NokiaLCD/ |
nxpfan | 0:343c01965543 | 41 | * |
nxpfan | 0:343c01965543 | 42 | * Example: |
nxpfan | 0:343c01965543 | 43 | * @code |
nxpfan | 0:343c01965543 | 44 | * #include "mbed.h" |
nxpfan | 0:343c01965543 | 45 | * #include "MARMEX_OB_oled.h" |
nxpfan | 0:343c01965543 | 46 | * |
nxpfan | 0:343c01965543 | 47 | * // oled1 is for MARMEX_OB_oled board on MAPLE slot 1 |
nxpfan | 0:343c01965543 | 48 | * // oled2 is for MARMEX_OB_oled board on MAPLE slot 2 |
nxpfan | 0:343c01965543 | 49 | * |
nxpfan | 0:343c01965543 | 50 | * //MARMEX_OB_oled oled1( p5, p7, p8, p30, p11 ); // mosi, sclk, cs, rst, power_control |
nxpfan | 0:343c01965543 | 51 | * MARMEX_OB_oled oled2( p5, p7, p26, p21, p17 ); // mosi, sclk, cs, rst, power_control |
nxpfan | 0:343c01965543 | 52 | * |
nxpfan | 0:343c01965543 | 53 | * int main() { |
nxpfan | 0:343c01965543 | 54 | * oled2.background( 0x000000 ); |
nxpfan | 0:343c01965543 | 55 | * oled2.cls(); |
nxpfan | 0:343c01965543 | 56 | * |
nxpfan | 0:343c01965543 | 57 | * for ( int i = 0; i < 8; i++ ) |
nxpfan | 0:343c01965543 | 58 | * oled2.fill( (MARMEX_OB_oled::WIDTH / 8) * i, 0, (MARMEX_OB_oled::WIDTH / 8), 128, ((i & 0x4) ? 0xFF0000 : 0x000000) | ((i & 0x2) ? 0x00FF00 : 0x000000) |((i & 0x1) ? 0x0000FF : 0x000000) ); |
nxpfan | 0:343c01965543 | 59 | * |
nxpfan | 0:343c01965543 | 60 | * oled2.fill( 50, 50, 64, 64, 0xCCCCCC ); |
nxpfan | 0:343c01965543 | 61 | * |
nxpfan | 0:343c01965543 | 62 | * oled2.locate( 0, 3 ); |
nxpfan | 0:343c01965543 | 63 | * oled2.printf( "Hello World!" ); |
nxpfan | 0:343c01965543 | 64 | * oled2.locate( 0, 4 ); |
nxpfan | 0:343c01965543 | 65 | * oled2.printf( "SPI = %s", MERMEX_OB_SPI_MODE_STR ); |
nxpfan | 0:343c01965543 | 66 | * |
nxpfan | 0:343c01965543 | 67 | * for (int i = 0; i < MARMEX_OB_oled::WIDTH; i++ ) { |
nxpfan | 0:343c01965543 | 68 | * oled2.pixel( i, 80 + sin( (float)i / 5.0 ) * 10, 0x000000 ); |
nxpfan | 0:343c01965543 | 69 | * } |
nxpfan | 0:343c01965543 | 70 | * } |
nxpfan | 0:343c01965543 | 71 | * @endcode |
nxpfan | 0:343c01965543 | 72 | */ |
nxpfan | 0:343c01965543 | 73 | |
nxpfan | 1:dbe2dc31542d | 74 | class MARMEX_OB_oled : public NokiaLCD |
nxpfan | 1:dbe2dc31542d | 75 | { |
nxpfan | 0:343c01965543 | 76 | |
nxpfan | 0:343c01965543 | 77 | public: |
nxpfan | 0:343c01965543 | 78 | |
nxpfan | 0:343c01965543 | 79 | /** General parameters for MARMEX_OB_oled */ |
nxpfan | 0:343c01965543 | 80 | enum { |
nxpfan | 0:343c01965543 | 81 | ROWS = 15, /**< # of rows (lines) for displaying characters */ |
nxpfan | 0:343c01965543 | 82 | COLS = 16, /**< # of columns (width) for displaying characters */ |
nxpfan | 0:343c01965543 | 83 | WIDTH = 128, /**< screen width [pixels] */ |
nxpfan | 0:343c01965543 | 84 | HEIGHT = 128, /**< screen height [pixels] */ |
nxpfan | 0:343c01965543 | 85 | SPI_FREQUENCY = 12000000 /**< SPI (sclk) SPI_FREQUENCY */ |
nxpfan | 0:343c01965543 | 86 | }; |
nxpfan | 0:343c01965543 | 87 | |
nxpfan | 0:343c01965543 | 88 | /** Constants for power() function */ |
nxpfan | 0:343c01965543 | 89 | enum { |
nxpfan | 0:343c01965543 | 90 | OFF = 0, /**< : to turning-OFF */ |
nxpfan | 0:343c01965543 | 91 | ON /**< : to turning-ON */ |
nxpfan | 0:343c01965543 | 92 | }; |
nxpfan | 0:343c01965543 | 93 | |
nxpfan | 0:343c01965543 | 94 | /** Create a MARMEX_OB_oled object connected to specified SPI and DigitalOut pins |
nxpfan | 0:343c01965543 | 95 | * |
nxpfan | 0:343c01965543 | 96 | * @param mosi SPI-MOSI pin (for MAPLE board, use p5) |
nxpfan | 0:343c01965543 | 97 | * @param sclk SPI-SCLK pin (for MAPLE board, use p8) |
nxpfan | 0:343c01965543 | 98 | * @param cs chip select signal (for MAPLE board, use p8(slot1), p26(slot2)) |
nxpfan | 0:343c01965543 | 99 | * @param rst reset signal (for MAPLE board, use p30(slot1), p21(slot2)) |
nxpfan | 0:343c01965543 | 100 | * @param power_pin backlight power control signal (for MAPLE board, use p11(slot1), p17(slot2)) |
nxpfan | 0:343c01965543 | 101 | * |
nxpfan | 0:343c01965543 | 102 | * Example of MARMEX_OB_oled on MAPLE board: |
nxpfan | 0:343c01965543 | 103 | * @code |
nxpfan | 0:343c01965543 | 104 | * #include "mbed.h" |
nxpfan | 0:343c01965543 | 105 | * #include "MARMEX_OB_oled.h" |
nxpfan | 0:343c01965543 | 106 | * |
nxpfan | 0:343c01965543 | 107 | * MARMEX_OB_oled oled_on_maple_slot1( p5, p7, p8, p30, p11 ); // mosi, sclk, cs, rst, power_control |
nxpfan | 0:343c01965543 | 108 | * MARMEX_OB_oled oled_on_maple_slot2( p5, p7, p26, p21, p17 ); // mosi, sclk, cs, rst, power_control |
nxpfan | 0:343c01965543 | 109 | * ... |
nxpfan | 0:343c01965543 | 110 | * .. |
nxpfan | 0:343c01965543 | 111 | * @endcode |
nxpfan | 0:343c01965543 | 112 | */ |
nxpfan | 0:343c01965543 | 113 | |
nxpfan | 0:343c01965543 | 114 | MARMEX_OB_oled( PinName mosi, PinName sclk, PinName cs, PinName rst, PinName power_pin ) : NokiaLCD( mosi, sclk, cs, rst, NokiaLCD::LCD6100 ), _power_pin( power_pin ) { |
nxpfan | 0:343c01965543 | 115 | power( ON ); |
nxpfan | 0:343c01965543 | 116 | reset(); |
nxpfan | 0:343c01965543 | 117 | } |
nxpfan | 0:343c01965543 | 118 | |
nxpfan | 0:343c01965543 | 119 | #if DOXYGEN_ONLY |
nxpfan | 0:343c01965543 | 120 | /** Write a character to the LCD |
nxpfan | 0:343c01965543 | 121 | * |
nxpfan | 0:343c01965543 | 122 | * @param c The character to write to the display |
nxpfan | 0:343c01965543 | 123 | */ |
nxpfan | 0:343c01965543 | 124 | int putc( int c ); |
nxpfan | 0:343c01965543 | 125 | |
nxpfan | 0:343c01965543 | 126 | /** Write a formated string to the LCD |
nxpfan | 0:343c01965543 | 127 | * |
nxpfan | 0:343c01965543 | 128 | * @param format A printf-style format string, followed by the |
nxpfan | 0:343c01965543 | 129 | * variables to use in formating the string. |
nxpfan | 0:343c01965543 | 130 | * |
nxpfan | 0:343c01965543 | 131 | * !!! 16th character in the string will be disappeared |
nxpfan | 0:343c01965543 | 132 | * !!! This problem is due to difference of screen size NokiaLCD library and its internal mechanism... |
nxpfan | 0:343c01965543 | 133 | */ |
nxpfan | 0:343c01965543 | 134 | int printf( const char* format, ... ); |
nxpfan | 0:343c01965543 | 135 | |
nxpfan | 0:343c01965543 | 136 | /** Set the foreground colour |
nxpfan | 0:343c01965543 | 137 | * |
nxpfan | 0:343c01965543 | 138 | * @param c 24-bit colour |
nxpfan | 0:343c01965543 | 139 | */ |
nxpfan | 0:343c01965543 | 140 | void foreground(int c); |
nxpfan | 0:343c01965543 | 141 | |
nxpfan | 0:343c01965543 | 142 | /** Set the background colour |
nxpfan | 0:343c01965543 | 143 | * |
nxpfan | 0:343c01965543 | 144 | * @param c 24-bit colour |
nxpfan | 0:343c01965543 | 145 | */ |
nxpfan | 0:343c01965543 | 146 | void background(int c); |
nxpfan | 0:343c01965543 | 147 | |
nxpfan | 0:343c01965543 | 148 | #endif |
nxpfan | 0:343c01965543 | 149 | |
nxpfan | 0:343c01965543 | 150 | /** reset MARMEX_OB_oled |
nxpfan | 0:343c01965543 | 151 | * |
nxpfan | 0:343c01965543 | 152 | * Executes hardware reset and initialize. |
nxpfan | 0:343c01965543 | 153 | * See MARMEX_OB_oled manual for the initialization sequence and values |
nxpfan | 0:343c01965543 | 154 | * For gamma correction table, using math function to make the code simple |
nxpfan | 0:343c01965543 | 155 | */ |
nxpfan | 0:343c01965543 | 156 | |
nxpfan | 0:343c01965543 | 157 | void reset( void ) { |
nxpfan | 0:343c01965543 | 158 | |
nxpfan | 0:343c01965543 | 159 | #define GAMMA_LUT_SIZE 63 |
nxpfan | 0:343c01965543 | 160 | unsigned char gamma_LUT[ GAMMA_LUT_SIZE ]; |
nxpfan | 0:343c01965543 | 161 | |
nxpfan | 0:343c01965543 | 162 | for ( int i = 0; i < GAMMA_LUT_SIZE; i++ ) |
nxpfan | 0:343c01965543 | 163 | gamma_LUT[ i ] = (unsigned char)(powf( ((float)i / 62.0), (1.0 / 0.58) ) * 178.0 + 2.0); |
nxpfan | 0:343c01965543 | 164 | |
nxpfan | 0:343c01965543 | 165 | // setup the SPI interface and bring display out of reset |
nxpfan | 0:343c01965543 | 166 | _cs = 1; |
nxpfan | 0:343c01965543 | 167 | _rst = 0; |
nxpfan | 0:343c01965543 | 168 | #ifdef MARMEX_OB_SPI_8BIT_MODE |
nxpfan | 0:343c01965543 | 169 | _spi.format( 8 ); |
nxpfan | 0:343c01965543 | 170 | #else |
nxpfan | 0:343c01965543 | 171 | _spi.format( 9 ); |
nxpfan | 0:343c01965543 | 172 | #endif |
nxpfan | 0:343c01965543 | 173 | |
nxpfan | 0:343c01965543 | 174 | _spi.frequency( SPI_FREQUENCY ); |
nxpfan | 0:343c01965543 | 175 | wait_ms( 1 ); |
nxpfan | 0:343c01965543 | 176 | _rst = 1; |
nxpfan | 0:343c01965543 | 177 | wait_ms( 1 ); |
nxpfan | 0:343c01965543 | 178 | |
nxpfan | 0:343c01965543 | 179 | _cs = 0; |
nxpfan | 0:343c01965543 | 180 | |
nxpfan | 0:343c01965543 | 181 | command( SET_DISPLAY_MODE_ALL_OFF ); |
nxpfan | 0:343c01965543 | 182 | command( SET_COMMAND_LOCK ); |
nxpfan | 0:343c01965543 | 183 | data( 0x12 ); |
nxpfan | 0:343c01965543 | 184 | |
nxpfan | 0:343c01965543 | 185 | command( SET_COMMAND_LOCK ); |
nxpfan | 0:343c01965543 | 186 | data( 0xb1 ); |
nxpfan | 0:343c01965543 | 187 | |
nxpfan | 0:343c01965543 | 188 | command( SET_SLEEP_MODE_ON ); |
nxpfan | 0:343c01965543 | 189 | |
nxpfan | 0:343c01965543 | 190 | command( FRONT_CLOCK_DRIVER_OSC_FREQ ); |
nxpfan | 0:343c01965543 | 191 | data( 0xF1 ); |
nxpfan | 0:343c01965543 | 192 | |
nxpfan | 0:343c01965543 | 193 | command( SET_MUX_RATIO ); |
nxpfan | 0:343c01965543 | 194 | data( 0x7F ); |
nxpfan | 0:343c01965543 | 195 | |
nxpfan | 0:343c01965543 | 196 | command( SET_DISPAY_OFFSET ); |
nxpfan | 0:343c01965543 | 197 | data( 0x00 ); |
nxpfan | 0:343c01965543 | 198 | |
nxpfan | 0:343c01965543 | 199 | command( SET_DISPAY_START_LINE ); |
nxpfan | 0:343c01965543 | 200 | data( 0x00 ); |
nxpfan | 0:343c01965543 | 201 | |
nxpfan | 0:343c01965543 | 202 | command( SET_REMAP_COLOR_DEPTH ); |
nxpfan | 0:343c01965543 | 203 | data( 0x74 ); |
nxpfan | 0:343c01965543 | 204 | |
nxpfan | 0:343c01965543 | 205 | command( SET_GPIO ); |
nxpfan | 0:343c01965543 | 206 | data( 0x00); |
nxpfan | 0:343c01965543 | 207 | |
nxpfan | 0:343c01965543 | 208 | command( FUNCTION_SELECTION ); |
nxpfan | 0:343c01965543 | 209 | data( 0x01 ); |
nxpfan | 0:343c01965543 | 210 | |
nxpfan | 0:343c01965543 | 211 | command( SET_SEGMENT_LOW_VOLTAGE ); |
nxpfan | 0:343c01965543 | 212 | data( 0xA0 ); |
nxpfan | 0:343c01965543 | 213 | data( 0xB5 ); |
nxpfan | 0:343c01965543 | 214 | data( 0x55 ); |
nxpfan | 0:343c01965543 | 215 | |
nxpfan | 0:343c01965543 | 216 | command( SET_CONTRAST_CURRENT_FOR_COLOR_ABC ); |
nxpfan | 0:343c01965543 | 217 | data( 0xC8 ); |
nxpfan | 0:343c01965543 | 218 | data( 0x80 ); |
nxpfan | 0:343c01965543 | 219 | data( 0xC8 ); |
nxpfan | 0:343c01965543 | 220 | |
nxpfan | 0:343c01965543 | 221 | command( MASTER_CONTRAST_CURRENT_CONTROL ); |
nxpfan | 0:343c01965543 | 222 | data( 0x0F ); |
nxpfan | 0:343c01965543 | 223 | |
nxpfan | 0:343c01965543 | 224 | command( LOOKUP_TABLE_FOR_GRAYSCALE_PULSE_WIDTH ); |
nxpfan | 0:343c01965543 | 225 | for ( int i = 0; i < GAMMA_LUT_SIZE; i++ ) |
nxpfan | 0:343c01965543 | 226 | data( gamma_LUT[ i ] ); |
nxpfan | 0:343c01965543 | 227 | |
nxpfan | 0:343c01965543 | 228 | command( SET_RESET_PRECHARGE_PERIOD ); |
nxpfan | 0:343c01965543 | 229 | data( 0x32 ); |
nxpfan | 0:343c01965543 | 230 | |
nxpfan | 0:343c01965543 | 231 | command( ENHANCE_DRIVING_SCHEME_CAPABILITY ); |
nxpfan | 0:343c01965543 | 232 | data( 0x04 ); |
nxpfan | 0:343c01965543 | 233 | data( 0x00 ); |
nxpfan | 0:343c01965543 | 234 | data( 0x00 ); |
nxpfan | 0:343c01965543 | 235 | |
nxpfan | 0:343c01965543 | 236 | command( SET_PRECHARGE_VOLTAGE ); |
nxpfan | 0:343c01965543 | 237 | data( 0x17 ); |
nxpfan | 0:343c01965543 | 238 | |
nxpfan | 0:343c01965543 | 239 | command( SET_SECOND_PRECHARGE_VOLTAGE ); |
nxpfan | 0:343c01965543 | 240 | data( 0x01 ); |
nxpfan | 0:343c01965543 | 241 | |
nxpfan | 0:343c01965543 | 242 | command( SET_VCOMH_VOLTAGE ); |
nxpfan | 0:343c01965543 | 243 | data( 0x05 ); |
nxpfan | 0:343c01965543 | 244 | |
nxpfan | 0:343c01965543 | 245 | command( SET_DISPLAY_MODE_RESET ); |
nxpfan | 0:343c01965543 | 246 | |
nxpfan | 0:343c01965543 | 247 | #if 0 |
nxpfan | 0:343c01965543 | 248 | command( SET_COLUMN_ADDRESS ); |
nxpfan | 0:343c01965543 | 249 | data( 0x00 ); |
nxpfan | 0:343c01965543 | 250 | data( 0x7F ); |
nxpfan | 0:343c01965543 | 251 | |
nxpfan | 0:343c01965543 | 252 | command( SET_ROW_ADDRESS ); |
nxpfan | 0:343c01965543 | 253 | data( 0x00 ); |
nxpfan | 0:343c01965543 | 254 | data( 0x7F); |
nxpfan | 0:343c01965543 | 255 | |
nxpfan | 0:343c01965543 | 256 | command( WRITE_RAM_COMMAND ); |
nxpfan | 0:343c01965543 | 257 | for ( int i = 0; i < WIDTH * HEIGHT; i++ ) |
nxpfan | 0:343c01965543 | 258 | data( 0x00 ); |
nxpfan | 0:343c01965543 | 259 | #endif |
nxpfan | 0:343c01965543 | 260 | _cs = 1; |
nxpfan | 0:343c01965543 | 261 | |
nxpfan | 0:343c01965543 | 262 | cls(); |
nxpfan | 0:343c01965543 | 263 | wait_ms( 200 ); |
nxpfan | 0:343c01965543 | 264 | |
nxpfan | 0:343c01965543 | 265 | command( SET_SLEEP_MODE_OFF ); |
nxpfan | 0:343c01965543 | 266 | } |
nxpfan | 0:343c01965543 | 267 | |
nxpfan | 0:343c01965543 | 268 | /** Clear the screen and locate to 0,0 */ |
nxpfan | 0:343c01965543 | 269 | |
nxpfan | 0:343c01965543 | 270 | void cls( void ) { |
nxpfan | 0:343c01965543 | 271 | fill( 0, 0, WIDTH , HEIGHT, _background ); |
nxpfan | 0:343c01965543 | 272 | _row = 0; |
nxpfan | 0:343c01965543 | 273 | _column = 0; |
nxpfan | 0:343c01965543 | 274 | } |
nxpfan | 0:343c01965543 | 275 | |
nxpfan | 0:343c01965543 | 276 | /** Set a pixel on te screen |
nxpfan | 0:343c01965543 | 277 | * |
nxpfan | 0:343c01965543 | 278 | * @param x horizontal position from left |
nxpfan | 0:343c01965543 | 279 | * @param y vertical position from top |
nxpfan | 0:343c01965543 | 280 | * @param colour 24-bit colour in format 0x00RRGGBB |
nxpfan | 0:343c01965543 | 281 | */ |
nxpfan | 0:343c01965543 | 282 | |
nxpfan | 0:343c01965543 | 283 | virtual void pixel( int x, int y, int colour ) { |
nxpfan | 0:343c01965543 | 284 | _cs = 0; |
nxpfan | 0:343c01965543 | 285 | _window( x, y, 1, 1 ); |
nxpfan | 0:343c01965543 | 286 | _putp( colour ); |
nxpfan | 0:343c01965543 | 287 | _cs = 1; |
nxpfan | 0:343c01965543 | 288 | } |
nxpfan | 0:343c01965543 | 289 | |
nxpfan | 0:343c01965543 | 290 | /** Fill an area of the screen |
nxpfan | 0:343c01965543 | 291 | * |
nxpfan | 0:343c01965543 | 292 | * @param x horizontal position from left |
nxpfan | 0:343c01965543 | 293 | * @param y vertical position from top |
nxpfan | 0:343c01965543 | 294 | * @param width width in pixels |
nxpfan | 0:343c01965543 | 295 | * @param height height in pixels |
nxpfan | 0:343c01965543 | 296 | * @param colour 24-bit colour in format 0x00RRGGBB |
nxpfan | 0:343c01965543 | 297 | */ |
nxpfan | 0:343c01965543 | 298 | |
nxpfan | 0:343c01965543 | 299 | void fill( int x, int y, int width, int height, int colour ) { |
nxpfan | 0:343c01965543 | 300 | _cs = 0; |
nxpfan | 0:343c01965543 | 301 | _window( x, y, width, height ); |
nxpfan | 0:343c01965543 | 302 | |
nxpfan | 0:343c01965543 | 303 | for (int i = 0; i < width * height; i++ ) { |
nxpfan | 0:343c01965543 | 304 | _putp( colour ); |
nxpfan | 0:343c01965543 | 305 | } |
nxpfan | 0:343c01965543 | 306 | |
nxpfan | 0:343c01965543 | 307 | _window( 0, 0, WIDTH, HEIGHT ); |
nxpfan | 0:343c01965543 | 308 | _cs = 1; |
nxpfan | 0:343c01965543 | 309 | } |
nxpfan | 0:343c01965543 | 310 | |
nxpfan | 0:343c01965543 | 311 | void blit( int x, int y, int width, int height, const int* colour ) { |
nxpfan | 0:343c01965543 | 312 | _cs = 0; |
nxpfan | 0:343c01965543 | 313 | _window( x, y, width, height ); |
nxpfan | 0:343c01965543 | 314 | |
nxpfan | 0:343c01965543 | 315 | for (int i = 0; i < width * height; i++ ) { |
nxpfan | 0:343c01965543 | 316 | _putp( colour[i] ); |
nxpfan | 0:343c01965543 | 317 | } |
nxpfan | 0:343c01965543 | 318 | _window( 0, 0, WIDTH, HEIGHT ); |
nxpfan | 0:343c01965543 | 319 | _cs = 1; |
nxpfan | 0:343c01965543 | 320 | } |
nxpfan | 0:343c01965543 | 321 | |
nxpfan | 1:dbe2dc31542d | 322 | void blit565( int x, int y, int width, int height, short* colour ) { |
nxpfan | 0:343c01965543 | 323 | _cs = 0; |
nxpfan | 0:343c01965543 | 324 | _window( x, y, width, height ); |
nxpfan | 0:343c01965543 | 325 | |
nxpfan | 1:dbe2dc31542d | 326 | #define OPTIMIZE_BY_GPIO_REGISTER_ACCESS |
nxpfan | 1:dbe2dc31542d | 327 | #if defined( TARGET_MBED_LPC1768 ) && defined (OPTIMIZE_BY_GPIO_REGISTER_ACCESS ) |
nxpfan | 1:dbe2dc31542d | 328 | LPC_GPIO1->FIOMASK = ~0x80000000; |
nxpfan | 1:dbe2dc31542d | 329 | |
nxpfan | 1:dbe2dc31542d | 330 | for (int i = 0; i < width * height; i += 8 ) { |
nxpfan | 1:dbe2dc31542d | 331 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 332 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 333 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 334 | |
nxpfan | 1:dbe2dc31542d | 335 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 336 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 337 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 338 | |
nxpfan | 1:dbe2dc31542d | 339 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 340 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 341 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 342 | |
nxpfan | 1:dbe2dc31542d | 343 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 344 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 345 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 346 | |
nxpfan | 1:dbe2dc31542d | 347 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 348 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 349 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 350 | |
nxpfan | 1:dbe2dc31542d | 351 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 352 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 353 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 354 | |
nxpfan | 1:dbe2dc31542d | 355 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 356 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 357 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 358 | |
nxpfan | 1:dbe2dc31542d | 359 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 360 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 361 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 362 | |
nxpfan | 1:dbe2dc31542d | 363 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 364 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 365 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 366 | |
nxpfan | 1:dbe2dc31542d | 367 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 368 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 369 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 370 | |
nxpfan | 1:dbe2dc31542d | 371 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 372 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 373 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 374 | |
nxpfan | 1:dbe2dc31542d | 375 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 376 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 377 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 378 | |
nxpfan | 1:dbe2dc31542d | 379 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 380 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 381 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 382 | |
nxpfan | 1:dbe2dc31542d | 383 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 384 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 385 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 386 | |
nxpfan | 1:dbe2dc31542d | 387 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 388 | _spi.write( 0x100 | (*colour >> 8) ); |
nxpfan | 1:dbe2dc31542d | 389 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 390 | |
nxpfan | 1:dbe2dc31542d | 391 | LPC_GPIO1->FIOCLR = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 392 | _spi.write( 0x100 | *colour++ ); |
nxpfan | 1:dbe2dc31542d | 393 | LPC_GPIO1->FIOSET = 0x80000000; |
nxpfan | 1:dbe2dc31542d | 394 | } |
nxpfan | 1:dbe2dc31542d | 395 | #else |
nxpfan | 0:343c01965543 | 396 | for (int i = 0; i < width * height; i++ ) { |
nxpfan | 0:343c01965543 | 397 | _putp565( colour[i] ); |
nxpfan | 0:343c01965543 | 398 | } |
nxpfan | 1:dbe2dc31542d | 399 | #endif |
nxpfan | 1:dbe2dc31542d | 400 | |
nxpfan | 0:343c01965543 | 401 | _window( 0, 0, WIDTH, HEIGHT ); |
nxpfan | 0:343c01965543 | 402 | _cs = 1; |
nxpfan | 0:343c01965543 | 403 | } |
nxpfan | 0:343c01965543 | 404 | void bitblit( int x, int y, int width, int height, const char* bitstream ) { |
nxpfan | 0:343c01965543 | 405 | _cs = 0; |
nxpfan | 0:343c01965543 | 406 | _window( x, y, width, height ); |
nxpfan | 0:343c01965543 | 407 | |
nxpfan | 0:343c01965543 | 408 | for (int i = 0; i < height * width; i++ ) { |
nxpfan | 0:343c01965543 | 409 | int byte = i / 8; |
nxpfan | 0:343c01965543 | 410 | int bit = i % 8; |
nxpfan | 0:343c01965543 | 411 | int colour = ((bitstream[ byte ] << bit) & 0x80) ? _foreground : _background; |
nxpfan | 0:343c01965543 | 412 | _putp( colour ); |
nxpfan | 0:343c01965543 | 413 | } |
nxpfan | 0:343c01965543 | 414 | _window( 0, 0, _width, _height ); |
nxpfan | 0:343c01965543 | 415 | _cs = 1; |
nxpfan | 0:343c01965543 | 416 | } |
nxpfan | 0:343c01965543 | 417 | |
nxpfan | 0:343c01965543 | 418 | /** Screen width |
nxpfan | 0:343c01965543 | 419 | * |
nxpfan | 0:343c01965543 | 420 | * @return screen width [pixel] |
nxpfan | 0:343c01965543 | 421 | */ |
nxpfan | 0:343c01965543 | 422 | int width() { |
nxpfan | 0:343c01965543 | 423 | return WIDTH; |
nxpfan | 0:343c01965543 | 424 | } |
nxpfan | 0:343c01965543 | 425 | |
nxpfan | 0:343c01965543 | 426 | /** Screen height |
nxpfan | 0:343c01965543 | 427 | * |
nxpfan | 0:343c01965543 | 428 | * @return screen height [pixel] |
nxpfan | 0:343c01965543 | 429 | */ |
nxpfan | 0:343c01965543 | 430 | int height() { |
nxpfan | 0:343c01965543 | 431 | return HEIGHT; |
nxpfan | 0:343c01965543 | 432 | } |
nxpfan | 0:343c01965543 | 433 | /** Columns |
nxpfan | 0:343c01965543 | 434 | * |
nxpfan | 0:343c01965543 | 435 | * @return screen columns |
nxpfan | 0:343c01965543 | 436 | */ |
nxpfan | 0:343c01965543 | 437 | int columns() { |
nxpfan | 0:343c01965543 | 438 | return COLS; |
nxpfan | 0:343c01965543 | 439 | } |
nxpfan | 0:343c01965543 | 440 | |
nxpfan | 0:343c01965543 | 441 | /** Rows |
nxpfan | 0:343c01965543 | 442 | * |
nxpfan | 0:343c01965543 | 443 | * @return screen rows |
nxpfan | 0:343c01965543 | 444 | */ |
nxpfan | 0:343c01965543 | 445 | int rows() { |
nxpfan | 0:343c01965543 | 446 | return ROWS; |
nxpfan | 0:343c01965543 | 447 | } |
nxpfan | 0:343c01965543 | 448 | |
nxpfan | 0:343c01965543 | 449 | /** Power switch for OLED backlight |
nxpfan | 0:343c01965543 | 450 | * |
nxpfan | 0:343c01965543 | 451 | * @param sw argument can be MARMEX_OB_oled::ON or MARMEX_OB_oled::OFF |
nxpfan | 0:343c01965543 | 452 | */ |
nxpfan | 0:343c01965543 | 453 | |
nxpfan | 0:343c01965543 | 454 | void power( unsigned char sw ) { |
nxpfan | 0:343c01965543 | 455 | _power_pin = sw; |
nxpfan | 0:343c01965543 | 456 | } |
nxpfan | 0:343c01965543 | 457 | |
nxpfan | 0:343c01965543 | 458 | private: |
nxpfan | 0:343c01965543 | 459 | /** Command list for the OLED controller */ |
nxpfan | 0:343c01965543 | 460 | enum { |
nxpfan | 0:343c01965543 | 461 | SET_DISPLAY_MODE_ALL_OFF = 0xA4, |
nxpfan | 0:343c01965543 | 462 | SET_COMMAND_LOCK = 0xFD, |
nxpfan | 0:343c01965543 | 463 | SET_SLEEP_MODE_ON = 0xAE, |
nxpfan | 0:343c01965543 | 464 | FRONT_CLOCK_DRIVER_OSC_FREQ = 0xB3, |
nxpfan | 0:343c01965543 | 465 | SET_MUX_RATIO = 0xCA, |
nxpfan | 0:343c01965543 | 466 | SET_DISPAY_OFFSET = 0xA2, |
nxpfan | 0:343c01965543 | 467 | SET_DISPAY_START_LINE = 0xA1, |
nxpfan | 0:343c01965543 | 468 | SET_REMAP_COLOR_DEPTH = 0xA0, |
nxpfan | 0:343c01965543 | 469 | SET_GPIO = 0xB5, |
nxpfan | 0:343c01965543 | 470 | FUNCTION_SELECTION = 0xAB, |
nxpfan | 0:343c01965543 | 471 | SET_SEGMENT_LOW_VOLTAGE = 0xB4, |
nxpfan | 0:343c01965543 | 472 | SET_CONTRAST_CURRENT_FOR_COLOR_ABC = 0xC1, |
nxpfan | 0:343c01965543 | 473 | MASTER_CONTRAST_CURRENT_CONTROL = 0xC7, |
nxpfan | 0:343c01965543 | 474 | LOOKUP_TABLE_FOR_GRAYSCALE_PULSE_WIDTH = 0xB8, |
nxpfan | 0:343c01965543 | 475 | SET_RESET_PRECHARGE_PERIOD = 0xB1, |
nxpfan | 0:343c01965543 | 476 | ENHANCE_DRIVING_SCHEME_CAPABILITY = 0xB2, |
nxpfan | 0:343c01965543 | 477 | SET_PRECHARGE_VOLTAGE = 0xBB, |
nxpfan | 0:343c01965543 | 478 | SET_SECOND_PRECHARGE_VOLTAGE = 0xB6, |
nxpfan | 0:343c01965543 | 479 | SET_VCOMH_VOLTAGE = 0xBE, |
nxpfan | 0:343c01965543 | 480 | SET_DISPLAY_MODE_RESET = 0xA6, |
nxpfan | 0:343c01965543 | 481 | SET_COLUMN_ADDRESS = 0x15, |
nxpfan | 0:343c01965543 | 482 | SET_ROW_ADDRESS = 0x75, |
nxpfan | 0:343c01965543 | 483 | WRITE_RAM_COMMAND = 0x5C, |
nxpfan | 0:343c01965543 | 484 | SET_SLEEP_MODE_OFF = 0xAF |
nxpfan | 0:343c01965543 | 485 | }; |
nxpfan | 0:343c01965543 | 486 | |
nxpfan | 0:343c01965543 | 487 | #ifdef MARMEX_OB_SPI_8BIT_MODE |
nxpfan | 0:343c01965543 | 488 | void command( int value ) { |
nxpfan | 0:343c01965543 | 489 | int tmp = value & 0x00ff; |
nxpfan | 0:343c01965543 | 490 | _cs = 0; |
nxpfan | 0:343c01965543 | 491 | _spi.write( tmp >> 1 ); |
nxpfan | 0:343c01965543 | 492 | _spi.write( tmp << 7 ); |
nxpfan | 0:343c01965543 | 493 | _cs = 1; |
nxpfan | 0:343c01965543 | 494 | } |
nxpfan | 0:343c01965543 | 495 | |
nxpfan | 0:343c01965543 | 496 | void data( int value ) { |
nxpfan | 0:343c01965543 | 497 | int tmp = value & 0x00ff; |
nxpfan | 0:343c01965543 | 498 | tmp |= 0x0100; |
nxpfan | 0:343c01965543 | 499 | _cs = 0; |
nxpfan | 0:343c01965543 | 500 | _spi.write( tmp >> 1 ); |
nxpfan | 0:343c01965543 | 501 | _spi.write( tmp << 7 ); |
nxpfan | 0:343c01965543 | 502 | _cs = 1; |
nxpfan | 0:343c01965543 | 503 | } |
nxpfan | 0:343c01965543 | 504 | #else |
nxpfan | 0:343c01965543 | 505 | void command( int value ) { |
nxpfan | 0:343c01965543 | 506 | _cs = 0; |
nxpfan | 0:343c01965543 | 507 | _spi.write( value & 0xFF ); |
nxpfan | 0:343c01965543 | 508 | _cs = 1; |
nxpfan | 0:343c01965543 | 509 | } |
nxpfan | 0:343c01965543 | 510 | |
nxpfan | 0:343c01965543 | 511 | void data(int value) { |
nxpfan | 0:343c01965543 | 512 | _cs = 0; |
nxpfan | 0:343c01965543 | 513 | _spi.write( value | 0x100 ); |
nxpfan | 0:343c01965543 | 514 | _cs = 1; |
nxpfan | 0:343c01965543 | 515 | } |
nxpfan | 0:343c01965543 | 516 | #endif |
nxpfan | 0:343c01965543 | 517 | |
nxpfan | 0:343c01965543 | 518 | virtual void _window( int x, int y, int width, int height ) { |
nxpfan | 0:343c01965543 | 519 | int x1 = x + 0; |
nxpfan | 0:343c01965543 | 520 | int y1 = y + 0; |
nxpfan | 0:343c01965543 | 521 | int x2 = x1 + width - 1; |
nxpfan | 0:343c01965543 | 522 | int y2 = y1 + height - 1; |
nxpfan | 0:343c01965543 | 523 | |
nxpfan | 0:343c01965543 | 524 | command( SET_COLUMN_ADDRESS ); |
nxpfan | 0:343c01965543 | 525 | data( x1 ); |
nxpfan | 0:343c01965543 | 526 | data( x2 ); |
nxpfan | 0:343c01965543 | 527 | command( SET_ROW_ADDRESS ); |
nxpfan | 0:343c01965543 | 528 | data( y1 ); |
nxpfan | 0:343c01965543 | 529 | data( y2 ); |
nxpfan | 0:343c01965543 | 530 | command( WRITE_RAM_COMMAND ); |
nxpfan | 0:343c01965543 | 531 | } |
nxpfan | 0:343c01965543 | 532 | |
nxpfan | 0:343c01965543 | 533 | void window( int x, int y, int width, int height ) { |
nxpfan | 0:343c01965543 | 534 | _cs = 0; |
nxpfan | 0:343c01965543 | 535 | _window( x, y, width, height ); |
nxpfan | 0:343c01965543 | 536 | _cs = 1; |
nxpfan | 0:343c01965543 | 537 | } |
nxpfan | 0:343c01965543 | 538 | |
nxpfan | 0:343c01965543 | 539 | virtual void _putp( int colour ) { |
nxpfan | 0:343c01965543 | 540 | int cnv = 0; |
nxpfan | 0:343c01965543 | 541 | |
nxpfan | 0:343c01965543 | 542 | cnv = (colour >> 8) & 0xf800; |
nxpfan | 0:343c01965543 | 543 | cnv |= (colour >> 5) & 0x07e0; |
nxpfan | 0:343c01965543 | 544 | cnv |= (colour >> 3) & 0x001f; |
nxpfan | 0:343c01965543 | 545 | |
nxpfan | 0:343c01965543 | 546 | data( cnv >> 8); |
nxpfan | 0:343c01965543 | 547 | data( cnv ); |
nxpfan | 0:343c01965543 | 548 | } |
nxpfan | 0:343c01965543 | 549 | virtual void _putp565( short colour ) { |
nxpfan | 0:343c01965543 | 550 | data( colour >> 8); |
nxpfan | 0:343c01965543 | 551 | data( colour ); |
nxpfan | 0:343c01965543 | 552 | } |
nxpfan | 0:343c01965543 | 553 | |
nxpfan | 0:343c01965543 | 554 | DigitalOut _power_pin; |
nxpfan | 0:343c01965543 | 555 | } |
nxpfan | 0:343c01965543 | 556 | ; |
nxpfan | 0:343c01965543 | 557 | |
nxpfan | 0:343c01965543 | 558 | #ifdef MARMEX_OB_SPI_8BIT_MODE |
nxpfan | 0:343c01965543 | 559 | #define MERMEX_OB_SPI_MODE_STR "8bit mode" |
nxpfan | 0:343c01965543 | 560 | #else |
nxpfan | 0:343c01965543 | 561 | #define MERMEX_OB_SPI_MODE_STR "9bit mode" |
nxpfan | 0:343c01965543 | 562 | #endif |
nxpfan | 0:343c01965543 | 563 | #endif // MBED_MARMEX_OB_OLED |
nxpfan | 0:343c01965543 | 564 | |
nxpfan | 0:343c01965543 | 565 | |
nxpfan | 0:343c01965543 | 566 | |
nxpfan | 0:343c01965543 | 567 | |
nxpfan | 0:343c01965543 | 568 |