Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Diff: N5110.cpp
- Revision:
- 14:520a02fc12aa
- Parent:
- 12:022993561fd8
- Child:
- 15:ee645611ff94
diff -r 022993561fd8 -r 520a02fc12aa N5110.cpp
--- a/N5110.cpp Tue Mar 10 18:09:37 2015 +0000
+++ b/N5110.cpp Tue Mar 10 19:21:47 2015 +0000
@@ -10,10 +10,10 @@
N5110::N5110(PinName pwrPin, PinName scePin, PinName rstPin, PinName dcPin, PinName mosiPin, PinName sclkPin, PinName ledPin)
{
-
+
spi = new SPI(mosiPin,NC,sclkPin); // create new SPI instance and initialise
- initSPI();
-
+ initSPI();
+
// set up pins as required
led = new PwmOut(ledPin);
pwr = new DigitalOut(pwrPin);
@@ -47,16 +47,18 @@
clearRAM();
}
-
-// sets normal video mode (black on white)
-void N5110::normalMode() {
- sendCommand(CMD_DC_NORMAL_MODE);
-
+
+// sets normal video mode (black on white)
+void N5110::normalMode()
+{
+ sendCommand(CMD_DC_NORMAL_MODE);
+
}
-// sets normal video mode (white on black)
-void N5110::inverseMode() {
- sendCommand(CMD_DC_INVERT_VIDEO);
+// sets normal video mode (white on black)
+void N5110::inverseMode()
+{
+ sendCommand(CMD_DC_INVERT_VIDEO);
}
// function to power up the LCD and backlight
@@ -144,7 +146,7 @@
}
-// function to set the XY address in RAM for subsequenct data write
+// function to set the XY address in RAM for subsequenct data write
void N5110::setXYAddress(int x, int y)
{
// check whether address is in range
@@ -187,11 +189,11 @@
void N5110::refresh()
{
int i,j;
-
+
setXYAddress(0,0); // important to set address back to 0,0 before refreshing display
// address auto increments after printing string, so buffer[0][0] will not coincide
// with top-left pixel after priting string
-
+
sce->write(0); //set CE low to begin frame
for(j = 0; j < 6; j++) { // be careful to use correct order (j,i) for horizontal addressing
@@ -217,17 +219,14 @@
}
// function to print 5x7 font
-void N5110::printChar(char c)
+void N5110::printChar(char c,int x,int y)
{
- int i;
- // loop through 5 columns
- for (i = 0; i < 5 ; i++ ) {
- sendData(font5x7[(c - 32)*5 + i]);
- // array is offset by 32 relative to ASCII, each character is 5 pixels wide
- // the X address is automatically incremented after each data write
+ for (int i = 0; i < 5 ; i++ ) {
+ buffer[x+i][y] = font5x7[(c - 32)*5 + i];
+ // array is offset by 32 relative to ASCII, each character is 5 pixels wide
}
- sendData(0); // send an empty byte to introduce space between characters
-
+
+ refresh(); // this sends the buffer to the display and sets address (cursor) back to 0,0
}
// function to print string at specified position
@@ -237,20 +236,16 @@
// loop through string and print character
while(*str) {
- // This is the old version - strings are printed using the printChar function
- //setXYAddress(x+6*n,y); // leave 1 pixel (6 = 5 + 1) between each character
- //printChar(*str); // print the char - can probably do *str++ and remove next line
-
- // the new version writes the character bitmap data to the buffer, so that
+ // writes the character bitmap data to the buffer, so that
// text and pixels can be displayed at the same time
for (int i = 0; i < 5 ; i++ ) {
buffer[x+i+n*6][y] = font5x7[(*str - 32)*5 + i];
}
-
+
str++; // go to next character in string
n++; // increment index
}
-
+
refresh(); // this sends the buffer to the display and sets address (cursor) back to 0,0
}
@@ -258,7 +253,6 @@
// function to clear the screen
void N5110::clear()
{
- clearRAM(); // clear on-board RAM
clearBuffer(); // clear the buffer then call the refresh function
refresh();
}
@@ -275,18 +269,19 @@
}
// function to plot array on display
-void N5110::plotArray(float array[]) {
-
+void N5110::plotArray(float array[])
+{
+
int i;
-
+
for (i=0; i<84; i++) { // loop through array
// elements are normalised from 0.0 to 1.0, so multiply
// by 47 to convert to pixel range, and subtract from 47
// since top-left is 0,0 in the display geometry
setPixel(i,47 - int(array[i]*47.0));
- }
-
+ }
+
refresh();
-
-
+
+
}
\ No newline at end of file