An mbed library for 4D Systems uOLED-160-G1

Fork of OLED160G1 by Steven Blair

Revision:
0:296a7ee30b3a
diff -r 000000000000 -r 296a7ee30b3a OLED160G1.cpp
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/OLED160G1.cpp	Sun Dec 19 16:42:32 2010 +0000
@@ -0,0 +1,281 @@
+/**
+ * mbed library for 4D Systems uOLED-160-G1
+ *
+ *
+ * Copyright (c) 2010 Steven Blair
+ *
+ * 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.
+ */
+
+#include "mbed.h"
+#include "OLED160G1.h"
+
+
+OLED160G1::OLED160G1(PinName serialTx, PinName serialRx, PinName resetPin) : s(serialTx, serialRx), reset(resetPin) {
+    s.baud(OLED_BAUDRATE);
+    
+    while (s.readable()) {
+        s.getc();
+    }
+    
+    locate(0, 0);
+    setFontColor(0xFFFF);
+    _fontSize = OLED_FONT5X7;
+}
+
+void OLED160G1::resetDisplay() {
+    reset = 0;
+    wait_ms(200);
+    reset = 1;
+    wait_ms(200);
+}
+
+void OLED160G1::getResponse() {
+    char response = OLED_NAK;
+    lastCount = 0;
+    NAKCount = 0;
+    
+    while (!s.readable() || response == OLED_NAK) {
+        wait_ms(1);
+        lastCount++;
+        if (s.readable()) {
+            response = s.getc();    // Read response
+            if (response == OLED_ACK) {
+                return;
+            }
+            else if (response == OLED_NAK) {
+                NAKCount++;
+            }
+        }
+    }
+}
+
+// Initialise OLED display. You must first activate serial comunication!
+void OLED160G1::init() {
+    resetDisplay();
+
+    wait_ms(OLED_INIT_DELAY);       // wait for initialisation
+
+    s.putc(OLED_DETECT_BAUDRATE);   // send byte for OLED to autodetect baudrate
+    
+    getResponse();
+}
+
+int OLED160G1::toRGB(int red, int green, int blue) {
+    int outR = ((red * 31) / 255);
+    int outG = ((green * 63) / 255);
+    int outB = ((blue * 31) / 255);
+
+    return (outR << 11) | (outG << 5) | outB;
+}
+
+void OLED160G1::eraseScreen() {
+    s.putc(OLED_CLEAR);
+    
+    wait(1);    // TODO: why needed?
+    
+    getResponse();
+    
+    _row = 0;
+    _column = 0;
+}
+
+void OLED160G1::drawPixel(char x, char y, int color) {
+    s.putc(OLED_PUTPIXEL);
+    s.putc(x);
+    s.putc(y);
+
+    s.putc(color >> 8);     // MSB
+    s.putc(color & 0xFF);   // LSB
+
+    getResponse();
+}
+
+void OLED160G1::drawLine(char x1, char y1, char x2, char y2, int color) {
+    s.putc(OLED_LINE);      // Line
+
+    s.putc(x1);
+    s.putc(y1);
+    s.putc(x2);
+    s.putc(y2);
+
+    s.putc(color >> 8);      // MSB          
+    s.putc(color & 0xFF);    // LSB
+
+    getResponse();
+}
+
+void OLED160G1::drawRectangle(char x, char y, char width, char height, int color) {
+    s.putc(OLED_RECTANGLE); 
+
+    s.putc(x);
+    s.putc(y);
+
+    s.putc(x+width);
+    s.putc(y+height);
+
+    s.putc(color >> 8);      // MSB          
+    s.putc(color & 0xFF);    // LSB
+    
+    //
+   // if (filled == 1) { printByte(0x01); }   // Filled
+    //else { printByte(0x00); }               // Outline
+    //
+    getResponse();
+}
+
+void OLED160G1::drawCircle(char x, char y, char radius, int color) {
+    s.putc(OLED_CIRCLE); 
+
+    s.putc(x);
+    s.putc(y);
+    s.putc(radius);
+
+    s.putc(color >> 8);     // MSB          
+    s.putc(color & 0xFF);   // LSB
+
+    getResponse();
+}
+
+void OLED160G1::setFontSize(char fontSize) {
+    s.putc(OLED_SETFONTSIZE);
+    s.putc(fontSize);
+    _fontSize = fontSize;
+    
+    getResponse();
+}
+
+void OLED160G1::setFontColor(int fontColor) {
+    _fontColor = fontColor;
+}
+
+void OLED160G1::setPenSize(char penSize) {
+    s.putc(OLED_PEN_SIZE);
+    
+    s.putc(penSize);
+    
+    _penSize = penSize;
+    
+    getResponse();
+}
+
+void OLED160G1::setTextBackgroundType(char textBackgroundType) {
+    s.putc(OLED_SET_TEXT_BACKGROUND_TYPE);
+    s.putc(textBackgroundType);
+    
+    getResponse();
+}
+
+void OLED160G1::setBackgroundColor(int color) {
+    s.putc(OLED_SET_BACKGROUND_COLOR);
+    
+    s.putc(color >> 8);      // MSB          
+    s.putc(color & 0xFF);    // LSB
+    
+    getResponse();
+}
+
+void OLED160G1::drawText(char column, char row, char font_size, char *mytext, int color) {
+    s.putc(OLED_TEXT);
+    
+    // Adjust to center of the screen (26 Columns at font size 0)
+    //int newCol = 13 - (strlen(mytext)/2);
+    //printByte(newCol); // column
+    s.putc(column); // column
+    
+    s.putc(row); // row
+    s.putc(font_size); // font size (0 = 5x7 font, 1 = 8x8 font, 2 = 8x12 font)
+
+    s.putc(color >> 8);      // MSB          
+    s.putc(color & 0xFF);    // LSB
+
+    for (int i = 0;  i < strlen(mytext); i++) {
+        s.putc(mytext[i]); // character to write
+    }
+    s.putc(0x00);   // string terminator (always 0x00)
+
+    getResponse();
+}
+
+void OLED160G1::drawSingleChar(char column, char row, char theChar, int color) {
+    s.putc(OLED_TEXTFORMATED);
+    
+    s.putc(theChar);
+    s.putc(column);
+    s.putc(row);
+    
+    s.putc(color >> 8);      // MSB          
+    s.putc(color & 0xFF);    // LSB
+
+    getResponse();
+}
+
+void OLED160G1::displayControl(char mode, char value) {
+    s.putc(OLED_COMMAND_CONTROL);
+    
+    s.putc(mode);
+    s.putc(value);
+    
+    getResponse();
+}
+
+char OLED160G1::getPenSize() {
+    return _penSize;
+}
+    
+int OLED160G1::_putc(int value) {
+    if (value == '\n') {
+        _column = 0;
+        _row++;
+        if(_row >= rows()) {
+            _row = 0;
+        }
+    } else {
+        drawSingleChar(_column, _row, value, _fontColor);
+        
+        wait_ms(1);    //TODO: why is this needed?
+        
+        _column++;
+        if (_column >= columns()) {
+            _column = 0;
+            _row++;
+            if(_row >= rows()) {
+                _row = 0;
+            }
+        }
+    }
+    return value;
+}
+
+int OLED160G1::_getc() {
+    return -1;
+}
+
+void OLED160G1::locate(int column, int row) {
+    _column = column;
+    _row = row;
+}
+
+int OLED160G1::rows() { 
+    return 16;
+}
+
+int OLED160G1::columns() { 
+    return 26;
+}
\ No newline at end of file