0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【Raspberry Pi】LCD1602Aにカタカナ表示機能を実装する

Posted at

はじめに

この記事は「ラズパイ5を使ってLCD1602Aを操作していこう!」という趣旨のものになります。

以前の記事で作成したプログラムをベースに改修を行いますので、先にご覧いただけますと幸いです!

  1. 【Raspberry Pi】I2CアダプターなしでLCD1602Aに文字を表示する
  2. 【Raspberry Pi】LCD1602Aに長文表示機能を実装する

■成果物

・ラズパイ5でのLCD操作プログラム(カタカナ表示機能付き)
↓こんな感じで表示ができます↓
IMG_0968(1).gif

動機

これまで第2回に渡ってラズパイからLCD1602Aを操作するプログラムを作成してきましたが
前回の記事では以下の課題が残っていました。

  1. ASCII以外の文字に対応する
  2. write_four_bitsのEピン立ち上げ順序を修正
  3. 長文の表示機能を追加
  4. 部品モジュールとして使用する際の処理・API追加

今回はついに、一番需要が高いであろう1の課題を解決していきましょう!!
かなり力技が連発しますが、それではレッツゴー!

ライブラリなど

  • gpiozero 2.0
  • Python 3.11.2

警告
本記事では文量の関係により、ライブラリのインストールなどの手順は記載しませんのでご注意ください。
諸兄が記事にされている内容で特に難しいことはないはずと思います。

LCD1602A とは

言わずもがなの16文字x2列の液晶ディスプレイです。
外観はこんな感じ。
image.png
詳細はぜひ以前の記事をご参照ください!

■実装

まずはどういった改修を行えばカタカナ表示が行えるかですが…
端的に言うと、 文字コードにある特定の上位ビットを送信できるようにコードを改造すれば可能 であります!
(以下は以前の記事で載せた文字コード表を再掲)

image.png

赤枠で囲った部分ですね。
今までのコードに追加すべき機能は以下になります。

  1. 赤枠で囲った範囲の上位ビット列を送信できるようにすること
  2. 文字に対応した上位ビット(+下位ビット)を検索できるようにすること

では早速これらの機能を実装していきましょう。
過去に作成したプログラムのうち、LCD1602Aにビット列を送信しているのは以下の部分になります。

python
    # 引数の文字をASCIIコード表に従って変換し、上位4ビット→下位4ビットの順に送信
    def write_char(self, char):
        GPIO.output(self.RS, GPIO.HIGH)
        self.write_four_bits(ord(char) >> 4)
        self.write_four_bits(ord(char) & 0x0F)
    
    # D4-7に文字データ送信
    def write_four_bits(self, data):
        # E立ち上げ後、データ送信
        self.E.on()
        self.D4.value = bool(data & 0x01)
        self.D5.value = bool(data & 0x02)
        self.D6.value = bool(data & 0x04)
        self.D7.value = bool(data & 0x08)
        
        # Eパルス幅の最小値x1.5倍の時間待機
        time.sleep(2.1e-7)
        self.E.off()
        time.sleep(0.0005)

現状では、write_charメソッドにて引数で受け取った文字をASCIIコード表に従って変換し、D4-D7ピンを経由してLCD1602Aに送信しています。

引数の文字は自動的にASCII文字に変換される処理となっていますが、ここに

  1. 送りたい文字の範囲によってASCII文字なのか特殊文字コード表に則った文字なのかを区別する機能
  2. 特殊文字を検索し、対応するビット列を返す機能

を付け加える必要があります。

よって、以下のようにwrite_charメソッドを改修します。
また、文字検索機能を実装するため、プログラム冒頭にWORD_DICT_LCD1602Aを定義するとともに、ヘルパーメソッドconvertCharを導入します。

python
    # 文字データ表示(アルファベットと数字,演算記号:ASCII準拠)
    def write_char(self, char):
        display_char = "-"
        char_ASCII = ord(char)

        # ASCIIの範囲ならASCIIコードに沿って変換
        if char_ASCII >= 0x20 and char_ASCII <= 0x7F:
            display_char = ord(char)
        else: # ASCII以外なら独自変換表に沿って変換
            display_char = self.convertChar(char)
        
        self.RS.on()
        self.write_four_bits(display_char >> 4)
        self.write_four_bits(display_char & 0x0F)

    # ASCII以外の文字変換
    def convertChar(self, char):
        result_num = 0xFF # 塗りつぶし文字
        
        # 文字コード表に文字があれば検索して数値を返す
        if char in WORD_DICT_LCD1602A:
            result_num = WORD_DICT_LCD1602A[char]

        return result_num
python
# LCD1602Aの文字変換辞書
WORD_DICT_LCD1602A ={"":0xA1,
                     "":0xA2,
                     "":0xA3,
                     "":0xA4,
                     "":0xA5,
                     "":0xA6,
                     "":0xA7,
                     "":0xA8,
                     "":0xA9,
                     "":0xAA,
                     "":0xAB,
                     "":0xAC,
                     "":0xAD,
                     "":0xAE,
                     "":0xAF,
                     "":0xB0,
                     "":0xB1,
                     "":0xB2,
                     "":0xB3,
                     "":0xB4,
                     "":0xB5,
                     "":0xB6,
                     "":0xB7,
                     "":0xB8,
                     "":0xB9,
                     "":0xBA,
                     "":0xBB,
                     "":0xBC,
                     "":0xBD,
                     "":0xBE,
                     "ソ":0xBF,
                     "":0xC0,
                     "":0xC1,
                     "":0xC2,
                     "":0xC3,
                     "":0xC4,
                     "":0xC5,
                     "":0xC6,
                     "":0xC7,
                     "":0xC8,
                     "":0xC9,
                     "":0xCA,
                     "":0xCB,
                     "":0xCC,
                     "":0xCD,
                     "":0xCE,
                     "":0xCF,
                     "":0xD0,
                     "":0xD1,
                     "":0xD2,
                     "":0xD3,
                     "":0xD4,
                     "":0xD5,
                     "":0xD6,
                     "":0xD7,
                     "":0xD8,
                     "":0xD9,
                     "":0xDA,
                     "":0xDB,
                     "":0xDC,
                     "":0xDD,
                     "":0xDE,
                     "":0xDF,
                     "α":  0xE0,
                     "a:": 0xE1,
                     "β":  0xE2,
                     "ε":  0xE3,
                     "μ":  0xE4,
                     "σ":  0xE5,
                     "p_": 0xE6, # 崩し字は"_"をつけることとする
                     "q_": 0xE7,
                     "":  0xE8,
                     "^-1":0xE9,
                     "i":  0xEA,
                     "^x": 0xEB,
                     "Φ":  0xEC,
                     "": 0xED,
                     "n^-":0xEE,
                     "o:": 0xEF,
                     "p":  0xF0,
                     "q":  0xF1,
                     "θ":  0xF2,
                     "":  0xF3,
                     "Ω":  0xF4,
                     "u:": 0xF5,
                     "Σ":  0xF6,
                     "π":  0xF7,
                     "x^-":0xF8,
                     "u":  0xF9,
                     "":  0xFA,
                     "":  0xFB,
                     "":  0xFC,
                     "÷":  0xFD,
                     " ":  0xFE,
                     "":  0xFF,
                     }

以上のコードでは 引数charをASCII文字に変換し、0x20(="!")から0x7F(="←")までの範囲に入っているか判定し、入っていなければ新たに定義した文字コードディクショナリから対応するビット列を検索する といった処理を行っています。

この処理の追加によって先程の機能1,2を追加できている、、、はず!

■動作確認・テスト

では、上で改修したwrite_charメソッドの動作確認をしてみましょう!
動作確認用のテストコードをこんな感じで作成してみました。

python
def test_Katakana():
        lcd = None
        try:
            # GPIOピン番号は実際の接続に合わせて変更してください
            lcd = LCD1602A(rs=17, e=8, d4=25, d5=24, d6=23, d7=18)

            text1 = "カタカナヒョウジ"
            text2 = "デキテル?"
            lcd.print_row12(text1, text2)
            
            print("Press Enter to exit...")
            
            while True:
                # 標準入力に何か入力があるかチェック
                if select.select([sys.stdin,], [], [], 0.0)[0]:
                    # 入力があればループを抜ける
                    break

                time.sleep(0.1)  # CPU使用率を下げるための短い待機
        
        except Exception as e:
            print(f"エラーが発生しました: {e}")
        finally:
            if lcd:
                lcd.clear()
                lcd.print("Goodbye!")
                time.sleep(2)  # "Goodbye!"を2秒間表示
                lcd.close()
            print("プログラムを終了します。")

配線は以前の記事のままなので省略!!

プログラムを実行して、LCDに
"カタカナヒョウジ"
"デキテル?"
と表示されれば成功です。

さてさて、LCDの表示内容はどうなるでしょうか…

IMG_0968(1).gif

OK!無事カタカナが表示されました!

まとめ

というわけで今回は、LCD1602Aにカタカナを表示する機能を実装しました!
これで日本語のメッセージを表示したい場合に対応することができるようになりました、いぇい:v_tone1:

今後

  1. ASCII以外の文字に対応する
  2. write_four_bitsのEピン立ち上げ順序を修正
  3. 長文の表示機能を追加
  4. 部品モジュールとして使用する際の処理・API追加

今回、課題1が解決されたので、残る課題は4のみ!
最後はLCD1602Aを部品として何らかのシステムに組み込んだ際、処理を並列化するための機能を追加していこうと思っています。
(が、記事が長くなって書くのが大変そうな予感が満載なので、上がらなければ察してください:innocent:

最後に

本日も乱文でありましたが、ご覧いただきありがとうございました!
これからも組み込みやIoTに関する記事を投稿していく予定ですので、よろしくお願いいたします。:blush:

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?