MARMEX_OB_oled with Japanese font

Dependencies:   NokiaLCD

Dependents:   MARMEX_OB_oled_J_Helloworld mbed_strscroll

Committer:
diasea
Date:
Fri Feb 01 11:50:26 2013 +0000
Revision:
0:9adb08a2910c
Child:
1:1106831b0509
first release

Who changed what in which revision?

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