Index: head/ja_JP.eucJP/books/handbook/multimedia/chapter.xml =================================================================== --- head/ja_JP.eucJP/books/handbook/multimedia/chapter.xml (revision 41824) +++ head/ja_JP.eucJP/books/handbook/multimedia/chapter.xml (revision 41825) @@ -1,2003 +1,2003 @@ Ross Lippert 編集: マルチメディア この章では FreeBSD は数多くの種類のサウンドカードに対応しており、 コンピュータで原音に忠実な出力を楽しむことができます。 これには録音機能と、MPEG Layer 3 Audio (MP3) や WAV, Ogg Vorbis などをはじめとした多くの形式の音楽の再生機能が含まれます。 加えて FreeBSD の Ports Collection には、録音した音楽を 編集したり、音響効果を加えたり、接続された MIDI 機器を制御するためのアプリケーションがあります。 多くの試みによって、&os; ではビデオファイルおよび DVD の 再生ができるようになりました。さまざまなビデオメディアをエンコード、 変換、再生するアプリケーションの数は、 音声用のアプリケーションほど充実していません。 この文書を執筆している時点では、たとえば audio/sox のようなファイル形式を変換するためのすぐれたアプリケーションは Ports Collection にありません。しかしながら、 この分野のソフトウェアの状況は急速に変わりつつあります。 この章ではサウンドカードを設定するために必要な方法を説明します (ただし、高音質で再生するためには若干の微調整が必要かもしれません)。 ビデオカードのハードウェアに関する問題は、 X11 () のインストールと設定においてすでに扱いましたので、 そちらをご覧ください。 この章を読むと、以下のことがわかります。 サウンドカードを認識させるためにシステムを設定する方法 サウンドカードがうまく動作しているかどうかテストする方法 サウンドの設定に関するトラブルシューティング MP3 およびその他の形式の音声を再生、エンコードする方法 X サーバで どのようにビデオに対応しているか ビデオを再生、エンコードするのに役に立つ ports DVD の .mpg ファイルおよび .avi ファイルを再生する方法 CD および DVD の情報を抽出する方法 TV カードの設定方法 画像スキャナの設定方法 この章を読む前に、以下のことを理解しておく必要があります。 新しいカーネルを設定してインストールする方法 () オーディオ CD を &man.mount.8; でマウントしようとすると、少なくともエラーになります。 最悪の場合、カーネルパニックが発生するでしょう。 これらのメディアは通常の ISO ファイルシステムとは異なり、 特別なエンコードが施されているからです。 Moses Moore 寄稿: Marc Fonvieille 再構成: サウンドカードの設定 システムを設定する PCI ISA サウンドカード 設定をはじめる前に、あなたが持っているカードのモデル、 そのカードが使用しているチップ、そして PCI, ISA どちらのカードなのかを確認する必要があります。 FreeBSD は PCI および ISA の両方のカードに幅広く対応しています。 使用しているカードが対応しているかどうかは、 ハードウェアノート の対応オーディオデバイスの一覧を調べてください。 このハードウェアノートには、 カードに対してどのドライバを利用すればよいかについても言及されています。 カーネル 設定 サウンドデバイスを使うために、 適切なデバイスドライバを読み込まなければいけません。 これには二つの方法のどちらかでできるでしょう。 もっとも簡単な方法は &man.kldload.8; を使ってサウンドカードのカーネルモジュールを単に読み込むことです。 次のコマンドで実現できます。 &prompt.root; kldload snd_emu10k1 または /boot/loader.conf ファイルにこのような適切な行を加えて実現することもできます。 snd_emu10k1_load="YES" 以上は Creative &soundblaster; Live! サウンドカードの例です。 他に利用可能な読み込み可能なサウンドモジュールは /boot/defaults/loader.conf に記載されています。 どのドライバを利用すればいいか確かでなければ、 snd_driver モジュールを読み込んでみてください。 &prompt.root; kldload snd_driver snd_driver モジュールは、 一般に使用されるカードに対応したドライバをまとめて一度に読み込むメタドライバです。 このドライバを使用すれば、速やかに正しいドライバを探し出すことができるでしょう。 /boot/loader.conf ファイルを使用して、 すべてのサウンドドライバを読み込むこともできます。 snd_driver メタドライバの読み込み後に、 どのドライバがサウンドカードに選択されたのかを知りたいのなら cat /dev/sndstat コマンドで /dev/sndstat ファイルを調べてください。 二つ目の方法は、 サウンドカードのドライバをカーネルへ静的に組み込むことです。 以下の節では、この方法でハードウェアを対応させる方法を説明します。 カーネル再構築の詳細は を参照してください。 サウンドに対応したカスタムカーネルを設定する はじめに、オーディオフレームワークドライバ &man.sound.4; をカーネルに追加します。 カーネルコンフィグレーションファイルに以下の行を追加してください。 device sound 次に、サウンドカードに対応したドライバを追加します。 それには、どのドライバがカードに対応しているかを知る必要があります。 使用しているカードに対する正しいドライバを決定するために、 ハードウェアノート の対応オーディオデバイスの一覧を調べてください。 たとえば、Creative &soundblaster; Live! サウンドカードは &man.snd.emu10k1.4; ドライバが対応しています。 このカードを使用するためには、 カーネルコンフィグレーションファイルに以下の行を追加してください。 device snd_emu10k1 ドライバのマニュアルページを読んで、 追加すべき構文を調べてください。 対応しているすべてのサウンドドライバに関するカーネルコンフィグレーションの具体的な構文は、 /usr/src/sys/conf/NOTES にもあります。 すべての PnP 非対応の ISA カードに当てはまるように、 PnP 非対応の ISA サウンドカードでは、 カーネルにカードが使用する資源 (IRQ, I/O ポートなど) を明示的に指定する必要があるかもしれません。 この場合は、/boot/device.hints ファイルを使用してください。 システムの起動時に、&man.loader.8; はこのファイルを読み、設定情報をカーネルに渡します。 たとえば、PnP 非対応の古い Creative &soundblaster; 16 (ISA 接続) には snd_sb16 とともに &man.snd.sbc.4; ドライバを使用します。 このカードを使用する場合には、 カーネルコンフィグレーションファイルに以下の行を追加すると同時に、 device snd_sbc device snd_sb16 /boot/device.hints ファイルに以下のエントリを追加してください。 hint.sbc.0.at="isa" hint.sbc.0.port="0x220" hint.sbc.0.irq="5" hint.sbc.0.drq="1" hint.sbc.0.flags="0x15" この例では、 I/O ポートに 0x220 を、 IRQ に 5 を使用します。 /boot/device.hints ファイルに用いるべき構文は、 &man.sound.4; ドライバのマニュアルページ、および、 各ドライバのマニュアルページに記載されています。 初期設定は以上の通りです。 カードを使用する状況によっては、 IRQ やその他の設定を変更する必要があるかもしれません。 このカードについての詳細は、 &man.snd.sbc.4; マニュアルページをご覧ください。 サウンドカードのテスト カーネルを変更して再起動するか、必要となるモジュールを読み込むと、 システムのメッセージバッファ (&man.dmesg.8;) にサウンドカードが認識されたことが示されます。 たとえば、次のようなメッセージが出力されます。 pcm0: <Intel ICH3 (82801CA)> port 0xdc80-0xdcbf,0xd800-0xd8ff irq 5 at device 31.5 on pci0 pcm0: [GIANT-LOCKED] pcm0: <Cirrus Logic CS4205 AC97 Codec> サウンドカードの状態は、/dev/sndstat ファイルを使用して確認することができます。 &prompt.root; cat /dev/sndstat FreeBSD Audio Driver (newpcm) Installed devices: pcm0: <Intel ICH3 (82801CA)> at io 0xd800, 0xdc80 irq 5 bufsz 16384 kld snd_ich (1p/2r/0v channels duplex default) この出力はシステムによって異なるでしょう。 pcm デバイスがなければ、 今までの手順を振り返ってみてください。 カーネルコンフィグレーションファイルをもう一度見直して、 正しいデバイスドライバを選択しているかどうか確認してください。 トラブルシューティングは を参照してください。 すべてうまくいけば、サウンドカードが機能するでしょう。 CD-ROM または DVD-ROM ドライブのオーディオ出力端子がサウンドカードと適切に接続されていれば、 &man.cdcontrol.1; を使ってドライブ内の CD を再生できます。 &prompt.user; cdcontrol -f /dev/acd0 play 1 audio/workman のように、よりよいインタフェースを提供するさまざまなアプリケーションがあります。 MP3 オーディオファイルを聴くために audio/mpg123 のようなアプリケーションをインストールしようと思うかもしれません。 手っ取り早くカードをテストするには、 /dev/dsp デバイスにデータを送ってみてください。 たとえば、以下のようにします。 &prompt.user; cat filename > /dev/dsp ここで filename はどんなファイルでも構いません。 このコマンドラインを実行すると雑音が発生するはずです。 これにより、サウンドカードが実際に動作していることを確認できます。 デバイスノード /dev/dsp* は、 必要とされる時に自動的に作成されます。 デバイスノードが使用されていない場合には存在せず、 &man.ls.1; の出力に表示されません。 サウンドカードのミキサレベルは &man.mixer.8; コマンドで変更することができます。 詳細は &man.mixer.8; マニュアルページをご覧ください。 よくある問題 デバイスノード I/O ポート IRQ DSP エラー 解決方法 sb_dspwr(XX) timed out 使用する I/O ポートが適切に設定されていません。 bad irq XX 使用する IRQ が正しく設定されていません。 サウンドカードの IRQ と設定した IRQ が同じかどうか確かめてください。 xxx: gus pcm not attached, out of memory デバイスを使用するのに十分なメモリを確保できません。 xxx: can't open /dev/dsp! fstat | grep dsp を使って、 他のアプリケーションがデバイスを使用しているか調べてください。 注目すべきトラブルメーカは esoundKDE のサウンド機能です。 最近のグラフィックカードの中には、 HDMI や類似のインタフェースを利用するため、 グラフィックカード自身がサウンドカードを持つものがあります。 このようなサウンドデバイスには、 時として本当のサウンドカードより若い番号が付けられることがあり、 そのような場合には、 サウンドカードをデフォルトプレイバックデバイスとして利用できません。 このことが原因かどうかを確認するには、dmesg を実行して pcm を探してください。 以下のような出力を得るかもしれません。 ... hdac0: HDA Driver Revision: 20100226_0142 hdac1: HDA Driver Revision: 20100226_0142 hdac0: HDA Codec #0: NVidia (Unknown) hdac0: HDA Codec #1: NVidia (Unknown) hdac0: HDA Codec #2: NVidia (Unknown) hdac0: HDA Codec #3: NVidia (Unknown) pcm0: <HDA NVidia (Unknown) PCM #0 DisplayPort> at cad 0 nid 1 on hdac0 pcm1: <HDA NVidia (Unknown) PCM #0 DisplayPort> at cad 1 nid 1 on hdac0 pcm2: <HDA NVidia (Unknown) PCM #0 DisplayPort> at cad 2 nid 1 on hdac0 pcm3: <HDA NVidia (Unknown) PCM #0 DisplayPort> at cad 3 nid 1 on hdac0 hdac1: HDA Codec #2: Realtek ALC889 pcm4: <HDA Realtek ALC889 PCM #0 Analog> at cad 2 nid 1 on hdac1 pcm5: <HDA Realtek ALC889 PCM #1 Analog> at cad 2 nid 1 on hdac1 pcm6: <HDA Realtek ALC889 PCM #2 Digital> at cad 2 nid 1 on hdac1 pcm7: <HDA Realtek ALC889 PCM #3 Digital> at cad 2 nid 1 on hdac1 ... ここで、グラフィックカード (NVidia) には、サウンドカード (Realtek ALC889) より若い番号が付けられています。 サウンドカードをデフォルトのプレイバックデバイスとして利用するには、 以下のように hw.snd.default_unit をプレイバックで使用するユニット番号に変更してください。 &prompt.root; sysctl hw.snd.default_unit=n ここで、n は使用するサウンドデバイスの番号です。 この例では 4 です。 /etc/sysctl.conf に以下の行を入れると、 常に設定の変更が反映されるようになります。 hw.snd.default_unit=4 Munish Chopra 寄稿: 複数音源の利用 特定のアプリケーションとのサウンドデバイスの共用に対応していない時、 esound または artsd のように 同時に再生することのできる音源を複数実装していることは、 多くの場合望ましいことです。 FreeBSD では、 仮想サウンドチャネル を使ってこれを実現でき、&man.sysctl.8; で設定できます。 仮想チャネルはカーネル内でサウンドを合成することにより、 サウンドカードの再生を多重化することができます。 仮想チャネルの数を決めるのに三つの sysctl 変数を設定できます。 root ユーザで以下のようにします。 &prompt.root; sysctl dev.pcm.0.play.vchans=4 &prompt.root; sysctl dev.pcm.0.rec.vchans=4 &prompt.root; sysctl hw.snd.maxautovchans=4 上記の例では四つの仮想チャネルを設定しています。 これは通常利用する上で十分実用的な数です。 dev.pcm.0.play.vchans=4dev.pcm.0.rec.vchans=4 は、 pcm0 が再生や録音のために持っている仮想チャネルの数で、 一度デバイスが取り付けられると設定できます。 hw.snd.maxautovchans は、 &man.kldload.8; を用いて認識された新しいデバイスの仮想チャネル数です。 pcm モジュールはハードウェアドライバとは独立して読み込むことができるので、 後でどんなにデバイスを認識しても hw.snd.maxautovchans は仮想チャネルを格納できます。 より詳細な情報については &man.pcm.4; のマニュアルページを参照してください。 デバイスを使用しているときに 仮想チャンネルの数を変更することはできません。 まず、ミュージックプレーヤやサウンドデーモンといった デバイスを使用しているすべてのプログラムを終了してください。 /dev/dsp0 を必要とするプログラムが意識しなくても、 適切な pcm デバイスが自動的に設定されます。 Josef El-Rayes 寄稿: ミキサチャネルの初期値を設定する 各ミキサチャネルの初期値は &man.pcm.4; ドライバのソースにハードコーディングされています。 起動時に記録されていた値をミキサに設定する さまざまなアプリケーションやデーモンがありますが、 あまりよい解決方法ではありません。 適切な値を /boot/device.hints ファイルに記述することにより、 ドライバレベルでミキサの初期値を設定することができます。 たとえば、以下のような行を追加します。 hint.pcm.0.vol="50" この例では、&man.pcm.4; が読み込まれたと同時に、 ボリュームチャネルの初期値を 50 に設定します。 Chern Lee 寄稿: MP3 オーディオ MP3 (MPEG Layer 3 Audio) は CD に匹敵する音質でサウンドを再生できます。あなたの FreeBSD ワークステーションにこのプレイヤをインストールしない理由はないでしょう。 MP3 プレイヤ XMMS (X Multimedia System) は とても人気のある X11 ベースの MP3 プレイヤです。 XMMS のグラフィカルインタフェースは Nullsoft の Winamp とほとんど同一なので、Winamp のスキンを使うことができます。 XMMS はネイティブプラグインにも対応しています。 XMMSmultimedia/xmms の port または package からインストールできます。 XMMS のプレイリスト、グラフィックイコライザそしてその他のインタフェースは 直感的です。 Winamp を使いなれている人は 簡単に XMMS を使えるでしょう。 audio/mpg123 はコマンドライン上の代替となる MP3 プレイヤの port です。 mpg123 はサウンドデバイスと MP3 ファイルを指定して実行できます。 /dev/dsp1.0 デバイスを使用して MP3 ファイル Foobar-GreatestHits.mp3 を再生するのであれば、次のように実行してください。 &prompt.root; mpg123 -a /dev/dsp1.0 Foobar-GreatestHits.mp3 High Performance MPEG 1.0/2.0/2.5 Audio Player for Layer 1, 2 and 3. Version 0.59r (1999/Jun/15). Written and copyrights by Michael Hipp. Uses code from various people. See 'README' for more! THIS SOFTWARE COMES WITH ABSOLUTELY NO WARRANTY! USE AT YOUR OWN RISK! Playing MPEG stream from Foobar-GreatestHits.mp3 ... MPEG 1.0 layer III, 128 kbit/s, 44100 Hz joint-stereo CD 音声トラックの抽出 CD 全体または CD トラックを MP3 に変換する前に、CD 上のオーディオデータをハードディスク上に抽出する必要があります。 これには raw CDDA (CD Digital Audio) データを WAV ファイルにコピーします。 sysutils/cdrtools スイートの一部である cdda2wav ツールは CD からオーディオデータを抽出したり、 情報を関係づけるのに使われます。 CD をドライブにいれて次のコマンドを (rootで) 実行して、 CD 全体を (トラックごとに) 個々の WAV ファイルに抽出できます。 &prompt.root; cdda2wav -D 0,1,0 -B cdda2wav は ATAPI (IDE) CDROM ドライブにも対応しています。 IDE ドライブから抽出するには、 SCSI ユニット番号をデバイス名に置き換えて指定します。 たとえば IDE ドライブから七番目のトラックを抽出するには、 次のようにします。 &prompt.root; cdda2wav -D /dev/acd0 -t 7 は SCSI デバイス 0,1,0 を表します。 これは cdrecord -scanbus の出力に一致します。 個々のトラックを抽出するには、 次のように オプションを使用します。 &prompt.root; cdda2wav -D 0,1,0 -t 7 上記の例はオーディオ CDROM の七番目のトラックを抽出します。 範囲を指定して、 たとえば一番目から七番目のトラックまで抽出したい場合、 次のようにします。 &prompt.root; cdda2wav -D 0,1,0 -t 1+7 &man.dd.1; ユーティリティも ATAPI ドライブ上のオーディオトラックを展開するのに使われます。 何ができるか詳しいことは オーディオ CD の複製について を参照してください。 MP3 のエンコード 現在、一般に好まれている MP3 エンコーダは lame です。 lame は Ports Collection の audio/lame に収録されています。 次のコマンドを実行すると、抽出した WAV ファイル audio01.wav を使って audio01.mp3 に変換します。 &prompt.root; lame -h -b 128 \ --tt "曲名" \ --ta "アーティスト名" \ --tl "アルバム名" \ --ty "" \ --tc "コメント" \ --tg "ジャンル" \ audio01.wav audio01.mp3 128 kbits が標準のビットレートのようです。 多くの人はさらに高音質の 160 kbits または 192 kbits を好むでしょう。 ビットレートが高くなるにつれて作成される MP3 ファイルは多くのディスク領域を消費しますが、より高音質となります。 オプションを指定すると 低速高品質 モードとなります。 ではじまるオプションは ID3 タグを設定します。 このタグにはたいてい曲の情報が含まれており、 MP3 ファイルに格納されます。 lame のマニュアルを参照すれば他のオプションが見つかるでしょう。 MP3 のデコード MP3 からオーディオ CD を作成するには、 MP3 形式を非圧縮 WAV 形式に変換しなければなりません。 XMMSmpg123 の両方が MP3 から非圧縮ファイル形式への出力に対応しています。 XMMS でディスクへ書き出す方法は次の通りです。 XMMS を起動します。 右クリックで XMMS メニューを表示します。 Options から Preference を選択します。 Output Plugin を Disk Writer Plugin に変更します。 Configure を押します。 非圧縮ファイルを書き出すディレクトリを入力 (または選択) します。 普段通り XMMS へ MP3 ファイルを読み込みます。 音量は 100% で イコライザの設定はオフにします。 Play を押します— XMMS は MP3 を再生しているかのように表示しますが、 音声はきこえません。 実際には MP3 をファイルに出力しています。 再び MP3 を聴けるように Output Plugin を以前のように元に戻すのを忘れないでください。 mpg123 で標準出力へ書き出す方法は次の通りです。 mpg123 -s audio01.mp3 > audio01.pcm を実行します。 XMMS は WAV 形式でファイルに書き出しますが、 mpg123 は MP3 を PCM オーディオデータに変換します。 両形式は cdrecord を使ってオーディオ CD を作成するのに利用することができます。 &man.burncd.8; を使う場合は raw PCM データが必要です。 WAV ファイルを使用する場合、 それぞれのトラックの先頭に小さなノイズが入るのに気づくでしょう。 これは WAV ファイルのヘッダ情報です。 SoX (audio/sox の port または package からインストールできます) を使うと簡単に WAV ファイルのヘッダ情報を削除できます。 &prompt.user; sox -t wav -r 44100 -s -w -c 2 track.wav track.raw FreeBSD での CD 作成の詳しい情報は を参照してください。 Ross Lippert 寄稿: ビデオ再生 ビデオ再生は今まさに成長中の新しいアプリケーション分野です。 辛抱強くしてください。 音声のようにすべてが順調にいくとは限りません。 設定をはじめる前に、あなたが持っているビデオカードのモデル、 そのカードが使用しているチップを確認する必要があります。 &xorg; はさまざまなビデオカードに対応していますが、 ビデオ再生に申し分のない性能を発揮できるカードはわずかです。 あなたのビデオカードの利用している X サーバが対応している拡張機能のリストを得るには、 X11 を実行中に &man.xdpyinfo.1; コマンドを実行してください。 さまざまなプレイヤやオプションを試すのに、 テストファイルとして小さな MPEG ファイルを用意しておくのはよい考えです。 いくつかの DVD プレイヤは DVD メディアを /dev/dvd として 初期設定しているか、ハードコーディングされているので、 次のように適切なデバイスにシンボリックリンクを張っておくと便利かもしれません。 &prompt.root; ln -sf /dev/acd0 /dev/dvd &prompt.root; ln -sf /dev/acd0 /dev/rdvd &man.devfs.5; の仕様により、 このように手動で作成されたリンクは再起動すると消えてしまいます。 システムの起動時にこれらのシンボリックリンクを自動的に作成するには、 /etc/devfs.conf に下記の設定を追加します。 link acd0 dvd link acd0 rdvd 加えて、特別な DVD-ROM 機能を必要とする DVD 解読は、 DVD デバイスへの書き込み権限が必要です。 共有メモリ X11 インタフェースを改善するために、 いくつかの &man.sysctl.8; 変数の値を増やすことが推奨されています。 kern.ipc.shmmax=67108864 kern.ipc.shmall=32768 ビデオ機能の決定 XVideo SDL DGA X11 においてビデオ表示性能を改善する方法はいくつかあると思われます。 ちゃんと動作するかどうかはハードウェアに大きく依存しています。 下記に説明したどの方法でも、 ハードウェアが変わると品質が変わるでしょう。 二つ目に、X11 でのビデオレンダリングは最近多くの注目を集めるトピックです。 そして &xorg; のバージョンを追うごとに、著しく改良されているかもしれません。 よく知られたビデオインタフェースは次の通りです。 X11: 共有メモリを用いた通常の X11 出力 XVideo: X11 drawable 内でのビデオ再生に対応した X11 インタフェースの拡張機能 SDL: Simple Directmedia Layer DGA: Direct Graphics Access SVGAlib: 低レベルコンソールグラフィックレイヤ XVideo &xorg; には XVideo (または Xvideo, Xv, xv) と呼ばれる拡張機能があります。 これは特別なアクセラレーションによって drawable オブジェクト に直接ビデオを表示することができます。 この拡張機能によって、 低速なマシンでも、とてもすぐれた品質の再生が可能となります。 この拡張機能が動作しているかどうかを調べるには、 xvinfo を使います。 &prompt.user; xvinfo 以下のような結果が得られたならば、あなたのカードは XVideo に対応しています。 X-Video Extension version 2.2 screen #0 Adaptor #0: "Savage Streams Engine" number of ports: 1 port base: 43 operations supported: PutImage supported visuals: depth 16, visualID 0x22 depth 16, visualID 0x23 number of attributes: 5 "XV_COLORKEY" (range 0 to 16777215) client settable attribute client gettable attribute (current value is 2110) "XV_BRIGHTNESS" (range -128 to 127) client settable attribute client gettable attribute (current value is 0) "XV_CONTRAST" (range 0 to 255) client settable attribute client gettable attribute (current value is 128) "XV_SATURATION" (range 0 to 255) client settable attribute client gettable attribute (current value is 128) "XV_HUE" (range -180 to 180) client settable attribute client gettable attribute (current value is 0) maximum XvImage size: 1024 x 1024 Number of image formats: 7 id: 0x32595559 (YUY2) guid: 59555932-0000-0010-8000-00aa00389b71 bits per pixel: 16 number of planes: 1 type: YUV (packed) id: 0x32315659 (YV12) guid: 59563132-0000-0010-8000-00aa00389b71 bits per pixel: 12 number of planes: 3 type: YUV (planar) id: 0x30323449 (I420) guid: 49343230-0000-0010-8000-00aa00389b71 bits per pixel: 12 number of planes: 3 type: YUV (planar) id: 0x36315652 (RV16) guid: 52563135-0000-0000-0000-000000000000 bits per pixel: 16 number of planes: 1 type: RGB (packed) depth: 0 red, green, blue masks: 0x1f, 0x3e0, 0x7c00 id: 0x35315652 (RV15) guid: 52563136-0000-0000-0000-000000000000 bits per pixel: 16 number of planes: 1 type: RGB (packed) depth: 0 red, green, blue masks: 0x1f, 0x7e0, 0xf800 id: 0x31313259 (Y211) guid: 59323131-0000-0010-8000-00aa00389b71 bits per pixel: 6 number of planes: 3 type: YUV (packed) id: 0x0 guid: 00000000-0000-0000-0000-000000000000 bits per pixel: 0 number of planes: 0 type: RGB (packed) depth: 1 red, green, blue masks: 0x0, 0x0, 0x0 リストにある形式 (YUV2, YUV12 など) が XVideo のすべての実装で存在するとは限りません。 対応している形式が少ないために、あるプレイヤでは悪影響が出る かもしれないことにも注意してください。 出力が以下のような場合、 X-Video Extension version 2.2 screen #0 no adaptors present あなたのカードはおそらく XVideo に対応していないのでしょう。 あなたのカードが XVideo に対応していないとしても、 このことはあなたのディスプレイでビデオを表示するのに、 計算上の要求を満たすことがより困難になるだけのことです。 しかしながら、あなたのビデオカードおよびプロセッサによっては、 それでも満足のいく性能が得られるかもしれません。 性能を向上させるには をよく読むとよいでしょう。 Simple Directmedia Layer - Simple Directmedia Layer (SDL) は - µsoft.windows;, BeOS そして &unix; の間で + Simple Directmedia Layer (SDL) は、 + さまざまなオペレーティングシステムの間で サウンドとグラフィックスを効果的に利用した クロスプラットホームアプリケーションを 開発することを目的としたレイヤです。 SDL レイヤはハードウェアに対する低レベルの抽象的概念を提供し、 時には X11 インタフェースを使用するよりも効果的なことがあります。 SDL は devel/sdl12 からインストールできます。 Direct Graphics Access Direct Graphics Access は、 プログラムが X サーバを介せず 直接フレームバッファを変更することを可能にする X11 の拡張機能です。 共有メモリを使用するために 低レベルのメモリマッピングが実行できることを期待しているので、 この機能を使うプログラムは root 権限で実行されなければなりません。 DGA 機能拡張は &man.dga.1; によってテストとベンチマークができます。 dga 実行中はキーボードを押せばいつでもディスプレイ色が変更されます。 中止するには q を押します。 ビデオを扱う ports および packages ビデオ ports ビデオ packages この節では Ports Collection で利用可能な、 ビデオの再生に使用できるソフトウェアについて論じます。 ビデオ再生は大変活発なソフト開発分野で、 さまざまなアプリケーションの機能は、 ここでの説明から省かざるをえません。 はじめに、FreeBSD で実行できるビデオアプリケーションの多くは、 Linux アプリケーションとして開発されたということを知ることは重要です。 これらのアプリケーションの多くはまだベータ版の品質です。 FreeBSD でこれらのビデオアプリケーションを使用する際に、 以下のような問題が起こるかもしれません。 あるアプリケーションが、 他のアプリケーションの作成したファイルを再生できない。 あるアプリケーションが、 自身の作成したファイルを再生できない。 二つの異なるマシンで構築した同じアプリケーションが、 同じファイルを再生する挙動がそれぞれ異なる。 イメージサイズ変更のように見たところではありふれたフィルタが、 バグの多いサイズ変更ルーチンによってひどい人工物を作成する。 アプリケーションがよくコアダンプする。 文書が port と一緒にインストールされない (文書は web サイトにあったり、その port の work ディレクトリの中に 残っていることがある)。 これらのアプリケーションの多くはさらに Linux 主義 を主張するかもしれません。 すなわち、アプリケーションの作者が仮定した、 Linux ディストリビューションでのみ実装されている ある標準ライブラリの使用方法や Linux カーネルの特定の機能に起因する問題が生じるかもしれません。 必ずしも port 保守担当者がこれらの問題を把握して作業しているとは限らず、 次のような問題が発生する可能性があります。 プロセッサの特性を検知するための /proc/cpuinfo の利用 本当はプログラムを終了させるはずであるのに、 停止させてしまうようなスレッドの誤用 一般的にアプリケーションとともに使用され、まだ FreeBSD の Ports Collection に収録されていないソフトウェアを必要とする これまで、これらのアプリケーションの開発者は、 移植に必要だったその場しのぎの回避方法を最小化し 問題を解決するために port 保守担当者と協力しています。 MPlayer MPlayer は最近開発され、 急激に成長しつつあるビデオプレイヤです。 MPlayer チームの目的は、 Linux や他の Unix 系 OS 上で高速性と柔軟性をもたらすことです。 このプロジェクトは、 チーム創設者が当時利用可能だったビデオプレイヤの ひどい再生能力にうんざりしたのをきっかけとして始まりました。 合理化された設計のために GUI が犠牲にされたと言う人もいます。 しかしながら、コマンドラインオプションおよびキーボード操作に 一度慣れれば非常によく動作します。 MPlayer の作成 MPlayer 作成 MPlayermultimedia/mplayer にあります。 MPlayer は 構築の際にさまざまなハードウェアのチェックをするため、 あるシステムで作成されたバイナリは、 別のシステムで利用できないかもしれません。 したがって port から構築し、 バイナリパッケージを利用しないことが重要です。 さらに、Makefile や構築のはじめに説明されるように、 make のコマンドラインで多くのオプションを指定することができます。 &prompt.root; cd /usr/ports/multimedia/mplayer &prompt.root; make N - O - T - E Take a careful look into the Makefile in order to learn how to tune mplayer towards you personal preferences! For example, make WITH_GTK1 builds MPlayer with GTK1-GUI support. If you want to use the GUI, you can either install /usr/ports/multimedia/mplayer-skins or download official skin collections from http://www.mplayerhq.hu/homepage/dload.html ほとんどのユーザにとっては port のデフォルトオプションで十分でしょう。 しかしながら、XviD コーデックが必要なら、 WITH_XVID オプションをコマンドラインで指定しなければなりません。 また、デフォルトの DVD デバイスを WITH_DVD_DEVICE オプションで定義することもできます (デフォルトでは /dev/acd0 が使用されます)。 この文書を執筆している時点では、 MPlayer の port は HTML 文書、そして mplayermencoder という二つの実行可能なバイナリを構築します。 mencoder はビデオを再エンコーディングするためのツールです。 MPlayer のための HTML 文書は非常に有益です。この章で不足した ビデオハードウェアおよびインタフェースに関する情報があれば、 MPlayer の文書は非常に詳細な補足になります。 &unix; のビデオ対応情報を探しているのなら、時間を割いて MPlayer の文書を読むべきなのは 明らかです。 MPlayer の使用 MPlayer 使用 MPlayer を使用する人はすべて、 各自のホームディレクトリ内に .mplayer サブディレクトリを用意しなければなりません。 この必要となるサブディレクトリを作成するために、 次のコマンドを入力します。 &prompt.user; cd /usr/ports/multimedia/mplayer &prompt.user; make install-user mplayer のコマンドオプションはマニュアルに記載されています。 さらにより詳細な説明について知りたいなら、HTML 文書をご覧ください。 この節では、一般的な使用法についてほんの少し説明します。 さまざまなビデオインタフェースの一つを用いて testfile.avi というファイルを再生するには、 オプションを指定します。 &prompt.user; mplayer -vo xv testfile.avi &prompt.user; mplayer -vo sdl testfile.avi &prompt.user; mplayer -vo x11 testfile.avi &prompt.root; mplayer -vo dga testfile.avi &prompt.root; mplayer -vo 'sdl:dga' testfile.avi ビデオ再生の相対的性能は多くの要因に依存し、 ハードウェアに応じて著しく変わると思われるので、 これらのオプションをすべて試してみる価値はあるでしょう。 DVD を再生するには、 testfile.avi に置き換えてください。 <N> には再生するタイトル番号を、 DEVICE は DVD-ROM のデバイスノードを指定します。 たとえば、/dev/dvd から 2 番目のタイトルを再生するには以下のようにします。 &prompt.root; mplayer -vo xv dvd://3 -dvd-device /dev/dvd デフォルトの DVD デバイスは、 MPlayer port の構築時に WITH_DVD_DEVICE で定義することができます。 デフォルトでは /dev/acd0 になります。 詳細はこの port の Makefile をご覧ください。 停止、休止、再生などをするにはキーの割り当てを調べてください。 mplayer -h を実行したり、 マニュアルを読めばわかります。 再生に関してさらに重要なオプションがあります。 全画面モードにする オプションと、 性能を向上させる オプションです。 mplayer に指定するコマンドラインが長くなりすぎないように、 .mplayer/config を作成してデフォルトのオプションを設定できます。 vo=xv fs=yes zoom=yes 最後に mplayer は DVD タイトルを .vob ファイルに抽出するのに使用できます。 DVD から 2 番目のタイトルをダンプするには次のようにします。 &prompt.root; mplayer -dumpstream -dumpfile out.vob dvd://2 -dvd-device /dev/dvd 出力された out.vob ファイルは MPEG 形式で、 この節で説明される他のアプリケーションで編集できます。 mencoder mencoder mencoder を使う前に、 HTML 文書を読んでオプションに慣れておくのはよい考えです。 マニュアルもありますが、HTML 文書なしではあまり有用ではありません。 品質向上、低ビットレート、形式変換をする方法が無数にあります。 これらの要素の調節具合で、性能が良かったり悪かったりするなど、 結果に違いが出るかもしれません。 ここにいくつか例を示します。 はじめは単純なファイルのコピーです。 &prompt.user; mencoder input.avi -oac copy -ovc copy -o output.avi コマンドラインオプションを不適切に組合せると、 mplayer でさえ再生できない出力ファイルを作成してしまいます。 したがって、単にファイルを抽出したいときには、 mplayer オプションをつけます。 input.avi を音声に MPEG3 エンコードを使用して MPEG4 コーデックに変換するには次のようにします (audio/lame が必要です)。 &prompt.user; mencoder input.avi -oac mp3lame -lameopts br=192 \ -ovc lavc -lavcopts vcodec=mpeg4:vhq -o output.avi これは mplayerxine で再生可能な出力ファイルを作成します。 DVD タイトルを直接再エンコードするためには、 上記のコマンドラインの input.avi に置き換えて、 root 権限で実行します。 はじめの作業結果に不満をもつと思われるので、 タイトルをファイルにダンプして、ファイルに対して作業することを おすすめします。 xine ビデオプレイヤ xine ビデオプレイヤは オールインワンのビデオソリューションであるだけでなく、 プラグインで拡張できる再利用可能な基本ライブラリと 実行可能なモジュールを提供する広範囲のプロジェクトです。 multimedia/xine の port と package の両方からインストールできます。 xine プレイヤは開発途上であり まだ非常に荒削りですが、通常の利用には十分安定しています。 実用上、xine を使用するには高速なビデオカードとともに高速な CPU があるか、 またはビデオカードが XVideo 拡張に対応していることが必要です。 GUI も利用できますがすこし扱いにくいです。 この文書を執筆している時点では、 xine と一緒に提供されている CSS エンコードされた DVD を再生する入力モジュールはありません。 このモジュールがあるサードパーティの構築物はいくつかありますが、 これらのどれも FreeBSD の Ports Collection には収録されていません。 xineMPlayer と比べて 利用者にとって多くのことをしてくれますが、 と同時にきめの細かい制御ができません。なお、 xine ビデオプレイヤは、 XVideo インタフェース上で最良の性能を発揮します。 デフォルトでは、xine プレイヤは GUI 付きで起動するでしょう。 その後、メニューを使用して特定のファイルを開くことができます。 &prompt.user; xine GUI なしでファイルを直ちに再生するには、 次のコマンドを実行します。 &prompt.user; xine -g -p mymovie.avi transcode ユーティリティ transcode というソフトウェアは、 プレイヤではなくビデオおよびオーディオファイルを再エンコードするためのツール一式です。 transcode を使えば、 stdin/stdout インタフェースとともに コマンドラインツールを用いることによって、 ビデオファイルの統合や、壊れたファイルの修復ができます。 multimedia/transcode port では、数多くのビルドオプションを指定できますが、 以下のコマンドラインのように transcode を構築することをおすすめします。 &prompt.root; make WITH_OPTIMIZED_CFLAGS=yes WITH_LIBA52=yes WITH_LAME=yes WITH_OGG=yes \ WITH_MJPEG=yes -DWITH_XVID=yes ほとんどのユーザにとっては、この設定で十分です。 transcode の能力を示す例として、DivX ファイルを PAL MPEG-1 (PAL VCD) ファイルに変換する使用例を示します。 &prompt.user; transcode -i input.avi -V --export_prof vcd-pal -o output_vcd &prompt.user; mplex -f 1 -o output_vcd.mpg output_vcd.m1v output_vcd.mpa 作成された MPEG ファイル、 output_vcd.mpg は、 MPlayer を使って再生できます。 また、ファイルを CD-R メディアに書き込むことでビデオ CD も作成できます。 この場合には、multimedia/vcdimager および sysutils/cdrdao プログラムをインストールする必要があるでしょう。 transcode のマニュアルもありますが、 transcode wiki から、更なる情報や使用例を得てください。 さらに進んだ情報 FreeBSD 用のさまざまなビデオソフトウェアは急速に成長しています。 近い将来、ここにあげた問題の多くが解決している可能性は高いでしょう。 それまでの間、FreeBSD の A/V 能力を最大限発揮させたい人々は、 FAQ およびチュートリアルから得た知識を寄せ集めて、 わずかなアプリケーションを使用しなければならないでしょう。 この節は、読者に そのような付加的な情報へのポインタを提供するために存在します。 MPlayer の文書 は技術的に非常に有益です。 おそらく、&unix; ビデオの高水準な専門的知識を得たい人はすべて、 これらの文書を調べるべきです。 MPlayer メーリングリストを購読している人たちは、 文書を面倒がって読まない人には、それが誰であれ反感を持ちます。 そのため、彼らにバグ報告をするときには、マニュアルを読んでください。 xine HOWTO にはすべてのプレイヤに一般的な性能向上についての章が含まれています。 最後に、読者が試みるかもしれない 有望なアプリケーションをいくつかあげます。 Avifile. port が multimedia/avifile にあります。 Ogle. port が multimedia/ogle にあります。 Xtheater. multimedia/dvdauthor. DVD コンテンツをオーサリングするためのオープンソースパッケージです。 Josef El-Rayes 原作: Marc Fonvieille 改訂: TV カードの設定 TV カード はじめに TV カードを使用することで、 TV 放送をコンピュータで見ることができます。 これらの多くは RCA コンポジットまたは S-video 入力端子を備えており、 FM ラジオチューナを装備したカードもあります。 &os; は Brooktree Bt848/849/878/879 または Conexant CN-878/Fusion 878a をビデオキャプチャチップに採用した PCI TV カードに &man.bktr.4; ドライバで対応しています。 対応しているチューナを搭載したボードかどうかを &man.bktr.4; マニュアルページの一覧を参照して確認してください。 ドライバの追加 TV カードを使用するために &man.bktr.4; ドライバを読み込む必要があります。 /boot/loader.conf ファイルに以下の行を追加してください。 bktr_load="YES" あるいは、カーネルにドライバを静的に組み込むこともできます。 この場合、次の行をカーネルコンフィギュレーションファイルに追加します。 device bktr device iicbus device iicbb device smbus カードコンポーネントは I2C バス経由で連結されているため、 &man.bktr.4; ドライバに加えてこれらのデバイスドライバが必要になります。 編集したら新しいカーネルを構築し、インストールします。 システムにドライバを追加したら、計算機を再起動してください。 起動時に TV カードは以下のように認識されるでしょう。 bktr0: <BrookTree 848A> mem 0xd7000000-0xd7000fff irq 10 at device 10.0 on pci0 iicbb0: <I2C bit-banging driver> on bti2c0 iicbus0: <Philips I2C bus> on iicbb0 master-only iicbus1: <Philips I2C bus> on iicbb0 master-only smbus0: <System Management Bus> on bti2c0 bktr0: Pinnacle/Miro TV, Philips SECAM tuner. もちろん、これらのメッセージはハードウェアに応じて異なります。 とはいえ、チューナが正しく検知されているかどうか確認するべきです。 &man.sysctl.8; による MIB の設定や、 カーネルコンフィギュレーションファイルオプションで、 検知されたいくつかのパラメータを変更できます。 たとえば、チューナを Philips SECAM チューナとして検知されるようにするには、 カーネルコンフィギュレーションファイルに以下の行を追加します。 options OVERRIDE_TUNER=6 または、直接 &man.sysctl.8; を使用して変更します。 &prompt.root; sysctl hw.bt848.tuner=6 利用可能なオプションの詳細については &man.bktr.4; マニュアルページおよび /usr/src/sys/conf/NOTES ファイルを参照してください。 便利なアプリケーション TV カードを使用するためには、以下のアプリケーションの一つをインストールする必要があります。 multimedia/fxtv はウィンドウ内に TV 映像を映します。 画像/音声/ビデオを取り込むこともできます。 multimedia/xawtv も TV アプリケーションです。 fxtv と同様の機能があります。 misc/alevt は文字放送 (ビデオテキスト/テレテキスト) のデコードと表示をします。 audio/xmradio は TV カードに搭載された FM ラジオチューナを使用するためのアプリケーションです。 audio/wmtune はラジオチューナのためのお手軽なデスクトップアプリケーションです。 他にも多くのアプリケーションが &os; Ports Collection に収録されています。 トラブルシューティング TV カードに関する問題が起きたときには、 &man.bktr.4; ドライバが本当にビデオキャプチャチップおよびチューナに 対応しているか、オプションが正しく設定されているかどうかをまず確認してください。 TV カードに関するサポートやさまざまな質問に関しては、 &a.multimedia.name; メーリングリストに参加したり、 過去のアーカイブを検索してみてください。 MythTV MythTV はオープンソースの PVR ソフトウェアプロジェクトです。 このアプリケーションは、たくさんのアプリケーションやライブラリに依存するため、 &linux; の世界ではインストールが難しいアプリケーションとして認識されています。 &os; ports システムは、インストールのほとんどのプロセスを自動化しますが、 ある部分は手動で設定しなければなりません。 この章は、MythTV の設定を助けるためのガイドです。 ハードウェア MythTV は、エンコーダやチューナなどのビデオ入力デバイスへのアクセスに V4L を用いるように設計されています。 現時点では、multimedia/webcamd によりサポートされている USB DVB-S/C/T カードにおいて最もよく動作します。 なぜならば、webcamd は、V4L ユーザランドアプリケーションを提供するためです。 webcamd に対応している DVB カードは、MythTV で動作するはずです。 動作することが知られているカードの一覧が ここ にあります。 Hauppauge カードもまた、 multimedia/pvr250 および multimedia/pvrxxx package として利用可能ですが、 標準的ではないドライバのインタフェースを提供しており、 0.23 より後の MythTV では動作しません。 HTPC は、DVB ドライバのすべての一覧を提供しています。 依存性 MythTV は、柔軟で、モジュール化されており、 異なるコンピュータでフロントエンドとバックエンドを利用できます。 フロントエンドとしては x11/xorg の X サーバとともに multimedia/mythtv-frontend が必要です。 フロントエンドコンピュータは、XvMC に対応しているビデオカードを持ち、オプションとして、LIRC 互換のリモートコントローラを持っていることが理想的です。 バックエンドでは、&mysql; データベースとともに multimedia/mythtv が必要です。 オプションで、録音のためにはチューナ、ストレージが必要です。 &mysql; package は、multimedia/mythtv のインストール時に、 依存として自動的にインストールされます。 MythTV の設定 以下のステップで、MythTV をインストールしてください。 まず &os; Ports Collection を用いて、 MythTV をインストールしてください。 &prompt.root; cd /usr/ports/multimedia/mythtv &prompt.root; make install MythTV データベースを設定してください。 &prompt.root; mysql -uroot -p < /usr/local/share/mythtv/database/mc.sql バックエンドを設定してください。 &prompt.root; mythtv-setup バックエンドを起動してください。 &prompt.root; echo 'mythbackend_enable="YES"' >> /etc/rc.conf &prompt.root; service mythbackend start Marc Fonvieille 寄稿: 画像スキャナ 画像スキャナ はじめに &os; では、画像スキャナに対するアクセスは SANE (Scanner Access Now Easy) API によって実現されており、 &os; Ports Collection でも提供されています。 SANE はスキャナのハードウェアにアクセスするために &os; デバイスドライバを使用します。 &os; は SCSI 接続および USB 接続のスキャナのどちらにも対応しています。 設定を始める前に、 SANE がスキャナに対応しているか確認してください。 SANE には スキャナについての情報とその状況がまとめられている 対応デバイスの一覧 があります。 カーネルのコンフィグレーション 前述のように、&os; はスキャナのインタフェースとして SCSI と USB の両方に対応しています。 スキャナのインタフェースによって、必要となるドライバが異なります。 USB インタフェース GENERIC カーネルにはデフォルトで USB スキャナに対応するためのデバイスドライバが搭載されています。 カスタムカーネルを使用する際には、 以下の行がカーネルコンフィグレーションファイルにあることを 確認してください。 device usb device uhci device ohci device ehci 適切なドライバを組み込んだカーネルで再起動後、 USB スキャナをシステムに接続します。 すると、メッセージバッファ (&man.dmesg.8;) にスキャナが認識されたことを示すメッセージが出力されます。 ugen0.2: <EPSON> at usbus0 これらの例では、スキャナが /dev/ugen0.2 デバイスノードを使用していることがわかります。 この例では、&epson.perfection; 1650 USB スキャナが使われています。 SCSI インタフェース スキャナに付属しているインタフェースが SCSI であれば、 重要なのはどの SCSI ボードを使用すればよいか把握することです。 使用する SCSI チップセットによって、 カーネルコンフィグレーションファイルを調整する必要があります。 GENERIC カーネルは 一般に使用される SCSI コントローラのほとんどに対応しています。 NOTES ファイルを読んで、 適切な行をカーネルコンフィグレーションファイルに追加してください。 また、SCSI アダプタドライバに加えて、 以下の行をカーネルコンフィグレーションファイルに 記述する必要があります。 device scbus device pass カーネルを適切にコンパイルしてインストールすると、 システムの起動時にデバイスがメッセージバッファに出力されるはずです。 pass2 at aic0 bus 0 target 2 lun 0 pass2: <AGFA SNAPSCAN 600 1.10> Fixed Scanner SCSI-2 device pass2: 3.300MB/s transfers システムを起動する際にスキャナの電源を入れてなければ、 &man.camcontrol.8; コマンドを使用して SCSI バスをスキャンし、 以下のように手動でデバイスを検出させることもできます。 &prompt.root; camcontrol rescan all Re-scan of bus 0 was successful Re-scan of bus 1 was successful Re-scan of bus 2 was successful Re-scan of bus 3 was successful すると、スキャナは SCSI デバイスの一覧に現れるでしょう。 &prompt.root; camcontrol devlist <IBM DDRS-34560 S97B> at scbus0 target 5 lun 0 (pass0,da0) <IBM DDRS-34560 S97B> at scbus0 target 6 lun 0 (pass1,da1) <AGFA SNAPSCAN 600 1.10> at scbus1 target 2 lun 0 (pass3) <PHILIPS CDD3610 CD-R/RW 1.00> at scbus2 target 0 lun 0 (pass2,cd0) SCSI デバイスについての詳細は、&man.scsi.4; および &man.camcontrol.8; のマニュアルページをご覧ください。 SANE の設定 SANE システムは、 二つの部分、すなわちバックエンド (graphics/sane-backends) とフロントエンド (graphics/sane-frontends) に分割されています。 バックエンドはスキャナそのものに対するアクセスを提供します。 SANE 対応デバイスの一覧 には、どのバックエンドが画像スキャナに対応しているかが記載されています。 デバイスを使用するためには、正しいバックエンドを決定するのは必須です。 また、フロントエンドはグラフィカルなスキャニングインタフェース (xscanimage) を提供します。 はじめに、 graphics/sane-backends の port または package をインストールしましょう。 次に、sane-find-scanner コマンドを使用して、 SANE システムで使用するバックエンドを検出します。 &prompt.root; sane-find-scanner -q found SCSI scanner "AGFA SNAPSCAN 600 1.10" at /dev/pass3 この出力から、 スキャナインタフェースの種類と システムに接続されているスキャナが使用するデバイスノードがわかります。 ベンダ名や製品のモデル名は表示されないかも知れませんが、 重要ではありません。 USB スキャナではファームウェアを読み込む必要がある場合があります。 これはバックエンドのマニュアルページで説明されています。 &man.sane-find-scanner.1; と &man.sane.7; のマニュアルページも読んでください。 スキャナがフロントエンドで認識されるか調べてみましょう。 デフォルトでは、SANE のバックエンドには &man.scanimage.1; と呼ばれるコマンドラインツールが付属します。 このコマンドを使用すると、 デバイスの一覧を表示したり画像を取得することができます。 オプションを使うと、 スキャナデバイスの一覧が出力されます。 &prompt.root; scanimage -L device `snapscan:/dev/pass3' is a AGFA SNAPSCAN 600 flatbed scanner また、 で使用した USB スキャナの例では、以下の出力が得られるでしょう。 &prompt.root; scanimage -L device 'epson2:libusb:/dev/usb:/dev/ugen0.2' is a Epson GT-8200 flatbed scanner これは、&os; 8.X システムでの出力例であり、 'epson2:libusb:/dev/usb:/dev/ugen0.2' から、 使用しているスキャナのバックエンド名 (epson2) とデバイスノード (/dev/ugen0.2) の情報を得ることができます。 何も出力が得られなかったり、 スキャナが見つからなかったというメッセージが表示されたら、 &man.scanimage.1; はスキャナを認識できなかったのでしょう。 このような場合は、バックエンドの設定ファイルを編集し、 使用するスキャナデバイスを定義する必要があります。 /usr/local/etc/sane.d/ ディレクトリには、 バックエンドが使用するすべての設定ファイルがあります。 このデバイスの認識による問題は、 特定の USB スキャナで発生するものです。 たとえば、 で使用した USB スキャナは、 &os; 8.X において正常に認識され動作します。 しかし、それより前のバージョンの (&man.uscanner.4; ドライバを利用する) &os; では、 sane-find-scanner コマンドを実行すると、以下のような情報が得られます。 &prompt.root; sane-find-scanner -q found USB scanner (UNKNOWN vendor and product) at device /dev/uscanner0 スキャナは正しく検出されました。 USB インタフェースを使用し、 /dev/uscanner0 デバイスノードに接続されていることがわかります。 次に、スキャナが正しく認識されているかどうか確認してみましょう。 &prompt.root; scanimage -L No scanners were identified. If you were expecting something different, check that the scanner is plugged in, turned on and detected by the sane-find-scanner tool (if appropriate). Please read the documentation which came with this software (README, FAQ, manpages). スキャナが認識されなかったので、 /usr/local/etc/sane.d/epson2.conf ファイルを編集する必要があります。 このスキャナのモデルは &epson.perfection; 1650 なので、 epson2 バックエンドを使用すればいいことがわかります。 バックエンドの設定ファイルに書かれているコメントを必ず読んでください。 設定ファイルを変更するのは非常に簡単です。 使用しているスキャナには不適切なインタフェースをすべてコメントアウトし (今回の場合は、USB インタフェースを使用するので scsi という語で始まる行をすべてコメントアウトします)、 ファイルの末尾に使用するインタフェースとデバイスノードを追加します。 この例では、以下の行を追加しました。 usb /dev/uscanner0 詳細と使用すべき構文は、 バックエンドのマニュアルページはもちろんのこと、 バックエンドの設定ファイルに書かれているコメントも読んでください。 以上の設定で、スキャナが認識されたかどうかを確認できます。 &prompt.root; scanimage -L device `epson:/dev/uscanner0' is a Epson GT-8200 flatbed scanner USB スキャナが認識されました。 ブランドやモデルがスキャナに一致しなかったとしても、それほど重要ではありません。 着目すべきは `epson:/dev/uscanner0' という部分で、 バックエンド名とデバイスノードが正しく認識されていることがわかります。 scanimage -L コマンドを実行してスキャナが認識されたことがわかれば、設定は終了です。 デバイスはスキャンする準備ができました。 &man.scanimage.1; コマンドを使用すると コマンドラインから画像を取得することができます。その一方で、 GUI を使用して画像を取得できると一層良いでしょう。 SANE は、簡素ですが役に立つグラフィカルなインタフェース xscanimage (graphics/sane-frontends) を提供しています。 Xsane (graphics/xsane) はもう一つのグラフィカルなスキャニングフロントエンドで、 人気があります。 Xsane には、さまざまなスキャニングモード (写真、FAX など)、 色補正、バッチスキャンなど先進的な機能があります。 これらのアプリケーションの両方とも GIMP のプラグインとして使用することができます。 他のユーザがスキャナにアクセスすることを許可する 前述の操作には、 すべて root 権限が必要となります。 しかしながら、他のユーザがスキャナに アクセスできるようにすることも可能です。 そのためには、スキャナが使用するデバイスノードへの 読み込み権限と書き込み権限をユーザに与えます。 一例として、USB スキャナが、/dev/ugen0.2 デバイスノードを使用しているものとします。 このデバイスノードは、 /dev/usb/0.2.0 へのシンボリックリンクです (/dev ディレクトリを調べると、 簡単に確認できます)。 シンボリックリンクとデバイスノードは、 それぞれ wheel および operator グループが所有しています。 ユーザ joe を これらのグループに加えると、彼はスキャナを使用できるようになります。 もちろん、ユーザをどんなグループ (特にグループ wheel) に追加する時はいつでも、 セキュリティ上の理由から二度は検討を行うべきです。 良い方法は、USB デバイスを利用するためにグループを作成し、 このグループに対してスキャナデバイスを利用できるようにすることです。 例として、usb という名前のグループを使用します。 まず最初に、&man.pw.8; コマンドを使ってグループを作成します。 &prompt.root; pw groupadd usb その後、シンボリックリンク /dev/ugen0.2 および、/dev/usb/0.2.0 デバイスノードに対して、 usb グループが利用できるように適切な許可属性 (0660 または 0664) を設定する必要があります。 デフォルトでは、これらのファイルの所有者 (root) のみが書き込み可能です。 /etc/devfs.rules に次の行を追加してください。 [system=5] add path ugen0.2 mode 0660 group usb add path usb/0.2.0 mode 0666 group usb 最後に、スキャナを利用するユーザを usb グループに追加します。 &prompt.root; pw groupmod usb -m joe 詳細については、&man.pw.8; のマニュアルページをご覧ください。