Openbox (正體中文)

From ArchWiki
Revision as of 18:18, 7 February 2010 by Carl (Talk | contribs) (Created page with 'Category:正體中文 {{translateme}} {{i18n_links_start}} {{i18n_entry|Česky|OpenBox (Česky)}} {{i18n_entry|English|Openbox}} {{i18n_entry|Español|Openbox (Español)}} {{…')

(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search

Tango-preferences-desktop-locale.pngThis article or section needs to be translated.Tango-preferences-desktop-locale.png

Notes: please use the first argument of the template to provide more detailed indications. (Discuss in Talk:Openbox (正體中文)#)
Template:I18n links start

Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n links end

Openbox 為一輕量且高度彈性之視窗管理員,具有廣泛標準支援。其功能於 官方網站 有完整文件說明。本文將提及如何在 Arch Linux 下執行 Openbox。


Openbox 可由標準套件庫取得:

# pacman -S openbox

安裝完成後,pacman 會指引您複製預設的 Template:FilenameTemplate:Filename 設定檔至 ~/.config/openbox/,例如:

Note: 請以一般使用者身分執行這些動作。
$ mkdir -p ~/.config/openbox/
$ cp /etc/xdg/openbox/rc.xml ~/.config/openbox/rc.xml
$ cp /etc/xdg/openbox/menu.xml ~/.config/openbox/menu.xml

Template:Filename 為 Openbox 核心設定檔,用以管理鍵盤快速鍵、佈景主題、虛擬桌面以及其它功能。

當您按下桌面時,Template:Filename 控制 Openbox 應用程式功能表顯示行為。The default items are pretty sparse, but it's very easy to modify the menu structure to suit your needs. See the menu section below for more details, or visit the Openbox website.


To run Openbox on its own, simply add the following to the bottom of Template:Filename:

exec openbox-session

If you have used another window manager before, such as Xfce, and Openbox wont start after logging out of X, try moving the autostart folder:

mv ~/.config/autostart ~/.config/autostart-bak



GNOME 2.26

Follow the next guide for GNOME 2.24. If it fails try this:

If after installing openbox and trying to log into the 'Gnome/openbox' session but it always fails then you can do the following as one way to achieve running openbox as your window manager every time you log into the 'Gnome' session from your login manager (xdm, gdm, kdm, entrance, slim, etc.)

  1. Log into your Gnome only session (which would still be using metacity as its window manager) if you aren't already.
  2. Install openbox if you have not done so already
  3. Explore your menus to System → Preferences → Startup Applications (possibly named 'Session' for older versions of Gnome)
  4. Open Startup Application, select '+ Add' and enter the text as seen in the box below whilst omitting the text behind the #.
  5. Now hit the 'Add' button for that data entry window and make sure the checkbox beside your new entry is selected.
  6. Thus log out of your gnome session and log back in and you should be running openbox as your window manager.
  7. Enjoy!
Name:    Openbox Windox Manager          # Can be changed
Command: openbox --replace               # Text should not be removed from this line, but possibly added to it
Comment: Replaces metacity with openbox  # Can be changed

This creates an entry in a startup list which is executed by gnome everytime that particular user's gnome-session is started.

GNOME 2.24

First, create Template:Filename containing the following:

[Desktop Entry]
# name of loadable control center module
# name we put on the WM spec check window

Then, in gconf, set /desktop/gnome/session/required_components/windowmanager to openbox:

$ gconftool-2 -s -t string /desktop/gnome/session/required_components/windowmanager openbox

最後,在 GDM session 功能表選擇 GNOME session。

GNOME 2.22 及早期版本

  1. If you use GDM, select the "GNOME/Openbox" login option
  2. If you use startx, add Template:Codeline to Template:Filename
  3. From the shell:
$ xinit /usr/bin/openbox-gnome-session


  1. If you use KDM, select the "KDE/Openbox" login option
  2. If you use startx, add Template:Codeline to Template:Filename
  3. From the shell:
$ xinit /usr/bin/openbox-kde-session


Log into a normal Xfce4 session. From your terminal of choice, do:

$ killall xfwm4 ; openbox & exit

This will kill xfwm4, run Openbox, and close the terminal.

Log out, making sure to check the "Save session for future logins" checkbox. On next login, Xfce4 will use Openbox as its WM. To be able to exit the session using xfce4-session, open your file Template:Filename (if it isn't there, copy it from Template:Filename).


 <item label="Exit Openbox">
   <action name="Exit">


 <item label="Exit Openbox">
   <action name="Execute">

否則,在最上層功能表使用 "Exit" 項目會導致 Openbox 終止自身執行,使您陷入沒有視窗管理員的窘境。

If you have an issue changing between virtual desktops with the mouse wheel skipping over virtual desktops, open your Template:Filename file and move the mouse binds with actions "DesktopPrevious" and "DesktopNext" from the context "Desktop" to the context "Root" (you may need to define the Root context).

If you want to use the Openbox root-menu instead of Xfce's, you may terminate Xfdesktop by running the following command in a terminal:

$ xfdesktop --quit

然而,若要讓 Xfdesktop 管理桌布以及桌面圖示,必須使用其它公用程式,例如 ROX, 以達成這些功能。

(When terminating Xfdesktop, the above issue with the virtual desktops is no longer a problem.)


現階段來說,您有兩種選項修改 Openbox 偏好設定;您可手動編輯 Template:Filename,或是使用 ObConf 工具。


若要手動設定 Openbox ,只要以您喜愛的文字編輯器編輯 Template:Filename 即可。整份設定檔提供大量註解,full documentation 可從官方網站取得。


ObConf is GUI-based Openbox configuration tool, which can be used to set most preferences including themes, virtual desktops, window properties and desktop margins.

若要安裝 ObConf,執行:

# pacman -S obconf
Note: ObConf 無法用來設定鍵盤快速鍵以及某些進階功能。若要進行這些修改,您必須手動編輯 Template:Filename (see above)。其它選項有 ObKey 應用程式(可於 AUR 取得)。


Openbox features per-application settings, allowing you to define rules for your programs. For example, you can:

  • load your web browser on a certain desktop
  • load your terminal without a window border
  • load your torrent client at a certain position on your screen

These are defined in Template:Filename. As you might expect, the instructions are well-documented within the file itself. Full details can also be found here:


The default Openbox menu includes a variety of applications to get you started, but you'll probably want to customize this at some point. There are a number of ways to do so:


Similar to the Template:Filename file, you can edit Template:Filename with your favourite text editor. Although many of the settings are self-explanatory, full documentation is available.


MenuMaker is a powerful tool that creates XML-based menus for a variety of Window Managers, including Openbox. MenuMaker will search your computer for executable programs and create an XML menu based on the results. It can be configured to exclude Legacy X, GNOME, KDE, or Xfce applications if the user desires.

MenuMaker 可於社群套件庫取得:

# pacman -S menumaker


$ mmaker -v OpenBox3

MenuMaker 預設不會覆蓋現有 menu.xml。若要這麼做,以 -f (force) 參數執行:

$ mmaker -vf OpenBox3

若要檢視完整選項清單,執行 Template:Codeline

This will give you a pretty thorough menu. Now you can modify the menu.xml by hand, or simply regenerate the list whenever you install new software.


Obmenu is a GUI-based menu editor for Openbox. For those who don't enjoy editing XML source code, this is probably the best option for you.

It is available in the community repository:

# pacman -S obmenu

Once installed, simply run Template:Codeline and add or remove the desired applications.


obm-xdg is a command-line tool that comes with Obmenu. It can generate a categorized sub-menu of installed GTK/GNOME applications.

To use obm-xdg, add the following line to Template:Filename:

<menu execute="obm-xdg" id="xdg-menu" label="xdg"/>

Then run Template:Codeline to refresh the Openbox menu. You should now see a sub-menu labeled xdg in your menu.

Note: If you do not have GNOME installed, then you need to install gnome-menus package for obm-xdg to work.

基於 Python 的 xdg 功能表指令碼

This script can be found in Fedora's Openbox package. You will only have to put the script somewhere and add a menu entry.

Here is my paste: And here is the head:

Download the one you like (maybe you'll prefer the head version of course). You can put the file anywhere, I used ~/Documents/build/xdg-menu (just modify the menu entry later according to YOUR filename/path.)

Then open your menu.xml with your favourite text editor and add the following entry where you want the new menu (of course, you can modify the label however you want):

<menu id="apps-menu" label="xdgmenu" execute="python /home/shiki/Documents/build/xdg-menu"/>

Save the file, and run: Template:Codeline.

Pipe menus

Openbox (and other WMs like WindowMaker and PekWM) allow you to write scripts that dynamically build menus on the fly. Some examples are system monitors, media player controls, and weather forecasts. Many examples can be found on the openbox site.

Xyne has also created a file browser and brisbin33 has one for scanning for / connecting to wireless hot spots (requires netcfg). The relevant forum posts for these utilities are here and here


Openbox features support for running programs at startup. This is provided by the "openbox-session" command.

There are two ways to enable autostart:

  1. If you use startx/xinit to log into your X session, edit Template:Filename and change the line that executes openbox to execute openbox-session instead.
  2. If you log in with GDM/KDM, then select the Openbox session and it will automatically use autostart.

Startup programs are managed in Template:Filename. Full instructions and best practices for how to do this are available at the Openbox website.


With the exception of the Openbox Themes topic, the following section is intended for users who have configured Openbox to run as a standalone desktop, without the assistance of GNOME, KDE or Xfce.

Openbox 佈景主題

Openbox themes control the appearance of window borders, including the titlebar and titlebar buttons. They also determine the appearance of the application menu and on-screen display (OSD).


# pacman -S openbox-themes

This package is by no means definitive. You can download more themes at websites such as:

下載的佈景主題應該可解壓縮至 ~/.themes 並且能夠經由 ObConf 工具安裝或選取。

Creating new themes is fairly easy and again well-documented.

For a GUI theme editor, take a look at ObTheme.

GTK 佈景主題


GTK+ themes can be managed easily with the lxappearance, gtk-chtheme, or switch2 utilities. To install, run:

# pacman -S lxappearance


# pacman -S gtk-chtheme


# pacman -S gtk-theme-switch2

Now you can simply run Template:Codeline, Template:Codeline or Template:Codeline to set the desired theme.


For legacy GTK1 themes, install the gtk-theme-switch package:

# pacman -S gtk-theme-switch

Then run Template:Codeline to select a desired theme.

GTK 字型

To manually change the type and size of your fonts, add the following to Template:Filename:

style "user-font"
font_name = "[font-name] [size]"
widget_class "*" style "user-font"
gtk-font-name = "[font-name] [size]"

where Template:Codeline is the desired font and point size. For example:

style "user-font"
font_name = "DejaVu Sans 8"
widget_class "*" style "user-font"
gtk-font-name = "DejaVu Sans 8"

Both Template:Codeline and Template:Codeline fields are required for backwards compatibility.

您也可以使用 gtk-chthemelxappearance 設定 GTK 字型。請參照上述段落。

GTK 圖示

First, extract the desired icon theme to /usr/share/icons (system-wide access) or ~/.icons (local user access), then:

Add the following to Template:Filename:

gtk-icon-theme-name = "[name-of-icon-theme]"

where Template:Codeline is the name of the icon theme directory. For example:

gtk-icon-theme-name = "Tango"

Ensure Template:Filename is configured to parse Template:Filename:

# ~/.gtkrc-2.0
include "/usr/share/themes/Rezlooks-Gilouche/gtk-2.0/gtkrc"
include "/home/username/.gtkrc.mine"

You can use lxappearance to choose GTK icon themes. Please refer to the above section.


Extract the desired Xcursor theme to either /usr/share/icons (system-wide access) or ~/.icons (local user access). There are also a limited amount of themes available in the community repository that can be installed using pacman.

Add this to Template:Filename:

Xcursor.theme:   [name-of-cursor-theme]

where Template:Codeline is the name of the cursor theme directory. For example:

Xcursor.theme:	Vanilla-DMZ-AA

To change the size:

Xcursor.size: [size]


Openbox does not provide a means to display icons on the desktop. PcmanFM, ROX, iDesk, or even Nautilus (and the gnome-settings-daemon) can provide this function.

ROX and PCmanFM have the additional advantage of being lightweight file managers.


Openbox itself does not include a way to change the wallpaper. This can be done easily with programs like Feh or Nitrogen. Other options include ImageMagick, hsetroot and xsetbg.


There is list of Lightweight Software at Arch's wiki, most of them nicely fits with Openbox.


SLiM provides a lightweight and elegant graphical login solution for standalone Openbox configurations. Refer to Arch's SLiM wiki for detailed instructions.

Qingy is ultralight and very configurable graphical login. It support login to both console and X Windows sessions. It uses DirectFB, therefore it does not start X Windows unless you choose X Windows session. See article about Qingy at Arch's wiki.

Composite desktop

Xcompmgr is a lightweight composite manager capable of rendering drop shadows, fading and simple window transparency within Openbox and other window managers.

(It's worth noting that xcompmgr is no longer developed, and so any issues are unlikely to be fixed)

Cairo Comp Mgr is an alternative.

Panels, trays, and pagers

There are quite a lot of utilities available that provide a panel (taskbar), system tray, and pager to Openbox. The most common are:




Make your choice and add it to your startup file. If you wish to set the desktop layout without using a pager, you can use obsetlayout, which is a packaged version of the setlayout tool from the Openbox wiki.


There are many possibilities, but the most popular lightweight file managers are:

  • Thunar. Thunar supports auto-mount features and other plugins.
# pacman -S thunar

Thunar may be started in daemon mode for tighter desktop integration. For instance, inserting a USB pendrive will invoke a Thunar window to popup, with the drive contents listed in the window.

To start Thunar in daemon mode, edit Template:Filename and add:

thunar --daemon &
  • ROX (ROX provides desktop icons)
# pacman -S rox
  • PCManFM (pcmanfm also provides desktop icons)
# pacman -S pcmanfm

For even lighter options, consider Gentoo or emelFM, both of which use the familiar 'Midnight Commander' two pane layout (these two require Gtk 1.2.x).

Of course, you can also use GNOME's Nautilus. Although slower than the above solutions, it has the additional advantage of VFS support (e.g. remote SSH, FTP and Samba connections)



Set-up dmenu as described in the dmenu wiki article. Then, add the following entry to the <keyboard> section Template:Filename to enable a shortcut to launch dmenu:

   <keybind key="W-space">
     <action name="Execute">


gmrun provides an excellent Run dialog box, similar to the Alt+F2 features found in Gnome and KDE:

# pacman -S gmrun

Add the following entry to the <keyboard> section Template:Filename to enable Alt+F2 functionality:

<keybind key="A-F2">
<action name="execute"><execute>gmrun</execute></action>


bashrun provides a different, barebones approach to a run dialog, using a specialized bash session within a small xterm window. It is available in the community repository and can be launched through the Alt+F2 style approach mentioned previously. To make bashrun act more like a traditional run dialog, add the following entry to the <applications> section Template:Filename:

   <application name="bashrun">
     <decor>no</decor>  # switch to yes if you prefer a bordered window


Launchy is a less minimalistic approach; it is skinnable and offers more functionality such as a calculator, checking the weather, etc. Originally for Windows, similar to Gnome Do.

# pacman -S launchy

It is launched by Ctrl+Space key combination.


The LXPanel run dialog can be executed with

lxpanelctl run


The gnome-panel run dialog can be executed with

gnome-panel-control --run-dialog


You may wish to install a clipboard manager for feature rich copy/paste ability. xfce4-clipman-plugin, parcellite, or glipper-old may be installed via pacman. Add your choice to From the terminal, Ctrl+Insert as copy and Shift+Insert as paste generally works as well. You may also copy from terminal with Ctrl+Shift+C, and paste with mouse middle click.


Tips and tricks


From the terminal, Ctrl+Insert as copy and Shift+Insert as paste generally works as well. You may also copy from terminal with Ctrl+Shift+C, and paste with mouse middle click.


By using the program transset-df, it is virtually the same as transset, (available by: pacman -S transset-df) you can enable transparancy of windows on the fly. For instance by editing the following in Template:Filename you can have your middle mouse scroll enable and disable transparency by scrolling down and up on the scroll button, respectively, while over the title bar (it is in the <mouse> section):

    <context name="Titlebar">
     <mousebind button="Left" action="Press">
       <action name="Focus"/>
       <action name="Raise"/>
     <mousebind button="Left" action="Drag">
       <action name="Move"/>
     <mousebind button="Left" action="DoubleClick">
       <action name="ToggleMaximizeFull"/>
     <mousebind button="Middle" action="Press">
     	<action name="Lower"/> 
       <action name="FocusToBottom"/>
       <action name="Unfocus"/>
     <mousebind button="Up" action="Click">
       <action name= "Execute" >
       <execute>transset-df -p .2 --inc  </execute>
     <mousebind button="Down" action="Click">
       <action name= "Execute" >
       <execute>transset-df -p .2 --dec </execute>
     <mousebind button="Right" action="Press">
       <action name="Focus"/>
       <action name="Raise"/>
       <action name="ShowMenu">

As of now, it only appears to work when no other actions are taken.

Xprop values for applications

If you use per-application settings frequently, you might find this bash alias handy:

alias xp='xprop | grep "WM_WINDOW_ROLE\|WM_CLASS" && echo "WM_CLASS(STRING) = \"NAME\", \"CLASS\""'

To use, run Template:Codeline and click on the running program that you'd like to define with per-app settings. The result will display only the info that Openbox requires, namely the WM_WINDOW_ROLE and WM_CLASS (name and class) values:

[thayer@dublin:~] $ xp

Xprop for Firefox

For whatever reason, Firefox and its open source equivalents will ignore application rules (e.g. <desktop>) unless Template:Codeline is used, regardless of what xprop reports as the actual WM_CLASS values.

Linking the menu to a command

Some people would want to link the Openbox main menu, or any other, to a command. This is useful for creating a menu button in a panel, for example. Although Openbox doesn't support this, a very simple script, xdotool, can simulate a keypress by running a command. Xdotool is available on AUR. To use it, simply add the following code to the <keyboard> section of your Template:Filename:

    <keybind key="A-C-q">
      <action name="ShowMenu">

Restart/reconfigure Openbox. You can now magically summon your menu at your cursor position by running the following command:

# xdotool key ctrl+alt+q

Of course, you can change the shortcut to your liking.

Urxvt in the background

With Openbox, running a terminal as desktop background is easy. You won't need devilspie here.

First you must enable transparency, open your Template:Filename file (if it doesn't exist yet, create it in your home folder).

URxvt*geometry:124x24    #I don't use the whole screen, if you want a full screen term don't bother with this and see below.
URxvt*foreground:Black   #Font color. My wallpaper is White, you may wish to change this to White.

接著編輯您的 Template:Filename 檔案:

<application name="urxvt">
  <maximized>true</maximized> #Only if you want a full size terminal.

The magic comes from the Template:Codeline line, which place the application under all others. Here Urxvt is displayed on all desktops, change it to your convenience.