1
TextLCD_UTF8.inc
- Committer:
- jRix
- Date:
- 2019-10-03
- Revision:
- 42:5ae223476b86
- Parent:
- 41:111ca62e8a59
File content as of revision 42:5ae223476b86:
/* 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