Demonstration of SSD1308 OLED driver library
Dependencies: mbed SSD1308_128x64_I2C
Diff: SSD1308.h
- Revision:
- 0:2ded56b8407d
- Child:
- 1:00053cb70ac5
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/SSD1308.h Tue Jun 19 20:00:10 2012 +0000 @@ -0,0 +1,242 @@ +// I2Cdev library collection - SSD1308 I2C device class header file +// Based on Solomon Systech SSD1308 datasheet, rev. 1, 10/2008 +// 8/25/2011 by Andrew Schamp <schamp@gmail.com> +// 19/06/2012 Ported to mbed (WH) +// +// This I2C device library is using (and submitted as a part of) Jeff Rowberg's I2Cdevlib library, +// which should (hopefully) always be available at https://github.com/jrowberg/i2cdevlib +// Note WH: I2Cdevlib not used for mbed port +// +// Changelog: +// 2011-08-25 - initial release +// 2012-06-19 - Ported to mbed (WH) + +/* ============================================ +I2Cdev device library code is placed under the MIT license +Copyright (c) 2011 Andrew Schamp +Copyright (c) 2012 WH (mbed port) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +=============================================== +*/ + +#ifndef SSD1308_H +#define SSD1308_H + +// This is the I2C address (8 bit) +// which one is used is determined by the D/C# pin. +// with D/C# (pin 13) grounded, address is 0x78 +// with D/C# tied high it is 0x7A +// assume grounded by default. +#define SSD1308_SA0 0x78 +#define SSD1308_SA1 0x7A +#define SSD1308_DEF_SA SSD1308_SA0 + +#define ROWS 64 +#define COLUMNS 128 +#define PAGES 8 +#define PAGE_WIDTH (ROWS / 8) +#define FONT_WIDTH 8 +#define CHARS (COLUMNS / FONT_WIDTH) +#define MAX_PAGE (PAGES - 1) +#define MAX_COL (COLUMNS - 1) + +#define HORIZONTAL_ADDRESSING_MODE 0x00 +#define VERTICAL_ADDRESSING_MODE 0x01 +#define PAGE_ADDRESSING_MODE 0x02 + +#define SET_MEMORY_ADDRESSING_MODE 0x20 // takes one byte + +#define SET_COLUMN_ADDRESS 0x21 // takes two bytes, start address and end address of display data RAM +#define SET_PAGE_ADDRESS 0x22 // takes two bytes, start address and end address of display data RAM + +#define SET_CONTRAST 0x81 // takes one byte, 0x00 - 0xFF + +#define SET_SEGMENT_REMAP_0 0xA0 // column address 0 is mapped to SEG0 +#define SET_SEGMENT_REMAP_127 0xA1 // column address 127 is mapped to SEG0 + +#define SET_ENTIRE_DISPLAY_ON 0xA5 // turns all pixels on, does not affect RAM +#define SET_DISPLAY_GDDRAM 0xA4 // restores display to contents of RAM + +#define SET_NORMAL_DISPLAY 0xA6 // a data of 1 indicates 'ON' +#define SET_INVERSE_DISPLAY 0xA7 // a data of 0 indicates 'ON' + +#define SET_MULTIPLEX_RATIO 0xA8 // takes one byte, from 16 to 63 (0x + +#define EXTERNAL_IREF 0x10 +#define INTERNAL_IREF 0x00 +#define SET_IREF_SELECTION 0xAD // sets internal or external Iref + +#define SET_DISPLAY_POWER_OFF 0xAE +#define SET_DISPLAY_POWER_ON 0xAF + +#define COMMAND_MODE 0x80 +#define DATA_MODE 0x40 + +#define PAGE0 0x00 +#define PAGE1 0x01 +#define PAGE2 0x02 +#define PAGE3 0x03 +#define PAGE4 0x04 +#define PAGE5 0x05 +#define PAGE6 0x06 +#define PAGE7 0x07 +#define SET_PAGE_START_ADDRESS 0xB0 // | with a page number to get start address + +#define SET_DISPLAY_OFFSET 0xD3 + +#define SET_DISPLAY_CLOCK 0xD5 + +#define VCOMH_DESELECT_0_65_CODE 0x00 +#define VCOMH_DESELECT_0_77_CODE 0x20 +#define VCOMH_DESELECT_0_83_CODE 0x30 +#define SET_VCOMH_DESELECT_LEVEL 0xDB + +#define NOP 0xE3 + +#define SET_RIGHT_HORIZONTAL_SCROLL 0x26 +#define SET_LEFT_HORIZONTAL_SCROLL 0x27 +#define SET_VERTICAL_RIGHT_HORIZONTAL_SCROLL 0x29 +#define SET_VERTICAL_LEFT_HORIZONTAL_SCROLL 0x2A + +#define SET_DEACTIVATE_SCROLL 0x2E +#define SET_ACTIVATE_SCROLL 0x2F + +#define SET_VERTICAL_SCROLL_AREA 0xA3 + +class SSD1308 { + public: + + // constructor + // takes a 8bit I2C address to use (0x78 by default, assumes D/C# (pin 13) grounded) + SSD1308(I2C &i2c, uint8_t address = SSD1308_DEF_SA); + + void initialize(); + void clearDisplay(); + void fillDisplay(); // crosshatches + + // x, y is position (x is row (i.e., page), y is character (0-15), starting at top-left) + // text will wrap around until it is done. + void writeString(uint8_t row, uint8_t col, uint16_t len, const char* txt); + + //void setXY(uint8_t, uint8_t y); + + void setHorizontalAddressingMode(); + void setVerticalAddressingMode(); + void setPageAddressingMode(); + + void setMemoryAddressingMode(uint8_t mode); + + // takes one byte, 0x00-0x0F + void setLowerColumnStartAddressForPageAddressingMode(uint8_t address); + + // takes one byte, 0x10-0x1F + void setHigherColumnStartAddressForPageAddressingMode(uint8_t address); + + // takes two bytes, start address and end address of display data RAM + void setColumnAddress(uint8_t start, uint8_t end); + + // takes two bytes, start address and end address of display data RAM + void setPageAddress(uint8_t start, uint8_t end); + + // takes one byte, PAGE0 - PAGE7 + void setPageStartForPageAddressingMode(uint8_t page); + + // takes one byte, 0x40-0x7F + void setDisplayStartLine(uint8_t line); + + // takes one byte, 0x00 (lowest) - 0xFF (highest) + void setContrastControl(uint8_t contrast); + + void setEntireDisplayOn(); + void setEntireDisplayRAM(); + void setEntireDisplay(bool on); + void setNormalDisplay(); + void setInverseDisplay(); + + // setMultiplexRatio + + void setInternalIref(); + void setExternalIref(); + + void setDisplayOn(); + void setDisplayOff(); + void setDisplayPower(bool on); + + // Set vertical shift by COM from 0 - 63 (0x00 - 0x3F) + // set to 0x00 after RESET + void setDisplayOffset(uint8_t offset); + + // divide ratio 0x00-0x0F, value +1 (reset 0x00) + // oscillator freq 0x00-0x0F (reset 0x08) + void setDisplayClock(uint8_t divideRatio, uint8_t oscFreq); + + // phase1 0x01-0x0F period of up to 15 DCLK clocks (reset 0x02, 0 is invalid) + // phase2 0x01-0x0F period of up to 15 DCLK clocks (reset 0x02, 0 is invalid) + void setPrechargePeriod(uint8_t phase1, uint8_t phase2); + + #define VCOM_DESELECT_0_65 0x00 + #define VCOM_DESELECT_0_77 0x02 + #define VCOM_DESELECT_0_83 0x03 + void setVcomhDeselectLevel(uint8_t level); + + // command for no-operation + void nop(); + + #define SCROLL_INTERVAL_5_FRAMES 0x00 + #define SCROLL_INTERVAL_64_FRAMES 0x01 + #define SCROLL_INTERVAL_128_FRAMES 0x02 + #define SCROLL_INTERVAL_256_FRAMES 0x03 + #define SCROLL_INTERVAL_3_FRAMES 0x04 + #define SCROLL_INTERVAL_4_FRAMES 0x05 + #define SCROLL_INTERVAL_25_FRAMES 0x06 + #define SCROLL_INTERVAL_2_FRAMES 0x07 + // end_page must not be less than start_page + void setContinuousHorizontalScroll(bool left, uint8_t start_page, uint8_t interval, uint8_t end_page); + // horizontal scroll by one column per interval + // offset = 1 (0x01) to 63 (0x3F) + void setContinuousVerticalAndHorizontalScroll(bool left, uint8_t start_page, uint8_t interval, uint8_t end_page, uint8_t offset); + + // note, after deactivating scrolling, the RAM data needs to be rewritten + void deactivateScroll(); + void activateScroll(); + + void setVerticalScrollArea(uint8_t topRowsFixed, uint8_t scrollRows); + + void sendData(uint8_t data); + void sendData(uint8_t len, uint8_t* data); + // write the configuration registers in accordance with the datasheet and app note 3944 +// void initialize(); + + + private: + // sends a single-byte command (given) to device + void sendCommand(uint8_t command); + void sendCommands(uint8_t len, uint8_t* buf); + + void writeChar(char chr); + + I2C _i2c; // I2C bus +// uint8_t m_devAddr; // contains the I2C address of the device + uint8_t _readOpcode; + uint8_t _writeOpcode; + +}; + +#endif