LIRC
関連記事
この記事ではシリアル・USB 赤外線デバイスを使って LIRC "Linux Infrared Remote Control" を設定・使用する方法を説明しています。
目次
概要
LIRC はサポートしているリモコンのキーが押されたのをプログラムにあわせてコマンドに変換することができるデーモンです。ここで、「プログラムにあわせて」とは実行しているプログラムによってキーの押下で異なる動作をさせることができることを意味します。
LIRC の役割
LIRC を使ってリモコンからの情報がプログラムに流れる過程は以下の通りです:
- ユーザーがリモコンのボタンを押すことで IR または RF 信号が送信されます。
- 信号が Linux が入ったパソコンに接続されたレシーバーによって受信されます。
- カーネル (の適切なモジュール) は
/dev/lirc0
でレシーバーからのパルス幅の情報をキャラクタライズします。 /usr/bin/lircd
は/etc/lirc/lircd.conf.d/foo.conf
からの情報でパルス幅をボタンの押下情報に変換します。- LIRC を使用するプログラムは
/usr/bin/lircd
のボタン押下情報を~/.lircrc
によってユーザーが定義した操作に解釈します。
必要なファイル
- {{ic|/etc/lirc/lircd.conf.d/foo.conf} - スキャンコード --> キーに変換するシステムレベルの設定。このディレクトリには複数の conf ファイルを入れることができ、それぞれがシステムの各リモートコントローラ・レシーバー固有です。
任意のファイル
LIRC を使用するアプリケーションによっては、以下のファイルは任意です。例えば mplayer や mythtv は以下のファイルを使ってキーマップやアクションを定義します。全てのアプリケーションが必要とするわけではありません。例として、kodi は自分の xml ファイルを使ってマッピングを行います。
~/.lircrc
- プログラムごとの lirc マップ (~/.lirc/foo
,~/.lirc/bar
など) を指定する include ステートメントを記述するファイル。~/.lirc/foo
- キー --> 操作に翻訳するユーザーレベルの設定。各リモコンとアプリケーション foo の固有設定。
インストール
公式リポジトリにある lirc パッケージをインストールします。
設定
リモコンによっては LIRC がなくても"キーボード"として認識されそのように動作することがあります。このように認識されているとコマンドを二重に実行してしまう可能性があります。シェルやテキストエディタを開いて、リモコンのボタンを押してキーボードとして認識されていないかテストして下さい。文字や数字が打ち込まれたり、物理キーボードの上・下・右・左矢印キーのように動く場合、無効にする必要があります。次に進む前に #リモコンがキーボードとして機能する を見て下さい。
LIRC の設定ファイル
LIRC がリモコンを扱えるようにするにはスキャンコードとキーマップの定義が必要です。適当な conf ファイルを /etc/lirc/lircd.conf.d
にコピーすることでマッピングできます。
選択肢 1. 上流の設定ファイル
使用するリモコン/レシーバを確認して /usr/share/lirc/configs
に設定済みの設定ファイルが存在しないか見てください。存在したら、デーモンが初期化をできるように、必要な conf を /etc/lirc/lircd.conf.d
にコピーします。
選択肢 2. ユーザーが作成した設定ファイル
Users with unsupported hardware will need to either find a config file someone else has created (i.e. google) or create one. Creating one is fairly straightforward using the included /usr/bin/irrecord
program which guides users along the needed process. If using a detected remote, invoke it like so:
irrecord --device=/dev/lirc0 MyRemote
The program will ask users to begin hitting keys on the remote in an attempt to learn it. If all goes well, the user will be prompted to map out each key press to a specific scancode LIRC uses to identify that specific key press. The process should take no more than 10 minutes. When finished, save the resulting file to /etc/lirc/lircd.conf.d/foo.conf
and proceed.
リモコンのテスト
lircd.service
を起動してブート/シャットダウン時に実行されるように有効化してください (強く推奨)。
/usr/bin/irw
を使ってリモコンをテストしてください、リモコンのボタンを押した時に LIRC が受信したものを全て標準出力に流します。
例:
$ irw 000000037ff07bfe 00 One mceusb 000000037ff07bfd 00 Two mceusb 000000037ff07bfd 01 Two mceusb 000000037ff07bf2 00 Home mceusb 000000037ff07bf2 01 Home mceusb
プログラムごとの設定
LIRC has the ability to allow for different programs to use the same keypress and result in unique commands. In other words, mplayer and vlc can respond differently to a given key press.
Decide which programs are to use LIRC commands. Common programs include: mplayer, mythtv, totem, vlc, and kodi.
Users should create the expected files showing LIRC where the various program-specific maps reside:
$ mkdir ~/.lirc $ touch ~/.lircrc
- Populate
~/.lirc
with the program specific config files named for each program.
Example:
$ ls ~/.lirc mplayer mythtv vlc
- Edit
~/.lircrc
to contain an include statement pointing to~/.lirc/foo
and repeat for each program that is to be controlled by LIRC.
Example:
~/.lircrc
include "~/.lirc/mplayer" include "~/.lirc/mythtv" include "~/.lirc/vlc"
トラブルシューティング
リモコンがキーボードとして機能する
Xorg detects some remotes, such as the Streamzap USB PC Remote, as a Human Interface Device (HID) which means some or all of the keys will show up as key strokes as if entered from the physical keyboard. This behavior will present problems if LIRC is to be used to manage the device. To disable, create the following file and restart X:
/etc/X11/xorg.conf.d/90-streamzap.conf
Section "InputClass" Identifier "Ignore Streamzap IR" MatchProduct "Streamzap" MatchIsKeyboard "true" Option "Ignore" "true" EndSection
Don't forget to alter the MatchProduct
property according to one shown in Name
from output of
$ cat /proc/bus/input/devices | grep -e IR
For example WinFast
for N: Name="cx88 IR (WinFast DTV2000 H rev."