1

Dependents:   Program_R11

Revision:
41:111ca62e8a59
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TextLCD_UTF8.inc	Fri Nov 06 18:59:27 2015 +0000
@@ -0,0 +1,124 @@
+/* mbed TextLCD Library, for LCDs based on HD44780 controllers
+ * Copyright (c) 2015, WH
+ *               2015, v01: WH, AR. Added UTF8 decode tables for Cyrilic font (by Andriy Ribalko).
+ *
+ * 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 MBED_TEXTLCDUTF8_INC
+#define MBED_TEXTLCDUTF8_INC
+
+#include "TextLCD_Config.h"
+
+#if(LCD_UTF8_FONT == 1)
+// Code by Andriy Ribalko
+// UTF8 conversion, please add other tables for your language
+// See wikipedia.org/wiki/UTF-8 and www.utf8-chartable.de
+
+//The two tables below are used to map UTF8 codes onto character codes for an LCD controller that
+//supports a specific fonttable. The UTF codes for a specific language like Cyrilic are between 0x0400 and 0x04FF.
+
+//Select one table for a specific controller and language
+
+#if(0)
+//Table for controller xxxx
+//The two tables below are used to map Cyrilic/Russian UTF8 codes onto character codes for an LCD controller that
+//supports a Cyrilic fonttable. The UTF codes for Cyrilic are between 0x0400 and 0x04FF
+
+#define UTF_FIRST         0x0400
+#define UTF_LAST          0x04FF
+#define UTF_SEQ_REC_FIRST utf_seq_rec_first_cyr 
+#define UTF_SEQ_REC_LAST  utf_seq_rec_last_cyr 
+#define UTF_SEQ_RECODE    utf_seq_recode_cyr
+#define UTF_RND_RECODE    utf_rnd_recode_cyr
+
+#define utf_seq_rec_first_cyr 0x0410  //UTF code of first symbol in sequential table UTF_recode
+#define utf_seq_rec_last_cyr  0x044F  //UTF code of last symbol in sequential table UTF_recode
+
+const char utf_seq_recode_cyr[] = {
+                                0x41,0xa0,0x42,0xa1, 0xe0,0x45,0xa3,0xa4, 0xa5,0xa6,0x4b,0xa7, 0x4d,0x48,0x4f,0xa8,   //Upper case Cyrillic
+                                0x50,0x43,0x54,0xa9, 0xaa,0x58,0xe1,0xab, 0xac,0xe2,0xad,0xae, 0x62,0xaf,0xb0,0xb1,
+                                0x61,0xb2,0xb3,0xb4, 0xe3,0x65,0xb6,0xb7, 0xb8,0xb9,0xba,0xbb, 0xbc,0xbd,0x6f,0xbe,   //Lower case Cyrillic
+                                0x70,0x63,0xbf,0x79, 0xe4,0x78,0xe5,0xc0, 0xc1,0xe6,0xc2,0xc3, 0xc4,0xc5,0xc6,0xc7
+                              };
+
+//Two dimensional table for some non-sequential symbol decoding (RUS/UKR)
+//U+0401 --> 0xa2 (Ё), U+0451 --> 0xb5 (ё), U+0406 --> 0x49 (І), U+0456 -->  0x69 (і) 
+const short int utf_rnd_recode_cyr [5][2]= {
+                                                {0x0401, 0xa2},
+                                                {0x0451, 0xb5},
+                                                {0x0406, 0x49},
+                                                {0x0456, 0x69},
+                                                {0}                  //Last element table zero
+                                           };
+#endif
+
+#if(LCD_UTF8_CYR_B == 1)
+//ROM_B Table for controller SSD1803 and US2066 
+//The two tables below are used to map Cyrilic/Russian UTF8 codes onto character codes for an LCD controller that
+//supports a Cyrilic fonttable. The UTF codes for Cyrilic are between 0x0400 and 0x04FF
+
+#define UTF_FIRST         0x0400
+#define UTF_LAST          0x04FF
+#define UTF_SEQ_REC_FIRST utf_seq_rec_first_cyr 
+#define UTF_SEQ_REC_LAST  utf_seq_rec_last_cyr 
+#define UTF_SEQ_RECODE    utf_seq_recode_cyr
+#define UTF_RND_RECODE    utf_rnd_recode_cyr
+
+#define utf_seq_rec_first_cyr 0x0410  //UTF code of first symbol in sequential table UTF_recode
+#define utf_seq_rec_last_cyr  0x044F  //UTF code of last symbol in sequential table UTF_recode
+const char utf_seq_recode_cyr[] = {
+                                0x80,0x81,0x82,0x83, 0x84,0x85,0x86,0x87, 0x88,0x89,0x8A,0x8B, 0x8C,0x8D,0x8E,0x8F,  //Upper case Cyrillic
+                                0x90,0x91,0x92,0x93, 0x94,0x95,0x96,0x97, 0x98,0x99,0x9A,0x9B, 0x9C,0x9D,0x9E,0x9F,
+                                0x61,0x81,0x62,0x83, 0x84,0x65,0x86,0x87, 0x88,0x89,0x6B,0x8B, 0x6D,0x69,0x6F,0x8F,  //Lower case Cyrillic (~Upper) 
+                                0x70,0x63,0x92,0x79, 0x94,0x95,0x96,0x97, 0x98,0x99,0x9A,0x9B, 0x9C,0x9D,0x9E,0x9F
+                              };
+ 
+//Two dimensional table for some non-sequential symbol decoding (RUS/UKR)
+//U+0400 --> 0xC8 (E)
+//U+0401 --> 0xCB (Ё)
+//U+0405 --> 0x53 (S)
+//U+0406 --> 0x49 (І)
+//U+0407 --> 0xCF (І)
+//U+0408 --> 0x4A (J)
+//U+0450 --> 0xE8 ( )
+//U+0451 --> 0xEB (ё)
+//U+0456 --> 0x69 (і) 
+//U+0457 --> 0xCF (і) 
+//U+0458 --> 0x6A (j) 
+const short int utf_rnd_recode_cyr [][2]=  {
+                                                {0x0400, 0xC8},
+                                                {0x0401, 0xCB},
+                                                {0x0405, 0x53},
+                                                {0x0406, 0x49},
+                                                {0x0407, 0xCF},
+                                                {0x0408, 0x4A},
+                                                {0x0450, 0xE8},
+                                                {0x0451, 0xEB},
+                                                {0x0456, 0x69},
+                                                {0x0457, 0xCF},
+                                                {0x0458, 0x6A},
+                                                {0     ,    0}   //Last element table zero
+                                           };
+#endif
+
+
+//end UTF conversion
+#endif
+
+#endif
\ No newline at end of file