Openbox
Openbox は軽量で設定が自由なスタック型ウィンドウマネージャです。デスクトップ環境とは独立して動作させることも、KDE や Xfce など他のデスクトップ環境に入っているウィンドウマネージャの代替として使うことも可能です。LXDE デスクトップ環境は Openbox を初めから組み込んでいます。
Openbox の機能については、公式ウェブサイト にドキュメントがあります。この記事では Arch Linux での Openbox のインストールに関して扱います。
目次
インストール
公式リポジトリから openbox をインストールしてください。
Openbox の起動
スタンドアロン
Openbox は単独のウィンドウマネージャ (WM) として使うことができます。デスクトップ環境と一緒に Openbox を使うよりもインストールや設定はシンプルになります。openbox だけを使うことは CPU やメモリの使用量を減らすこともできます。
Openbox をスタンドアロンのウィンドウマネージャとして実行するには、以下を ~/.xinitrc
に追加してください:
exec openbox-session
logind (や consolekit) セッションの維持などについては xinitrc を見て下さい。
以前に他のウィンドウマネージャ (Xfwm 等) を使っていて、Openbox が起動しないときは、autostart フォルダを削除してみてください:
mv ~/.config/autostart ~/.config/autostart.bak
他のデスクトップ環境
デスクトップ環境のネイティブのウィンドウマネージャを Openbox で置き換えるときは、Openbox に (透過などの) コンポジット効果が存在しないことに注意してください。#コンポジット効果 を参照。
GNOME
GNOME Shell
は mutter のプラグインであり、Openbox で使うことはできません。Openbox は GNOME アプリケーションで動作しません (GTK+ を参照) [1]。
KDE
KDE#KDE/Openbox Session を見て下さい。
Xfce
Xfce#デフォルトウィンドウマネージャ を見て下さい。
MATE
MATE#MATE で他のウィンドウマネージャを使う を見て下さい。
設定
XDG
アプリケーションを自動実行するのに、Openbox はローカルの ~/.config/openbox/autostart
ファイルだけでなく、パッケージによってグローバルな /etc/xdg/autostart
ディレクトリに自動的にインストールされた .desktop
ファイルも読み込みます。python2-xdg は Openbox の xdg-autostart に必要です。
例えば、NetworkManager のアプレット (nm-applet) などをローカルで自動実行を行っていて、後で python2-xdg をインストールしていた場合、グローバルな XDG .desktop
ファイルが読み込まれることになり、結果としてシステムトレイに2つアイコンが表示されてしまいます。したがって、python2-xdg を明示的にインストールしておいて、インストールしたときに自動的にアプリケーションが自動実行されるようにしておくのを推奨します。
Downloads
, Documents
などの Home
フォルダが存在しない場合は Xdg ユーザーディレクトリを見て下さい。
Openbox
Openbox の基本的な設定は主に4つのファイルを使って行い、それぞれに固有の役割があります: rc.xml
, menu.xml
, autostart
, environment
。これらのファイルの詳細は以下で記述していますが、Openbox の設定を始めるには、まず (特定のユーザーアカウントの) ローカルの Openbox プロファイルを作成する必要があります。グローバルな /etc/xdg/openbox
プロファイル (全てのユーザーに適用されます) をテンプレートとしてコピーすることで作成できます:
$ cp -R /etc/xdg/openbox ~/.config/
rc.xml
~/.config/openbox/rc.xml
はメインの設定ファイルです。以下の設定を定義します:
- キーボードショートカット (例: アプリケーションの起動やボリュームのコントロール)
- テーマ
- デスクトップと仮想デスクトップの設定
- アプリケーションウィンドウの設定
このファイルにはあらかじめ設定がされており、個人的な好みで修正するほかは既存の内容に変更を加える必要はありません。
~/.config/openbox/menu.xml
はデスクトップを右クリックしたときに表示されるメニューの中身を定義するファイルです。デフォルトのメニューは静的なメニュー (新しいアプリケーションをインストールしてもメニューが更新されない) ですが、自動的に更新されるダイナミックメニューを使うこともできます。
メニューについては下のメニューセクションで詳しい説明をしています。
autostart
~/.config/openbox/autostart
には Openbox セッションが開始したときにどのアプリケーションを起動するか記述します。
コマンドはアンパサンド (&
) を付けて終了する必要があります。コマンドにアンパサンドが付いていないと、それから先に記述されたコマンドが実行されなくなります。
また、autostart ファイルではコマンドの実行を遅延させることを推奨します。そうしないと全てのコマンドが同時に実行されることになり、結果的にアイテムが起動しなくなることがあります。コマンドの実行を遅延させるには以下のような形式で記述します:
(sleep <number of seconds>s && <command>) &
例えば、Conky の実行を3秒だけ遅らせたい場合、コマンドは以下の通りです:
(sleep 3s && conky) &
environment
~/.config/openbox/environment
では以下のような環境変数を設定するのに使います:
- 新しいパスの定義 (例: パスを必要とする実行コマンド)
- 言語設定の変更
- 他の使用される変数 (例: GTK テーマの修正)
GUI 設定パッケージ
Openbox デスクトップを簡単に設定するための GUI が複数存在します。公式リポジトリには以下の GUI が含まれています:
- ObConf — Openbox ウィンドウマネージャのための GTK2 ベースの設定ツール。
- LXAppearance ObConf — Openbox を設定するための LXAppearance のプラグイン。
- LXInput — LXDE のキーボード・マウス設定。
- LXRandR — LXDE のモニター設定。
- obkey — Openbox のキーボードショートカットを設定。
- ob-autostart — Openbox のためのシンプルな自動起動アプリケーション。
Openbox のデスクトップメニューを設定するアプリケーションについてはメニューセクションを見て下さい。
Openbox の再設定
Openbox は常に設定ファイルの変更をセッションに反映させるわけではありません。そのため、設定ファイルを編集したら手動でリロードする必要があります。再設定を行うには、次のコマンドを実行してください:
$ openbox --reconfigure
上のコマンドを実行するキーバインドを ~/.config/openbox/rc.xml
に追加すれば、いちいちターミナルを開く必要がなくなります。例えば Super
+F11
キーバインドを使用する場合:
<keybind key="W-F11"> <action name="Reconfigure"/> </keybind>
キーバインド
全てのキーバインドは ~/.config/openbox/rc.xml
ファイルの <!-- Keybindings for running aplications -->
の下に追加します。ここでは簡単な説明をするにとどめるので、キーバインドの詳しい説明は openbox.org を読んで下さい。
特殊なキー
基本的な英数字キーをキーバインドに使うのはわかりやすいですが modifers
, multimedia
, navigation
キーなど他のタイプのキーには特殊な名前が割り当てられています。
修飾キー
Modifer
キーにはキーバインドで重要な役割があります (例: shift
や CTRL / control
キーを押しながら他のキーを押すことでアクションを実行する)。修飾キーを使うことでキーバインドの衝突を減らし、同一のキーに複数のアクションを指定することができます。修飾キーと他のキーを使う場合の構文は:
"<modifier>-<key>"
modifer のコードは以下の通りです:
S
: ShiftC
: Control / CTRLA
: AltW
: Super / WindowsM
: MetaH
: Hyper (If it is bound to something)
例えば、以下のコードは super
と t
で lxterminal を起動します:
<keybind key="W-t"> <action name="Execute"> <command>lxterminal</command> </action> </keybind>
マルチメディアキー
ボリュームや画面の明るさの調整など、適切な multimedia
キーで予期した操作が実行されるように設定することが可能です。通常はマルチメディアキーは function
キーに統合されますが、適当なシンボルで識別できます。詳しくは特別なキーボードキーを見て下さい。
ボリュームと輝度のマルチメディアキーは以下の通りです (マルチメディアキーを機能させるにはコマンドを割り当てる必要があります):
XF86AudioRaiseVolume
: ボリュームを上げるXF86AudioLowerVolume
: ボリュームを下げるXF86AudioMute
: ボリュームをミュート / ミュート解除XF86MonBrightnessUp
: 画面の明るさを上げるXF86MonBrightnessDown
: 画面の明るさを下げる
上記のキーを ~/.config/openbox/rc.xml
で使用する例は下にあります。
ナビゲーションキー
矢印キーは通常、カーソルを上下左右に動かすのに使われます。navigation のコードは以下の通りです:
Up
: 上Down
: 下Left
: 左Right
: 右
ボリュームコントロール
音量のコントロールにどのコマンドを使うかは、サウンドシステムとして ALSA, PulseAudio, OSS のどれを使っているかによって変わってきます。
ALSA
ALSA を使って音声を鳴らしている場合、(alsa-utils パッケージに入っている) amixer
プログラムを使ってボリュームを調整することができます。以下はボリューム調整用の multimedia
キーを使ってボリュームを +/- 5% で調整する例です (調整量は変更できます):
<keybind key="XF86AudioRaiseVolume"> <action name="Execute"> <command>amixer set Master 5%+ unmute</command> </action> </keybind> <keybind key="XF86AudioLowerVolume"> <action name="Execute"> <command>amixer set Master 5%- unmute</command> </action> </keybind> <keybind key="XF86AudioMute"> <action name="Execute"> <command>amixer set Master toggle</command> </action> </keybind>
Pulseaudio
ALSA をバックエンドにして PulseAudio を使用している場合、amixer
プログラムのコマンドを以下のように修正します:
<keybind key="XF86AudioRaiseVolume"> <action name="Execute"> <command>amixer -D pulse set Master 5%+ unmute</command> </action> </keybind> <keybind key="XF86AudioLowerVolume"> <action name="Execute"> <command>amixer -D pulse set Master 5%- unmute</command> </action> </keybind> <keybind key="XF86AudioMute"> <action name="Execute"> <command>amixer -D pulse set Master toggle</command> </action> </keybind>
OSS
OSS を使っている場合、特定のミキサーを上げ下げできるキーバインドを作成することができます。これによって、例えば全体のシステムボリュームを変更せずに特定のアプリケーション (オーディオプレイヤーなど) のボリュームを変えることが可能です。この場合、OSS のミキサーを使うようにアプリケーションを設定する必要があります。
以下の例では、OSS のミキサーを使って、1デシベル単位でボリュームを上げ下げするように MPD を設定しています。ossmix
コマンドの後に --
が追加されるのは負の値が引数として扱われないようにするためです:
<keybind key="[chosen keybind]"> <action name="Execute"> <command>ossmix -- mpd +1</command> </action> </keybind> <keybind key="[chosen keybind]"> <action name="Execute"> <command>ossmix -- mpd -1</command> </action> </keybind>
メディアプレイヤーの操作
playerctlAUR コマンドラインユーティリティを使ってマルチメディアキーをプレイヤーのアクションに結びつけることができます。ほとんどのメディアプレイヤーで動作するはずです。
<keybind key="XF86AudioPlay"> <action name="Execute"> <command>playerctl play</command> </action> </keybind> <keybind key="XF86AudioPause"> <action name="Execute"> <command>playerctl pause</command> </action> </keybind> <keybind key="XF86AudioNext"> <action name="Execute"> <command>playerctl next</command> </action> </keybind> <keybind key="XF86AudioPrev"> <action name="Execute"> <command>playerctl previous</command> </action> </keybind>
明るさ調整
画面の明るさを調整するには xbacklight
プログラムを使います。このプログラムは Xorg に含まれています。以下の例では、画面の明るさをコントロールするための multimedia
キーを使って +/- 10% で設定を調整します:
<keybind key="XF86MonBrightnessUp"> <action name="Execute"> <command>xbacklight +10</command> </action> </keybind> <keybind key="XF86MonBrightnessDown"> <action name="Execute"> <command>xbacklight -10</command> </action> </keybind>
ウィンドウのスナップ
多数のデスクトップ環境やウィンドウマネージャはウィンドウのスナップ (例: Windows 7 の Aero スナップ) をサポートしています。画面の端に移動された時に自動的にウィンドウの大きさが変更されます。ウィンドウに関するキーバインドを使用することで Openbox でもこの効果を再現することが可能です。
As illustrated in the example below, percentages must be used to determine window sizes (see openbox.org for further information). In this instance, The super
key is used in conjunction with the navigation
keys:
<keybind key="W-Left"> <action name="UnmaximizeFull"/> <action name="MaximizeVert"/> <action name="MoveResizeTo"> <width>50%</width> </action> <action name="MoveToEdge"><direction>west</direction></action> </keybind> <keybind key="W-Right"> <action name="UnmaximizeFull"/> <action name="MaximizeVert"/> <action name="MoveResizeTo"> <width>50%</width> </action> <action name="MoveToEdge"><direction>east</direction></action> </keybind>
However, it should be noted that once a window has been 'snapped' to an edge, it will remain vertically maximised unless subsequently maximised and then restored. The solution is to implement additional keybinds - in this instance using the down
and up
keys - to do so. This will also make pulling 'snapped' windows from screen edges faster as well:
<keybind key="W-Down"> <action name="Unmaximize"/> </keybind> <keybind key="W-Up"> <action name="Maximize"/> </keybind>
Ubuntu フォーラムのスレッド に詳しい情報が載っています。AUR からインストールできる opensnap-gitAUR などのアプリケーションはキーバインドを使わずにウィンドウのスナップを自動的にシミュレートします。
デスクトップメニュー
デスクトップメニューにアクセスするキーバインドを作成することもできます。例えば、以下のコードは CTRL
+ m
を押すことでメニューが表示されるようにします:
<keybind key="C-m"> <action name="ShowMenu"> <menu>root-menu</menu> </action> </keybind>
メニュー
Openbox では3つのタイプのメニューを使うことができます: static
, pipes
(dynamic), generators
(static または dynamic)。どれか一つだけを使うこともできますし組み合わせることも可能です。
Static
名前の通り、デフォルトのメニュータイプであり決して変更されることがありません。手動で編集したり、適切なソフトウェアパッケージを使って自動で生成することが可能です。
Fast and efficient, while this type of menu can be used to select applications, it can also be useful to access specific functions and/or perform specific tasks (e.g. desktop configuration), leaving the access of applications to another process (e.g. the synapse or xfce4-appfinder applications).
~/.config/openbox/menu.xml
ファイルが static デスクトップメニューの唯一の設定ファイルです。
menumaker は Openbox, Fluxbox, IceWM, Xfce など複数のウィンドウマネージャに対応した xml
メニューを自動で作成します。MenuMaker はあなたのコンピュータにある実行可能ファイルを検索して、その結果からメニューファイルを作成します。特定のアプリケーション (GNOME, KDE など) を省くように設定することも可能です。
インストールして実行すると、新しい ~/.config/openbox/menu.xml
ファイルが生成されます。既存のファイルが上書きされないようにするには、次を実行:
$ mmaker -v OpenBox3
もしくは、既存のファイルを上書きしたい場合は、force
引数を追加 (f
):
$ mmaker -vf OpenBox3
新しい ~/.config/openbox/menu.xml
ファイルが作成されたら、手動で編集しても良いですし、obmenu などの GUI のメニューエディタを使って設定を行ってもかまいません。
obmenu は ~/.config/openbox/menu.xml
を編集するためのユーザーフレンドリな GUI アプリケーションで、xml
のコードを編集したくない人にうってつけでしょう。
archlinux-xdg-menu は Openbox を含む、様々なウィンドウマネージャのメニューを /etc/xdg/
ディレクトリに含まれている xdg
ファイルから自動で作成することができます。詳しくは Xdg-menu#OpenBox を見て下さい。
ログアウトメニューのオプション
The ~/.config/openbox/menu.xml
file can be edited in order to provide a sub-menu with the same options as provided by oblogout. The sample script below will provide all of these options, with the exception of the ability to lock the screen:
<menu id="exit-menu" label="Exit"> <item label="Log Out"> <action name="Execute"> <command>openbox --exit</command> </action> </item> <item label="Shutdown"> <action name="Execute"> <command>systemctl poweroff</command> </action> </item> <item label="Restart"> <action name="Execute"> <command>systemctl reboot</command> </action> </item> <item label="Suspend"> <action name="Execute"> <command>systemctl suspend</command> </action> </item> <item label="Hibernate"> <action name="Execute"> <command>systemctl hibernate</command> </action> </item> </menu>
Once the entries have been composed, add the following line to present the sub-menu where desired within the main desktop menu (usually as the last entry):
<menu id="exit-menu"/>
Pipes
このタイプのメニューは基本的にスクリプトで、実行時に即座に更新される動的なリストを提供します。リストが使用される目的は複数あり、アプリケーションを一覧したり、情報を表示したり、機能を制御したりします。定義済みのパイプメニューをインストールすることができますが、公式リポジトリには存在しません。上級者であればカスタムスクリプトを作成・修正することができます。また、~/.config/openbox/menu.xml
には複数のパイプメニューを定義することができます。
サンプル
- openbox-xdgmenuAUR: xdg-menu を xml-pipe-menu に変換
- obfilebrowserAUR: アプリケーションとファイルブラウザ
- obdevicemenuAUR: udisks によるリムーバルメディアの管理
- wifi pipe menu: Netctl による無線ネットワーク
Openbox.org にも様々なパイプメニューのリストが載っています。
Generators
このタイプのメニューは Xfce や LXDE などのデスクトップ環境で使われているタスクバーに似ています。このタイプのメニューは自動的に更新され、強力でとても便利です。カスタムカテゴリやメニューエントリを追加することもできます。使用するダイナミックメニューのドキュメントを読んで下さい。
メニュージェネレータは ~/.config/openbox/menu.xml
ファイルから実行する必要があります。
obmenu-generatorAUR は非公式パッケージながら強く推奨されています。静的または動的なメニューとして使うことができ、細かくカスタマイズすることが可能です。メニューのカテゴリや個々のエントリは簡単に非表示にすることができ、カスタマイズしたり追加するのもお茶の子さいさい。詳しい説明やスクリーンショットが 公式ホームページ にあります。
Below is an example of how obmenu-generator would be dynamically executed without icons in ~/.config/openbox/menu.xml
:
<?xml version="1.0" encoding="utf-8"?> <openbox_menu> <menu id="root-menu" label="OpenBox 3" execute="/usr/bin/obmenu-generator"> </menu> </openbox_menu>
To automatically iconify entries, the -i
option would be added:
<menu id="root-menu" label="OpenBox 3" execute="/usr/bin/obmenu-generator -i">
openbox-menuAUR は LXDE プロジェクトによる menu-cache を使って Openbox のダイナミックメニューを作成します。詳細については 公式ホームページ を見て下さい。
ObmenugenAUR を使うことで .desktop
ファイルから静的なまたは動的なアプリケーションメニューを生成することができます。詳しくは 公式ホームページ を見て下さい。
メニューアイコン
メニューエントリの横にアイコンを表示するには、~/.config/openbox/rc.xml
ファイルの <menu>
セクションでアイコンを有効にする必要があります:
<applicationIcons>yes</applicationIcons>
Where using a static menu, it will then be necessary to edit the ~/.config/openbox/menu.xml
file to provide both the icon =
command, along with the full path and icon name for each entry. An example of the syntax used to provide an icon for a category is:
<menu id="apps-menu" label="[label name]" icon="[pathway to icon]/[icon name]">
デスクトップメニューをパネルメニューとして使う
xdotool is a package that can issue commands to simulate key presses / keybinds, meaning that it is possible to use it to invoke keybind-related actions without having to actually press their assigned keys. As this includes the ability to invoke an assigned keybind for the Openbox desktop menu, it is therefore possible to use XDoTool to turn the Openbox desktop menu into a panel menu. Especially where the desktop menu is heavily customised and feature-rich, this may prove very useful to:
- Replace an existing panel menu
- Implement a panel menu where otherwise not provided or possible (e.g. for tint2-gitAUR)
- Compensate where losing access to the desktop menu due to the use of an application like xfdesktop to manage the desktop.
Once XDoTool has been installed - if not already present - it will be necessary to create a keybind to access the root menu in ~/.config/openbox/rc.xml
, and again below the <!-- Keybindings for running aplications -->
heading. For example, the following code will bring up the menu by pressing CTRL
+ m
:
<keybind key="C-m"> <action name="ShowMenu"> <menu>root-menu</menu> </action> </keybind>
Openbox must then be re-configured. In this instance, XDoTool will be used to simulate the CTRL
+ m
keypress to access the desktop menu with the following command (note the use of +
in place of -
):
xdotool key control+m
How this command may be used as a panel launcher / icon is largely dependent on the features of panel used. While some panels will allow the above command to be executed directly in the process of creating a new launcher, others may require the use of an executable script. As an example, a custom executable script called obpanelmenu.sh
will be created in the ~/.config
folder:
$ text editor ~/.config/obpanelmenu.sh
Once the empty file has been opened, the appropriate XDoTool command must be added to the empty file (i.e. to simulate the CTRL
+ m
keypress for this example):
xdotool key control+m
After the file has been saved and closed, it may then be made into an executable script with the following command:
$ chmod +x ~/.config/obpanelmenu.sh
Executing it will bring up the Openbox desktop menu. Consequently, where using a panel that supports drag-and-drop functionality to add new launchers, simply drag the executable script onto it before changing the icon to suit personal taste. For instructions on how to use this executable script with tint2-svnAUR - a derivative of the popular tint2 panel that allows launchers to be added - see Tint2-Svn launchers.
デスクトップテーマ
大量の Openbox 専用の GTK+ テーマと、汎用の Openbox 対応の GTK+ テーマが存在し、ウィンドウ装飾やデスクトップメニューの外観を変更することができます。汎用のテーマは様々なデスクトップ環境やウィンドウマネージャでも利用できるように作られており、その中に Openbox も含まれています。例は パッケージの説明 を見て下さい。
設定
GTK テーマを選択したり設定するには obconf や lxappearance-obconf を使います。VirtualBox や Skype など Qt ベースのアプリケーションのテーマについての情報は Qt と GTK アプリケーションの外観の統合を見て下さい。
インストール: 公式リポジトリと AUR
公式リポジトリの openbox-themes パッケージに様々なテーマが入っています。
公式リポジトリや AUR からインストールした Openbox のテーマは /usr/share/themes
ディレクトリに自動的にインストールされます。すぐに選択することが可能です。
インストール: 他のソース
box-look.org is an excellent and well-established source of themes. deviantART.com is another excellent resource. Many more can be found through the utilisation of a search engine.
トラブルシューティング
稀に、以下の2つの問題が発生することがあります。特にサポートされないウェブサイトからテーマをダウンロードしたときに発生します。
テーマが使えない
If for any reason the newly extracted theme cannot be selected, open the theme directory to first ensure that it is indeed compatible with Openbox by determining that an openbox-3
directory is present, and that within this directory a themerc
file is also present. An .obt
(OpenBox Theme) file may also be present in some instances, which can then be manually loaded in obconf.
Where expected files and directories are present and correct, then on occasion it is possible that the theme author has not correctly set permission to access the file (e.g. permission may still be for the account of the author, rather than for root). To eliminate this possibility, ensure the folder and file permissions are for root:
# chown -R root /user/share/themes
テーマの見た目が壊れている
Of course, the first line of enquiry would be to check that it is not just a badly made, broken theme! Otherwise, ensure that the Openbox GTK fix has been implemented, and then re-start the session. Unfortunately some older themes can simply break if not maintained sufficiently to keep pace with the changes incurred by GTK+ updates. To avoid such occurrences, it is best to check that desired themes have recently been created or at least updated / patched.
テーマの編集または新しいテーマの作成
新しいテーマを作成したり既存のテーマを修正する方法は公式ウェブサイトの openbox.org で詳しく解説されています。また、obthemeAUR を使うことで GUI で行うことができます。
コンポジット効果
Openbox はネイティブではコンポジットをサポートしておらず、したがって、コンポジットを使うにはコンポジタをインストールする必要があります。コンポジットを使用することで透過や影などの様々なデスクトップ効果を使うことができるようになります。コンポジットは必須のコンポーネントではありませんが、見た目の良い環境を作るのに役立ち、oblogout を使うときの画面の乱れや、ターミナルウィンドウの透過を有効にしたときに起こるグリッチを防ぐことができます。一般的には以下からコンポジタを選択します:
- Compton: パワフルで信頼性があり、拡張性のあるコンポジタ。
- Xcompmgr: 旧式ながらシンプルなコンポジタ。
- Cairo Compmgr: 高度なコンポジット効果があり、プラグインをサポートし、ユーザーフレンドリな GUI を提供。ただしバグが多くてシステムリソースの消費も著しい。
デスクトップアイコンと壁紙
Openbox はネイティブではデスクトップアイコンや壁紙の使用をサポートしていません。したがって、必要であればアプリケーションを追加でインストールする必要があります。
ファイルマネージャによるデスクトップ管理
ファイルマネージャの中には完全にデスクトップを管理できる機能を持っているものがあり、そうしたファイルマネージャを使うことでデスクトップ上での壁紙やアイコンの使用をすることができます。LXDE デスクトップ環境ではそのために PCManFM を使っています。
PCManFM#デスクトップの管理 や SpaceFM#デスクトップの管理 を見て下さい。
壁紙
アプリケーション一覧#壁紙設定を見て下さい。
アイコンプログラム
デスクトップアイコンを使うためだけのプログラムというものも存在しますが、ファイルマネージャを利用するよりも利便性は大きく劣ります。
idesk
idesk は壁紙の管理に加えてアイコンを使えるようにもできるシンプルなプログラムです。~/.idesktop
ディレクトリを作成する必要があり、デスクトップアイコンは手動で作成しなくてはなりません。idesk を使ってアイコンを表示するには、~/.config/openbox/autostart
ファイルに以下のコマンドを追加してください:
idesk &
xfdesktop
xfdesktop は Xfce のデスクトップマネージャです。Thunar ファイルマネージャも依存パッケージとしてダウンロードされます。xfdesktop を使用しているときは、壁紙を右クリックして Openbox のデスクトップメニューにアクセスすることはできなくなります。
そのため、キーバインドを作成するか、パネルをインストールしてデスクトップメニューをパネルメニューとして使うかして、他の方法でアクセスできるようにする必要があります。xfdesktop を使ってアイコンを表示するには、以下のコマンドを ~/.config/openbox/autostart
ファイルに追加します:
xfdesktop &
conky の設定
ファイルマネージャを使ってデスクトップを管理するときは、conky を使っている場合、~/.conkyrc
を編集して own_window_type
コマンドを変更する必要があります。コマンドは以下のように修正してください:
own_window_type normal
Tips and tricks
マウスを使ってデスクトップを切り替える
画面の端にマウスを移動することでデスクトップを切り替えることが可能です。まず xdotool をインストールして以下の2行を ~/.xinitrc
に追加してください:
xdotool behave_screen_edge --delay 500 left set_desktop --relative -- -1 & xdotool behave_screen_edge --delay 500 right set_desktop --relative -- +1 &
規定のアプリケーション/ファイルの関連付けの設定
デフォルトアプリケーションを見て下さい。
マウスホイールによるデスクトップ切り替えを循環しないようにする
デフォルトではマウスホイールを回すことで Openbox は最後のデスクトップから最初のデスクトップに切り替えます。mousebind
セクションで <wrap>no</wrap>
を使うことでこの挙動を無効化することが可能です。
<context name="Desktop"> <mousebind button="Up" action="Click"> <action name="GoToDesktop"> <to>previous</to> <wrap>no</wrap> </action> </mousebind> <mousebind button="Down" action="Click"> <action name="GoToDesktop"> <to>next</to> <wrap>no</wrap> </action> </mousebind> </context>
ウィンドウ透過
transset-df が公式リポジトリから利用できます。transset-df を使えばすぐにウィンドウ透過を有効にできます。
例えば以下を ~/.config/openbox/rc.xml
ファイルの <mouse> セクションに追加すれば、タイトルバー上でマウスのホイールを回すことでウィンドウの透明度を調整できるようになります:
<context name="Titlebar"> ... <mousebind button="Up" action="Click"> <action name= "Execute" > <execute>transset-df -p .2 --inc </execute> </action> </mousebind> <mousebind button="Down" action="Click"> <action name= "Execute" > <execute>transset-df -p .2 --dec </execute> </action> </mousebind> ... </context>
obxprop を使って高速な設定を行う
The openbox package provides a obxprop
binary that can parse relevant values for applications settings in rc.xml
. Officially obxprop | grep "^_OB_APP"
is recommended for this task. Start the process by running the command shown, then click a window to see its properties in the terminal.
Doing so for multiple applications and its windows can be very inefficient however. The following script obxprop2obrc
makes it much easier to configure even a large number of applications.
#!/bin/bash ##Script: obxprop-to-openbox-rc.sh ##Recommended executable name: obxprop2obrc while [ $# -ne 0 ]; do case $1 in -f*) shift; FILE="$1"; shift; ;; -t*) shift; TIME="$1"; shift; ;; *) echo Usage: $0 [-f FILE_TEMPLATE] [-t WAIT_TO_KILL_TIME] exit 1; ;; esac done if [ $TIME ]; then OBXPROPS=( $(obxprop | cat & (sleep $TIME && pkill -13 cat) | awk -F \" '/_OB_APP/{ print "\x22"$2"\x22" }' ) ); else OBXPROPS=( $(obxprop | awk -F \" '/_OB_APP/{ print "\x22"$2"\x22" }' ) ); fi OBPROPS=(TYPE TITLE GROUP_CLASS GROUP_NAME CLASS NAME ROLE); j=0; for i in $( seq 2 2 14 ); do OBPROP="$( echo ${OBXPROPS[@]} | awk -F \" '{ print $'$i'}' )"; if [[ -z $OBPROP ]]; then declare ${OBPROPS[$j]}='"*"'; else declare ${OBPROPS[$j]}="\"$OBPROP\""; fi j=$(($j+1)); done; echo " <application type="$TYPE" title="$TITLE" class="$CLASS" name="$NAME" role="$ROLE">" if [ -f "$FILE" ]; then cat "$FILE" && exit; fi cat << EOF <desktop>1</desktop> <desktop>all</desktop> <decor>yes</decor> <decor>no</decor> <focus>yes</focus> <focus>no</focus> <fullscreen>yes</fullscreen> <fullscreen>no</fullscreen> <iconic>yes</iconic> <iconic>no</iconic> <maximized>yes</maximized> <maximized>no</maximized> <maximized>both</maximized> <maximized>horizontal</maximized> <maximized>vertical</maximized> <monitor>0</monitor> <monitor>1</monitor> <position force="no"> <position force="yes"> <width>40%</width> <height>30%</height> <x>-1</x> <y>-1</y> <x>center</x> <y>center</y> </position> <layer>above</layer> <layer>normal</layer> <layer>below</layer> <shade>yes</shade> <shade>no</shade> <skip_pager>yes</skip_pager> <skip_pager>no</skip_pager> <skip_taskbar>yes</skip_taskbar> <skip_taskbar>no</skip_taskbar> </application> EOF
If no further options are used default configuration, that can be edited by deleting unnecessary lines, is printed out. This script can use templates with default values when using -f
switch:
$ obxprop2obrc -f templates-rc-inkscape-dialogs.sc > part-rc-applications-inkscape.xml $ cat part-rc-applications-inkscape.xml
<application type="normal" title="Align and Distribute (Shift+Ctrl+A)" class="Inkscape" name="inkscape" role="*"> <desktop>3</desktop> <decor>yes</decor> <maximized>no</maximized> <position force="yes"> <width>20%</width> <height>30%</height> <x>-1</x> <y>-1</y> </position> <layer>normal</layer> <shade>yes</shade> </application>
It also has a time switch -t
which kills obxprop and thus can reduce time significantly in certain situations, although it may not work perfectly.
アプリケーションの Xprop の値
xorg-xprop is available in the official repositories, and can be used to relay property values for selected applications. Where frequently using per-application settings, the following Bash Alias may be useful: dy:
alias xp='xprop | grep "WM_WINDOW_ROLE\|WM_CLASS" && echo "WM_CLASS(STRING) = \"NAME\", \"CLASS\""'
To use Xorg-XProp, run using the alias given xp
, and click on the active program desired to define with per-application settins. The results displayed will only be the information that Openbox itself requires, namely the WM_WINDOW_ROLE
and WM_CLASS
(name and class) values:
WM_WINDOW_ROLE(STRING) = "roster" WM_CLASS(STRING) = "gajim.py", "Gajim.py" WM_CLASS(STRING) = "NAME", "CLASS"
Firefox
For whatever reason, Firefox and like-minded equivalents ignore application rules (e.g. <desktop>) unless class="Firefox*"
is used. This applies irrespective of whatever values xprop may report for the program's WM_CLASS
.
キーボードレイアウトの切り替え
キーボードレイアウトの管理に他のプログラムを使いたくない場合、特定のキーボードショートカットでレイアウトを切り替えるように X を手動で設定することができます。詳しい方法は Xorg#キーボードレイアウトの切り替え を見て下さい。
仮想デスクトップのグリッドレイアウトの設定
obsetlayoutAUR をインストールしてください。2x2 のグリッドを設定するには:
obsetlayout 0 2 2 0
引数を付けないで実行することで引数の意味を知ることができます。
トラブルシューティング
ウィンドウがアクティブウィンドウの後ろにロードされる
(Firefox のウィンドウなど) アプリケーションウィンドウが現在のアクティブウィンドウの後ろにロードされ、ウィンドウをフォーカスして切り替える必要が生じることがあります。この挙動を修正するには以下を ~/.config/openbox/rc.xml
ファイルの <openbox_config>
と </openbox_config>
タグの間に追加してください:
<applications> <application class="*"> <focus>yes</focus> </application> </applications>
参照
- Openbox Website – 公式ウェブサイト
- Planet Openbox – Openbox ニュースポータル
- Box-Look.org – A good resource for themes and related artwork
- Openbox Hacks and Configs Thread @ Arch Linux Forums
- Openbox Screenshots Thread @ Arch Linux Forums
- Using GNOME 3 with Openbox Tutorial