Openbox: Unterschied zwischen den Versionen

Aus wiki.archlinux.de
(→‎Fensterverwaltung: xprop -> obxprop, obapps)
 
(23 dazwischenliegende Versionen von 7 Benutzern werden nicht angezeigt)
Zeile 2: Zeile 2:
Diese Seite beschreibt die Installation und Konfiguration des Window-Managers „Openbox“. Openbox ist ein Fenstermanager für X basierend auf dem Quellcode von Blackbox 0.65.0. Ab Version 3 wurde Openbox komplett in C neu geschrieben, lehnt sich jedoch immer noch an das Aussehen von Blackbox an (Wikipedia).
Diese Seite beschreibt die Installation und Konfiguration des Window-Managers „Openbox“. Openbox ist ein Fenstermanager für X basierend auf dem Quellcode von Blackbox 0.65.0. Ab Version 3 wurde Openbox komplett in C neu geschrieben, lehnt sich jedoch immer noch an das Aussehen von Blackbox an (Wikipedia).


== Installation ==
{{installation|name=Openbox|repo=extra|paket=openbox}}
Es wird davon ausgegangen, dass der [[X|X-Server]] bereits installiert ist, und funktioniert. Für die Verwendung von Openbox muss das gleichnamige Paket aus „[[Pacman#Repositorien_und_Spiegel-Server|extra]]“ installiert werden.
 
pacman -S openbox


Nach der Installation wird folgende Meldung auf der Standardausgabe (stdout) ausgegeben:
Nach der Installation wird folgende Meldung auf der Standardausgabe (stdout) ausgegeben:
Zeile 12: Zeile 9:
  They can both be found in /etc/xdg/openbox
  They can both be found in /etc/xdg/openbox


Das kopieren der Dateien ist nötig, um die Einstellungen je Benutzer verwalten zu können. Wenn Openbox diese Dateien nicht vorfindet, werden die Dateien in /etc/xdg/openbox verwendet. Es ist sinnvoll, die Dateien in das eigene home-Verzeichnis zu kopieren, da ansonsten einige Tools (s.u.) nicht richtig arbeiten, und man zum Bearbeiten der Konfiguration ansonsten root-Rechte braucht.
Das kopieren der Dateien ist nötig, um die Einstellungen je Benutzer verwalten zu können. Wenn Openbox diese Dateien nicht vorfindet, werden die Dateien in {{ic|/etc/xdg/openbox}} verwendet. Es ist sinnvoll, die Dateien in das eigene home-Verzeichnis zu kopieren, da ansonsten einige Tools (s.u.) nicht richtig arbeiten, und man zum Bearbeiten der Konfiguration ansonsten root-Rechte braucht.


Zuerst wird also das Verzeichnis angelegt, und dann die angegebenen Dateien in dieses Verzeichnis kopiert.
Zuerst wird also das Verzeichnis angelegt, und dann die angegebenen Dateien in dieses Verzeichnis kopiert.
Zeile 20: Zeile 17:
  cp /etc/xdg/openbox/menu.xml ~/.config/openbox/
  cp /etc/xdg/openbox/menu.xml ~/.config/openbox/


Damit Openbox beim Start von X gleich mitgestartet wird, und man es sofort verwenden kann, bedarf es eines Eintrages in der Datei „~/.xinitrc“. Es ist diese Datei also in einem Texteditor zu öffnen, und dort folgendes am Ende hinzuzufügen.
Damit Openbox beim Start von [[X]] gleich mitgestartet wird, und man es sofort verwenden kann, bedarf es eines Eintrages in der [[xinitrc]]. Es ist diese Datei also in einem Texteditor zu öffnen, und dort folgendes am Ende hinzuzufügen.
 
  exec openbox-session
  exec openbox-session
Sollte die Datei nicht existieren, so ist sie anzulegen.
Sollte die Datei nicht existieren, so ist sie anzulegen.


Zeile 36: Zeile 35:
[[Bild:Obkey_config.png‎|thumb|Anzeige einer Konfiguration mittels obkey]]
[[Bild:Obkey_config.png‎|thumb|Anzeige einer Konfiguration mittels obkey]]


Konfigurieren kann man Openbox über die Datei ~/.config/openbox/rc.xml“, jedoch gibt es für diese Aufgabe auch das grafische Interface "OBconf", welches zunächst installiert werden muss
Konfigurieren kann man Openbox über die Datei {{ic|~/.config/openbox/rc.xml}}, jedoch gibt es für diese Aufgabe auch das grafische Interface ''OBconf'', welches zunächst installiert werden muss


  pacman -S obconf
  pacman -S obconf


Gestartet wird das Programm mittels des Aufrufes „obconf“. Hier können nun diverse Anpassungen vorgenommen werden, so können zum Beispiel das Theme oder das Fensterverhalten angepasst werden, sowie die Fenstericons konfiguriert werden. Das Menü, das man sich über einen Rechtsklick auf dem Desktop anzeigen lassen kann, wird hier allerdings nicht konfiguriert, dies geschieht in der Datei ~/.config/openbox/menu.xml“. Natürlich gibt es auch für diese Datei ein grafisches Konfigurationstool. Dieses muss jedoch auch erst installiert werden.
Gestartet wird das Programm mittels des Aufrufes {{ic|obconf}}. Hier können nun diverse Anpassungen vorgenommen werden, so können zum Beispiel das Theme oder das Fensterverhalten angepasst werden, sowie die Fenstericons konfiguriert werden. Das Menü, das man sich über einen Rechtsklick auf dem Desktop anzeigen lassen kann, wird hier allerdings nicht konfiguriert, dies geschieht in der Datei {{ic|~/.config/openbox/menu.xml}}. Natürlich gibt es auch für diese Datei ein grafisches Konfigurationstool. Dieses muss jedoch auch erst installiert werden.


  pacman -S obmenu
  pacman -S obmenu


Danach ist das Tool über den Aufruf von „obmenu“ zu starten. Dieses Tool bietet für die Konfiguration ausreichende Funktionen, unterstützt aber nicht alle Funktionen der menu.xml, so sind derzeit (2008-12-05, Version 1.0-5) Labels für Seperatoren – die diese dann zu Überschriften machen – nicht unterstützt. Ein weiteres Problem ergibt sich, wenn man alle Menüs entfernt: Es kann kein neues Menü angelegt werden. Das „root-menu“ sollte darüber hinaus sowieso nicht entfernt werden. Innerhalb dieses Menüs wird alles angezeigt, was über Rechtsklick verfügbar ist.
Danach ist das Tool über den Aufruf von {{ic|obmenu}} zu starten. Dieses Tool bietet für die Konfiguration ausreichende Funktionen, unterstützt aber nicht alle Funktionen der menu.xml, so sind derzeit (2008-12-05, Version 1.0-5) Labels für Separatoren – die diese dann zu Überschriften machen – nicht unterstützt. Ein weiteres Problem ergibt sich, wenn man alle Menüs entfernt: Es kann kein neues Menü angelegt werden. Das „root-menu“ sollte darüber hinaus sowieso nicht entfernt werden. Innerhalb dieses Menüs wird alles angezeigt, was über Rechtsklick verfügbar ist.


Ein weiteres grafisches Programm, mit welchem Tastenkombinationen verändert werden können, heißt Obkey. Es wurde von einem Benutzer aus dem englischen Arch Forum programmiert und findet sich im AUR : http://aur.archlinux.org/packages.php?ID=23822
Ein weiteres grafisches Programm, mit welchem Tastenkombinationen verändert werden können, heißt ''Obkey''. Es wurde von einem Benutzer aus dem englischen Arch Forum programmiert und findet sich im AUR: http://aur.archlinux.org/packages.php?ID=23822


== Desktopverwaltung ==
== Desktopverwaltung ==
Openbox unterstützt selbstverständlich mehrere virtuelle Desktops. Diese können mit den Tastenkombinationen „Windowstaste+F*“ ausgewählt werden, wobei „F*“ eine der F-Tasten (F1 bis F12) ist, die Zahl der Taste entspricht dabei der Nummer des virtuellen Desktops, den man anwählen möchte. Zudem besteht die Möglichkeit, mittels Strg+Alt+CursorLinks/CursorRechts zum jeweils nächsten bzw. vorherigen Desktop zu wechseln. Auch das Drehen des Mausrades auf dem Desktop, bzw. bei gedrücktem Strg+Alt auch „in“ Anwendungsfenstern wechselt den Desktop.
Openbox unterstützt selbstverständlich mehrere virtuelle Desktops. Diese können mittels {{taste|super}}+{{taste|F1}} bis {{taste|super}}+{{taste|F12}} angewählt werden. Zudem besteht die Möglichkeit, mittels {{taste|Strg}}+{{taste|Alt}}+{{taste|links}} bzw. {{taste|Strg}}+{{taste|Alt}}+{{taste|rechts}} zum jeweils vorherigen bzw. nächsten Desktop zu wechseln. Auch das Drehen des Mausrades auf dem Desktop, bzw. bei gedrücktem {{taste|Strg}}+{{taste|Alt}} auch „in“ Anwendungsfenstern wechselt den Desktop.


Openbox verfügt neben dem Hauptmenü, das per Rechtsklick erreichbar ist, noch über ein Desktop-Menü. Dieses ist per Mittelklick auf eine freie Stelle des Desktops aufrufbar, und zeigt alle Anwendungen je Desktop an. mit einem Klick auf die jeweilige Anwendung, wird auf den entsprechenden Desktop gewechselt, und die Anwendung in den Vordergrund geholt. Anwendungen, die minimiert sind, werden in der Liste eingeklammert angezeigt.
Openbox verfügt neben dem Hauptmenü, das per Rechtsklick erreichbar ist, noch über ein Desktop-Menü. Dieses ist per Mittelklick auf eine freie Stelle des Desktops aufrufbar, und zeigt alle Anwendungen je Desktop an. mit einem Klick auf die jeweilige Anwendung, wird auf den entsprechenden Desktop gewechselt, und die Anwendung in den Vordergrund geholt. Anwendungen, die minimiert sind, werden in der Liste eingeklammert angezeigt.


Über dieses Menü ist es zudem möglich ad-hoc Desktops hinzuzufügen, oder zu entfernen, wenn auf den anderen Desktops mal kein Platz mehr sein sollte.
Über dieses Menü ist es zudem möglich ad-hoc Desktops hinzuzufügen, oder zu entfernen, wenn auf den anderen Desktops mal kein Platz mehr sein sollte. Wer die Desktops grafisch verwalten möchte, der kann z.B. auf {{paket|bbpager}} zurückgreifen. Damit der Pager beim Start von Openbox auch mit gestartet wird, ist es sinnvoll, den Aufruf in die Autostart-Datei von Openbox zu legen. Diese befindet sich unter {{ic|~/.config/openbox/autostart.sh}}, oder muss dort erst angelegt werden.
 
Wenn man allerdings lieber ein grafisches Verwaltungstool für die Desktops haben möchte, bedarf es eines Zusatztools. Allerdings befindet sich das originäre Openbox-Desktopverwaltungstool [http://aur.archlinux.org/packages.php?ID=11208 obpager] nicht in den Repositories, sondern derzeit nur im [[ArchLinux_User-Community_Repository|AUR]].
 
Wem es nur darauf ankommt, die Desktops grafisch verwalten zu können, der kann auch auf z.B. „bbpager“ zurückgreifen, das sich im „extra“-Repository von Arch befindet, und ganz normal über [[pacman]] installiert werden kann. Wer lieber den Openbox-Pager verwenden möchte, muss diesen aus dem AUR installieren (ausführliche Informationen dazu siehe [[ArchLinux_User-Community_Repository|AUR-Wikiseite]]).
 
Damit der Pager beim Start von Openbox auch mitgestartet wird, ist es sinnvoll, den Aufruf in die Autostart-Datei von Openbox zu legen. Diese befindet sich unter ~/.config/openbox/autostart.sh“, oder muss dort erst angelegt werden. In diese Datei wird nun …
 
obpager &
 
… geschrieben. Das Kaufmanns-Und am Ende ist wichtig, damit nachfolgende Befehle ebenfalls ausgeführt werden.


== Menüverwaltung ==
== Menüverwaltung ==
Zeile 76: Zeile 65:
Konfiguriert werden kann der Rahmen über obconf. Dort befindet sich als vorletzter seitlicher Reiter der Punkt „Margins“. Auf dieser Registerkarte kann über das leicht verständliche GUI in Echtzeit für alle vier Kanten des Desktops ein Rahmen eingerichtet werden.
Konfiguriert werden kann der Rahmen über obconf. Dort befindet sich als vorletzter seitlicher Reiter der Punkt „Margins“. Auf dieser Registerkarte kann über das leicht verständliche GUI in Echtzeit für alle vier Kanten des Desktops ein Rahmen eingerichtet werden.


Will man den Rahmen lieber manuell konfigurieren, so findet man die dazu nötigen Einstellungen etwa in der Mitte der Datei ~/.config/openbox/rc.xml“ im Abschnitt „<desktops>[…]</desktops>“.
Will man den Rahmen lieber manuell konfigurieren, so findet man die dazu nötigen Einstellungen etwa in der Mitte der Datei {{ic|~/.config/openbox/rc.xml}} im Abschnitt „<desktops>[…]</desktops>“.


  <margins>
  <margins>
Zeile 88: Zeile 77:


=== Menüaufruftaste definieren ===
=== Menüaufruftaste definieren ===
Will man keinen Rahmen definieren, besteht auch die Möglichkeit, den Aufruf der Menüs auf Tasten der Tastatur zu legen. Hierzu eignen sich eher ungenutzte Tasten wie „Rollen“ oder „Pause“ gut, allerdings kann es auch eine beliebige, von Openbox verwaltbare, aber eher unübliche Tastenkombination sein. Zum Beispiel könnte man das Fenster-Menü auf Strg+Shift+F12, und das Programm-Menü auf Strg+Shift+F11 legen, weil dies relativ leicht erreichbare, aber dennoch eher unübliche Tastenkombinationen sind.
Will man keinen Rahmen definieren, besteht auch die Möglichkeit, den Aufruf der Menüs auf Tasten der Tastatur zu legen. Hierzu eignen sich eher ungenutzte Tasten wie „Rollen“ oder „Pause“ gut, allerdings kann es auch eine beliebige, von Openbox verwaltbare, aber eher unübliche Tastenkombination sein. Zum Beispiel könnte man das Fenster-Menü auf {{taste|Strg}}+{{taste|shift}}+{{taste|F12}}, und das Programm-Menü auf {{taste|Strg}}+{{taste|shift}}+{{taste|F11}} legen, weil dies relativ leicht erreichbare, aber dennoch eher unübliche Tastenkombinationen sind.


Konfiguriert werden Tastenkombinationen in der Datei ~/.config/openbox/rc.xml“ relativ weit am Ende der Datei im Abschnitt <keyboard>[…]</keyboard>. Um die Menüs wie im vorherigen Absatz geschrieben auf Strg+Shift+F11 und Strg+Shift+F12 zu legen, müssen dort zwei Definitionen erstellt werden
Konfiguriert werden Tastenkombinationen in der Datei {{ic|~/.config/openbox/rc.xml}} relativ weit am Ende der Datei im Abschnitt {{ic|<keyboard>[…]</keyboard>}}. Um die Menüs wie im vorherigen Absatz geschrieben auf {{taste|Strg}}+{{taste|shift}}+{{taste|F11}} und {{taste|Strg}}+{{taste|shift}}+{{taste|F12}} zu legen, müssen dort zwei Definitionen erstellt werden


  <keybind key="C-S-F11">
  <keybind key="C-S-F11">
Zeile 107: Zeile 96:
  openbox --reconfigure
  openbox --reconfigure


… bewerkstelligt, und ist sofort wirksam. Nun können über den Druck auf Strg+Shift+F11 und Strg+Shift+F12 die Menüs auch geöffnet werden, wenn man sich mit dem Mauscursor innerhalb eines Nicht-Desktop-Fensters befindet.
… bewerkstelligt, und ist sofort wirksam. Nun können über den Druck auf {{taste|Strg}}+{{taste|shift}}+{{taste|F11}} und {{taste|Strg}}+{{taste|shift}}+{{taste|F12}} die Menüs auch geöffnet werden, wenn man sich mit dem Mauscursor innerhalb eines Nicht-Desktop-Fensters befindet.
 
=== Icons in Menüs ===
[[Bild:openbox_icons_menu.png|thumb|Beispielmenü mit Icons]]
Wenn man Menü-Icons verwenden möchte, muss man deren Verwendung zuerst in der {{ic|rc.xml}} aktivieren, hierzu muss der {{ic|menu}}-Abschnitt um {{ic|<showIcons>yes</showIcons>}} erweitert werden. Nun können in der {{ic|menu.xml}} für alle Menüs, Untermenüs, und Menüeinträge Icons definiert werden.
 
<menu id="die-id" label="das Label" execute="programm" icon="icon.png" />  # Pipemenü
<menu id="die-id" label="das Label" icon="/pfad/icon.png">                # Normales Menü
<item label="Programm starten" icon=".icons/menu/mein_icon.png">          # Menüeinträge
 
Der Übersichtlichkeit halber wurden weitere nötige Tags weg gelassen, und nur der Anfangstag beschrieben. Für das einbinden von Icons können gängige Pfadangaben genutzt werden. Nach dem Bearbeiten muss mittels {{ic|openbox --reconfigure}} oder, falls die Icons nicht übernommen werden, {{ic|openbox --restart}} Openbox neu geladen werden.


== Fensterverwaltung ==
== Fensterverwaltung ==
Openbox ermöglicht es, Fenster unterschiedlich zu verwalten. So besteht die Möglichkeit, Firefox zum Beispiel immer 1024×768 Pixel groß zentriert auf dem zweiten Desktop zu öffnen, oder aber auch Die Werkzeugfenster von Gimp standardmäßig ohne Fensterumrandung darzustellen. Auch besteht die Möglichkeit, zu bestimmen, wo ein bestimmtes Fenster positioniert werden soll, indem man seine X- und Y-Koordinaten angibt.
Openbox ermöglicht es, Fenster unterschiedlich zu verwalten. So besteht die Möglichkeit, Firefox zum Beispiel immer 1024×768 Pixel groß zentriert auf dem zweiten Desktop zu öffnen, oder aber auch Die Werkzeugfenster von Gimp standardmäßig ohne Fensterumrandung darzustellen. Auch besteht die Möglichkeit, zu bestimmen, wo ein bestimmtes Fenster positioniert werden soll, indem man seine X- und Y-Koordinaten angibt.


Damit Openbox dies bewerkstelligen kann, muss in der Datei ~/.config/openbox/rc.xml“ im <applications> Block ein Unterblock <application> mit folgender Syntax angelegt werden.
Damit Openbox dies bewerkstelligen kann, muss in der Datei {{ic|~/.config/openbox/rc.xml}} im {{ic|<applications>}}-Block ein Unterblock {{ic|<application>}} mit folgender Syntax angelegt werden.
 
  <applications>
  <applications>
   ...
   ...
Zeile 121: Zeile 121:
  </applications>
  </applications>


Von den Angaben ''name'', ''class'', ''role'' und ''type'' muss mindestens ''name'' oder ''class'' angegeben werden. Um die Fenster spezieller zu definieren, kann man zusätzlich noch weiter mit angeben. Ausserdem ist zu beachten, dass ''name'' nicht der Fenstertitel ist. Ermitteln kann man die nötigen Informationen mittels des Programms „obxprop“, das im Openbox Paleket enthalten ist.
Von den Angaben {{ic|name}}, {{ic|class}}, {{ic|role}} und {{ic|type}} muss mindestens {{ic|name}} oder {{ic|class}} angegeben werden. Um die Fenster spezieller zu definieren, kann man zusätzlich noch weitere mit angeben. Außerdem ist zu beachten, dass {{ic|name}} nicht der Fenstertitel ist. Ermitteln kann man die nötigen Informationen mittels des Programms ''obxprop'', das im Openbox-Paket enthalten ist.


  obxprop | grep "^_OB_APP"
  obxprop | grep "^_OB_APP"
Zeile 128: Zeile 128:


  _OB_APP_TYPE(UTF8_STRING) = "normal"
  _OB_APP_TYPE(UTF8_STRING) = "normal"
  _OB_APP_CLASS(UTF8_STRING) = "Firefox"
  _OB_APP_CLASS(UTF8_STRING) = "Firefox-bin"
  _OB_APP_NAME(UTF8_STRING) = "firefox"
  _OB_APP_NAME(UTF8_STRING) = "firefox-bin"
  _OB_APP_ROLE(UTF8_STRING) = "browser"
  _OB_APP_ROLE(UTF8_STRING) = "browser"


=== Fenster von Firefox anpassen ===
=== Beispiel: Fenster von Firefox anpassen ===
Anhand der Angaben und der Anfangs erwähnten Idee kann man nun in der „rc.xml“ eine Anwendungsregel für Firefox definieren. Dazu erstellt man im Abschnitt <applications>ziemlich am Ende der Datei einfach einen neuen Eintrag:
Anhand der Angaben und der Anfangs erwähnten Idee kann man nun in der {{ic|rc.xml}} eine Anwendungsregel für Firefox definieren. Dazu erstellt man im Abschnitt {{ic|<applications>}} ziemlich am Ende der Datei einfach einen neuen Eintrag:


  <application class="Firefox*">
  <application class="Firefox-bin">
   <desktop>2</desktop>
   <desktop>2</desktop>
   <position force="yes">
   <position force="yes">
Zeile 143: Zeile 143:
  </application>
  </application>


Hier wird Firefox anhand seiner Klasse referenziert. Allerdings hat die Referenzierung mittels der Klasse eine Besonderheit: Die Referenzierung greift nur, wenn hinter dem Klassennamen ein Sternchen steht, das als Wildcard fungiert. Andere Referenzierungen funktionieren für gewöhnlich aber ohne dieses zusätzliche Sternchen.
Hier wird Firefox anhand seiner Klasse referenziert. Bei einigen Programmen kann es nötig sein, an die Klassendefinition als Wildcard-Zeichen ein Sternchen anhängen zu müssen, damit diese Definition auch greift.


Nach der Definition muss Openbox neukonfiguriert werden, dies geschieht mittels …
Nach der Definition muss Openbox neu konfiguriert werden, dies geschieht mittels …


  openbox --reconfigure
  openbox --reconfigure
Zeile 151: Zeile 151:
… und bedarf keines Neustarts von X oder Openbox. Alle ab sofort geöffneten Firefox-Hauptfenster werden nun zentriert auf dem zweiten Desktop angezeigt.
… und bedarf keines Neustarts von X oder Openbox. Alle ab sofort geöffneten Firefox-Hauptfenster werden nun zentriert auf dem zweiten Desktop angezeigt.


=== Gajim-Fenster anpassen ===
=== Beispiel: Gajim-Fenster anpassen ===
Möchte man zum Beispiel das das Fenster des [[Jabber|Jabber-Messengers]] [[Gajim]] immer oben Rechts auf dem Bildschirm haben, und soll das Fenster beim Start in die Icon-Anzeigefläche („Systray“) minimiert werden, kann man folgendes benutzen:
Möchte man zum Beispiel das das Fenster des [[Jabber|Jabber-Messengers]] [[Gajim]] immer oben Rechts auf dem Bildschirm haben, und soll das Fenster beim Start in die Icon-Anzeigefläche („Systray“) minimiert werden, kann man folgendes benutzen:


  <application class="Gajim.py*">
  <application class="Gajim.py">
   <position force="yes">
   <position force="yes">
     <x>-100</x>
     <x>-100</x>
Zeile 162: Zeile 162:
  </application>
  </application>


Hierdurch wird Gajim (bzw. alle Fenster deren Klasse mit „Gajim.py“ anfängt) oben rechts auf dem Desktop mit 100 Pixeln zum Rand ausgerichtet angezeigt, wenn man es sichtbar macht. Beim Starten wird das Fenster automatisch ins Systray minimiert.
Hierdurch wird Gajim (bzw. alle Fenster deren Klasse {{ic|Gajim.py}} lautet) oben rechts auf dem Desktop mit 100 Pixeln zum Rand ausgerichtet angezeigt, wenn man es sichtbar macht. Beim Starten wird das Fenster automatisch ins Systray minimiert.


  <skip_pager>yes</skip_pager>
  <skip_pager>yes</skip_pager>
Zeile 170: Zeile 170:


=== Weiteres ===
=== Weiteres ===
In der „rc.xml“ von Openbox befindet sich im unteren Bereich eine ausführliche, auskommentierte, vollständig Dokumentierte Auflistung aller verfügbaren Optionen.
In der {{ic|rc.xml}} von Openbox befindet sich im unteren Bereich eine ausführliche, auskommentierte, vollständig Dokumentierte Auflistung aller verfügbaren Optionen.


So bestehen zum Beispiel auch die Möglichkeiten, Fenster maximiert oder im Vollbildmodus darzustellen, oder zu bestimmen, ob das Fenster auf allen Desktops sichtbar sein soll, und auch, ob es einen Fensterrahmen besitzen soll.  
So bestehen zum Beispiel auch die Möglichkeiten, Fenster maximiert oder im Vollbildmodus darzustellen, oder zu bestimmen, ob das Fenster auf allen Desktops sichtbar sein soll, und auch, ob es einen Fensterrahmen besitzen soll.  
Zeile 183: Zeile 183:
  DISPLAY=:0.1 openbox
  DISPLAY=:0.1 openbox


Hiermit wird Openbox auf dem ersten und dem zweiten Display gestartet. Alle Instanzen können interagieren. Siehe [http://openbox.org/wiki/Help:Actions#MoveResizeTo Funktionsbeschreibung von „MoveResizeTo“ im Openbox-Wiki]
Hiermit wird Openbox auf dem ersten und dem zweiten Display gestartet. Alle Instanzen können interagieren. Siehe [http://openbox.org/wiki/Help:Actions#MoveResizeTo Funktionsbeschreibung von {{ic|MoveResizeTo}} im Openbox-Wiki]


Ausserdem gibt es noch [http://sourceforge.net/apps/mediawiki/obapps/index.php?title=Main_Page OBApps]. Das ist eine GUI, mit der man die "per-application" Fenstereinstellungen konfigurieren kann. OBApps ist im [http://aur.archlinux.org/packages.php?ID=37166 AUR] verfügbar.
Außerdem gibt es noch [http://sourceforge.net/apps/mediawiki/obapps/index.php?title=Main_Page OBApps]. Das ist eine GUI, mit der man die „per-application“ Fenstereinstellungen konfigurieren kann. OBApps ist im [http://aur.archlinux.org/packages.php?ID=37166 AUR] verfügbar.


== Hintergrundbild anpassen ==
== Hintergrundbild anpassen ==
Openbox ist nicht darauf ausgerichtet, Hintergrundbilder zu verwalten. Man kann hier zum Beispiel auf den Bildbetrachter „feh“ zurückgreifen. Jedoch könnten dafür auch „display“ aus dem ImageMagick-Paket, „xsetbg“ oder „Nitrogen“ verwendet werden.
Openbox ist nicht darauf ausgerichtet, Hintergrundbilder zu verwalten. Man kann hier zum Beispiel auf den Bildbetrachter [[Feh]] zurückgreifen. Jedoch könnten dafür auch ''display'' aus dem [[ImageMagick]]-Paket, ''xsetbg'' oder ''Nitrogen'' verwendet werden.


Der Wiki-Artikel [[Hintergrundbild anpassen]] bietet diesbezügliche, ausführliche Anleitungen, inklusive einiger Beispiele.
Der Wiki-Artikel [[Hintergrundbild anpassen]] bietet diesbezügliche, ausführliche Anleitungen, inklusive einiger Beispiele.
Zeile 197: Zeile 197:
Openbox verfügt in der Grundinstallation nicht über einen Ausführ-Dialog. Der Wiki-Artikel [[Ausführen-Dialog]] zeigt verschiedene Programme auf, mit denen diese Funktionalität nachgerüstet werden kann.
Openbox verfügt in der Grundinstallation nicht über einen Ausführ-Dialog. Der Wiki-Artikel [[Ausführen-Dialog]] zeigt verschiedene Programme auf, mit denen diese Funktionalität nachgerüstet werden kann.


Openbox hat keine eigene Funktion um Icons auf dem Desktop darzustellen. Wer darauf dennoch nicht verzichten möchte, kann z.B. [http://idesk.sourceforge.net/wiki/index.php/Main_Page iDesk], [http://roscidus.com/desktop/ ROX], [http://pcmanfm.sourceforge.net/ PCManFM] oder auch Nautilus (plus 'gnome-settings-daemon') verwenden. ROX und PCManFM sind gleichzeitig auch noch schlanke Dateimanager.
Openbox hat keine eigene Funktion um Icons auf dem Desktop darzustellen. Wer darauf dennoch nicht verzichten möchte, kann z.B. [http://idesk.sourceforge.net/wiki/index.php/Main_Page iDesk], [[ROX]], [[PCManFM]] oder auch Nautilus (plus 'gnome-settings-daemon') verwenden. ROX und PCManFM sind gleichzeitig auch noch schlanke Dateimanager.


Es gibt zahlreiche Panels, Pager, etc. die man mit Openbox verwenden kann. Zum Beispiel diese hier:
Es gibt zahlreiche Panels, Pager, etc. die man mit Openbox verwenden kann. Zum Beispiel diese hier:


* [[Pypanel]]
* [[Fbpanel]]
* [[Fbpanel]]
* [http://code.google.com/p/neap/ neap], ein Systray-Pager
* [https://github.com/vzxwco/neap neap], ein Systray-Pager
* ObPager (siehe oben)
* Weitere Panels siehe [[Liste von Panels]]
* Weitere Panels siehe [[Liste von Panels]]


Um die gewünschten Programme beim Start von Openbox zu starten, sollte ein entsprechender Eintrag in der Openbox-Autostartdatei (s.o.) reichen.
Um die gewünschten Programme beim Start von Openbox zu starten, sollte ein entsprechender Eintrag in der Openbox-Autostartdatei reichen.


=== Dateimanager ===
=== Dateimanager ===
Da Openbox ein Fenstermanager ist, und keine Desktopumgebung, verfügt es nicht über einen Dateimanager. Eine [[Liste von Dateimanagern]] befindet sich im gleichnamigen Wiki-Artikel, oder in der [[:Kategorie:Dateimanager|Dateimanager-Wiki-Kategorie]].
Da Openbox ein Fenstermanager ist, und keine Desktopumgebung, verfügt es nicht über einen Dateimanager. Hier im Wiki gibt es eine [[:Kategorie:Dateimanager|Dateimanager-Kategorie]].
 
=== Desktopeffekte ===
Um auch unter Openbox Desktopeffekte wie Transparenz, Fensterschatten, Menü- und Fensteranimationen, etc. nutzen zu können, muss man einen Composite-Manager installieren. Für die Nutzung zusammen mit Openbox eignen sich zum Beispiel diese hier:
 
* [[Cairo Composite Manager]]
* [[Compton]]
* [https://wiki.archlinux.org/index.php/Xcompmgr Xcompmgr] {{sprache|en}}


==Weblinks==
==Weblinks==
* http://openbox.org/
* [http://openbox.org/ Openbox Homepage und Wiki] {{sprache|en}}
* http://de.wikipedia.org/wiki/Openbox
* [http://urukrama.wordpress.com/openbox-guide/ urukramas Openbox-Guide] {{sprache|en}}
* http://www.box-look.org
* [http://de.wikipedia.org/wiki/Openbox Wikipedia Artikel] {{sprache|de}}
* http://themes.freshmeat.net/browse/1086/
* [http://www.box-look.org Themes, Icons, Hintergrundbilder, ect.] {{sprache|en}}
* http://urukrama.wordpress.com/openbox-guide/
* [http://themes.freshmeat.net/browse/1086/ Themes auf freshmeat.net] {{sprache|en}}
 


[[Kategorie:Fenstermanager]]
[[Kategorie:Fenstermanager]]
[[en:Openbox]]
[[en:Openbox]]

Aktuelle Version vom 3. Mai 2022, 08:50 Uhr

Diese Seite beschreibt die Installation und Konfiguration des Window-Managers „Openbox“. Openbox ist ein Fenstermanager für X basierend auf dem Quellcode von Blackbox 0.65.0. Ab Version 3 wurde Openbox komplett in C neu geschrieben, lehnt sich jedoch immer noch an das Aussehen von Blackbox an (Wikipedia).

Installation

Openbox ist als openbox in extra verfügbar, und kann von dort mittels Pacman installiert werden.

pacman -S openbox

Nach der Installation wird folgende Meldung auf der Standardausgabe (stdout) ausgegeben:

Place menu.xml and rc.xml in ~/.config/openbox
They can both be found in /etc/xdg/openbox

Das kopieren der Dateien ist nötig, um die Einstellungen je Benutzer verwalten zu können. Wenn Openbox diese Dateien nicht vorfindet, werden die Dateien in /etc/xdg/openbox verwendet. Es ist sinnvoll, die Dateien in das eigene home-Verzeichnis zu kopieren, da ansonsten einige Tools (s.u.) nicht richtig arbeiten, und man zum Bearbeiten der Konfiguration ansonsten root-Rechte braucht.

Zuerst wird also das Verzeichnis angelegt, und dann die angegebenen Dateien in dieses Verzeichnis kopiert.

mkdir -p ~/.config/openbox
cp /etc/xdg/openbox/rc.xml ~/.config/openbox/
cp /etc/xdg/openbox/menu.xml ~/.config/openbox/

Damit Openbox beim Start von X gleich mitgestartet wird, und man es sofort verwenden kann, bedarf es eines Eintrages in der xinitrc. Es ist diese Datei also in einem Texteditor zu öffnen, und dort folgendes am Ende hinzuzufügen.

exec openbox-session

Sollte die Datei nicht existieren, so ist sie anzulegen.

Wer Openbox per Login Manager starten will, sollte sich mal SLiM ansehen. SLiM hat keine Abhängigkeiten zu Gnome oder KDE. Einen Überblick über verschiedene Login-Manager bietet der Wiki-Artikel Login-Manager.

Weitere Informationen hierzu finden sich im Artikel über X#Xorg starten.

Konfigurationswerkzeuge und -Dateien

Anzeige der Fensterkonfiguration in Obconf
Konfiguration des Openbox-Menüs über Obmenu
Tastenkombinationen mit Obkey anpassen
Die Desktopwechsel-Anzeige beim Wechseln auf einen mit „Temporär“ benannten Desktop
Das Desktop-Menü mit Anwendungen auf allen Desktops
Anzeige einer Konfiguration mittels obkey

Konfigurieren kann man Openbox über die Datei ~/.config/openbox/rc.xml, jedoch gibt es für diese Aufgabe auch das grafische Interface OBconf, welches zunächst installiert werden muss

pacman -S obconf

Gestartet wird das Programm mittels des Aufrufes obconf. Hier können nun diverse Anpassungen vorgenommen werden, so können zum Beispiel das Theme oder das Fensterverhalten angepasst werden, sowie die Fenstericons konfiguriert werden. Das Menü, das man sich über einen Rechtsklick auf dem Desktop anzeigen lassen kann, wird hier allerdings nicht konfiguriert, dies geschieht in der Datei ~/.config/openbox/menu.xml. Natürlich gibt es auch für diese Datei ein grafisches Konfigurationstool. Dieses muss jedoch auch erst installiert werden.

pacman -S obmenu

Danach ist das Tool über den Aufruf von obmenu zu starten. Dieses Tool bietet für die Konfiguration ausreichende Funktionen, unterstützt aber nicht alle Funktionen der menu.xml, so sind derzeit (2008-12-05, Version 1.0-5) Labels für Separatoren – die diese dann zu Überschriften machen – nicht unterstützt. Ein weiteres Problem ergibt sich, wenn man alle Menüs entfernt: Es kann kein neues Menü angelegt werden. Das „root-menu“ sollte darüber hinaus sowieso nicht entfernt werden. Innerhalb dieses Menüs wird alles angezeigt, was über Rechtsklick verfügbar ist.

Ein weiteres grafisches Programm, mit welchem Tastenkombinationen verändert werden können, heißt Obkey. Es wurde von einem Benutzer aus dem englischen Arch Forum programmiert und findet sich im AUR: http://aur.archlinux.org/packages.php?ID=23822

Desktopverwaltung

Openbox unterstützt selbstverständlich mehrere virtuelle Desktops. Diese können mittels ⊞ Super+F1 bis ⊞ Super+F12 angewählt werden. Zudem besteht die Möglichkeit, mittels Strg+Alt+ bzw. Strg+Alt+ zum jeweils vorherigen bzw. nächsten Desktop zu wechseln. Auch das Drehen des Mausrades auf dem Desktop, bzw. bei gedrücktem Strg+Alt auch „in“ Anwendungsfenstern wechselt den Desktop.

Openbox verfügt neben dem Hauptmenü, das per Rechtsklick erreichbar ist, noch über ein Desktop-Menü. Dieses ist per Mittelklick auf eine freie Stelle des Desktops aufrufbar, und zeigt alle Anwendungen je Desktop an. mit einem Klick auf die jeweilige Anwendung, wird auf den entsprechenden Desktop gewechselt, und die Anwendung in den Vordergrund geholt. Anwendungen, die minimiert sind, werden in der Liste eingeklammert angezeigt.

Über dieses Menü ist es zudem möglich ad-hoc Desktops hinzuzufügen, oder zu entfernen, wenn auf den anderen Desktops mal kein Platz mehr sein sollte. Wer die Desktops grafisch verwalten möchte, der kann z.B. auf bbpager zurückgreifen. Damit der Pager beim Start von Openbox auch mit gestartet wird, ist es sinnvoll, den Aufruf in die Autostart-Datei von Openbox zu legen. Diese befindet sich unter ~/.config/openbox/autostart.sh, oder muss dort erst angelegt werden.

Menüverwaltung

Definition eines ein Pixel schmalen, linksseitigen Rahmens in obconf

Die beiden Openbox-Menüs, die standardmäßig auf Rechts- und Mittelklick liegen, und das Programm- bzw. Fenster-Menü anzeigen, können durch einen Klick nur erreicht werden, wenn man eine freie Stelle auf dem Desktop hat, wenn man Anwendungen wie die Textverarbeitung oder einen Browser im Vollbildmodus laufen lässt, hat man keine freie Fläche des Desktops zur Verfügung. Um dennoch auf die Menüs zugreifen zu können, gibt es zwei Möglichkeiten.

Rahmen einrichten

Um auf die Menüs zugreifen zu können, benötigt man den Desktop. Es reicht dabei auch, wenn lediglich ein Pixel des Desktops erreichbar ist. Dies kann man über die Openbox-Funktion der Rahmenverwaltung ermöglichen.

Durch einen ein Pixel schmalen Rahmen an einer beliebigen Fensterseite hat man auch bei maximierten Anwendungen immer die Möglichkeit, die Menüs zu öffnen, man muss lediglich den Mauszeiger bis an den Bildschirmrand bewegen und die entsprechende Maustaste drücken. Anwendungen werden von Openbox nie in dem definierten Bereich geöffnet. Fenster verdecken den Rahmen auch im Vollbildmodus nicht.

Konfiguriert werden kann der Rahmen über obconf. Dort befindet sich als vorletzter seitlicher Reiter der Punkt „Margins“. Auf dieser Registerkarte kann über das leicht verständliche GUI in Echtzeit für alle vier Kanten des Desktops ein Rahmen eingerichtet werden.

Will man den Rahmen lieber manuell konfigurieren, so findet man die dazu nötigen Einstellungen etwa in der Mitte der Datei ~/.config/openbox/rc.xml im Abschnitt „<desktops>[…]</desktops>“.

<margins>
  <top>0</top>
  <bottom>0</bottom>
  <left>0</left>
  <right>0</right>
</margins>

Der angegebene Wert entspricht dem Rand in Pixeln auf dieser Seite des Desktops.

Menüaufruftaste definieren

Will man keinen Rahmen definieren, besteht auch die Möglichkeit, den Aufruf der Menüs auf Tasten der Tastatur zu legen. Hierzu eignen sich eher ungenutzte Tasten wie „Rollen“ oder „Pause“ gut, allerdings kann es auch eine beliebige, von Openbox verwaltbare, aber eher unübliche Tastenkombination sein. Zum Beispiel könnte man das Fenster-Menü auf Strg+⇧ Shift+F12, und das Programm-Menü auf Strg+⇧ Shift+F11 legen, weil dies relativ leicht erreichbare, aber dennoch eher unübliche Tastenkombinationen sind.

Konfiguriert werden Tastenkombinationen in der Datei ~/.config/openbox/rc.xml relativ weit am Ende der Datei im Abschnitt <keyboard>[…]</keyboard>. Um die Menüs wie im vorherigen Absatz geschrieben auf Strg+⇧ Shift+F11 und Strg+⇧ Shift+F12 zu legen, müssen dort zwei Definitionen erstellt werden

<keybind key="C-S-F11">
  <action name="ShowMenu">
    <menu>root-menu</menu>
  </action>
</keybind>
<keybind key="C-S-F12">
  <action name="ShowMenu">
    <menu>client-list-combined-menu</menu>
  </action>
</keybind>

Danach muss die Konfigurationsdatei von Openbox neu eingelesen werden, dies wird mittels des Befehls …

openbox --reconfigure

… bewerkstelligt, und ist sofort wirksam. Nun können über den Druck auf Strg+⇧ Shift+F11 und Strg+⇧ Shift+F12 die Menüs auch geöffnet werden, wenn man sich mit dem Mauscursor innerhalb eines Nicht-Desktop-Fensters befindet.

Icons in Menüs

Beispielmenü mit Icons

Wenn man Menü-Icons verwenden möchte, muss man deren Verwendung zuerst in der rc.xml aktivieren, hierzu muss der menu-Abschnitt um <showIcons>yes</showIcons> erweitert werden. Nun können in der menu.xml für alle Menüs, Untermenüs, und Menüeinträge Icons definiert werden.

<menu id="die-id" label="das Label" execute="programm" icon="icon.png" />  # Pipemenü
<menu id="die-id" label="das Label" icon="/pfad/icon.png">                 # Normales Menü
<item label="Programm starten" icon=".icons/menu/mein_icon.png">           # Menüeinträge

Der Übersichtlichkeit halber wurden weitere nötige Tags weg gelassen, und nur der Anfangstag beschrieben. Für das einbinden von Icons können gängige Pfadangaben genutzt werden. Nach dem Bearbeiten muss mittels openbox --reconfigure oder, falls die Icons nicht übernommen werden, openbox --restart Openbox neu geladen werden.

Fensterverwaltung

Openbox ermöglicht es, Fenster unterschiedlich zu verwalten. So besteht die Möglichkeit, Firefox zum Beispiel immer 1024×768 Pixel groß zentriert auf dem zweiten Desktop zu öffnen, oder aber auch Die Werkzeugfenster von Gimp standardmäßig ohne Fensterumrandung darzustellen. Auch besteht die Möglichkeit, zu bestimmen, wo ein bestimmtes Fenster positioniert werden soll, indem man seine X- und Y-Koordinaten angibt.

Damit Openbox dies bewerkstelligen kann, muss in der Datei ~/.config/openbox/rc.xml im <applications>-Block ein Unterblock <application> mit folgender Syntax angelegt werden.

<applications>
  ...
  <application name="NAME" class="CLASS" role="ROLE" type="TYPE">
    ...PROPERTIES...
  </application>
  ...
</applications>

Von den Angaben name, class, role und type muss mindestens name oder class angegeben werden. Um die Fenster spezieller zu definieren, kann man zusätzlich noch weitere mit angeben. Außerdem ist zu beachten, dass name nicht der Fenstertitel ist. Ermitteln kann man die nötigen Informationen mittels des Programms obxprop, das im Openbox-Paket enthalten ist.

obxprop | grep "^_OB_APP"

Der Mauscursor wird nun als Fadenkreuz dargestellt. Wenn man nun ein Fenster anklickt, werden die Entsprechenden Informationen ausgegeben, die man dann in der Konfigurationsdatei von Openbox verwenden kann. Am Beispiel von Firefox ist dies

_OB_APP_TYPE(UTF8_STRING) = "normal"
_OB_APP_CLASS(UTF8_STRING) = "Firefox-bin"
_OB_APP_NAME(UTF8_STRING) = "firefox-bin"
_OB_APP_ROLE(UTF8_STRING) = "browser"

Beispiel: Fenster von Firefox anpassen

Anhand der Angaben und der Anfangs erwähnten Idee kann man nun in der rc.xml eine Anwendungsregel für Firefox definieren. Dazu erstellt man im Abschnitt <applications> ziemlich am Ende der Datei einfach einen neuen Eintrag:

<application class="Firefox-bin">
  <desktop>2</desktop>
  <position force="yes">
    <x>center</x>
    <y>center</y>
  </position>
</application>

Hier wird Firefox anhand seiner Klasse referenziert. Bei einigen Programmen kann es nötig sein, an die Klassendefinition als Wildcard-Zeichen ein Sternchen anhängen zu müssen, damit diese Definition auch greift.

Nach der Definition muss Openbox neu konfiguriert werden, dies geschieht mittels …

openbox --reconfigure

… und bedarf keines Neustarts von X oder Openbox. Alle ab sofort geöffneten Firefox-Hauptfenster werden nun zentriert auf dem zweiten Desktop angezeigt.

Beispiel: Gajim-Fenster anpassen

Möchte man zum Beispiel das das Fenster des Jabber-Messengers Gajim immer oben Rechts auf dem Bildschirm haben, und soll das Fenster beim Start in die Icon-Anzeigefläche („Systray“) minimiert werden, kann man folgendes benutzen:

<application class="Gajim.py">
  <position force="yes">
    <x>-100</x>
    <y>100</y>
  </position>
  <iconic>yes</iconic>
</application>

Hierdurch wird Gajim (bzw. alle Fenster deren Klasse Gajim.py lautet) oben rechts auf dem Desktop mit 100 Pixeln zum Rand ausgerichtet angezeigt, wenn man es sichtbar macht. Beim Starten wird das Fenster automatisch ins Systray minimiert.

<skip_pager>yes</skip_pager>
<skip_taskbar>yes</skip_taskbar>

Wenn man dies hinzufügt, wird das entsprechende Fenster auch nicht bei Alt+Tab oder in der Fensterliste angezeigt.

Weiteres

In der rc.xml von Openbox befindet sich im unteren Bereich eine ausführliche, auskommentierte, vollständig Dokumentierte Auflistung aller verfügbaren Optionen.

So bestehen zum Beispiel auch die Möglichkeiten, Fenster maximiert oder im Vollbildmodus darzustellen, oder zu bestimmen, ob das Fenster auf allen Desktops sichtbar sein soll, und auch, ob es einen Fensterrahmen besitzen soll.

Alle Optionen greifen nur, wenn das Fenster sie auch unterstützt. So kann man zwar definieren, dass PCManFM als Systray-Icon angezeigt werden soll, so lange der Dateimanager das aber nicht unterstützt, wird die Angabe einfach ignoriert.

Man muss auf jeden Fall etwas herumprobieren, bis man einerseits das Fenster „zu fassen bekommt“, und andererseits, bis man es mittels der verfügbaren Optionen so konfiguriert hat, wie man es braucht.

Openbox hat ausgereifte Funktionen, mehrere Bildschirme gleichzeitig zu verwalten (dies unterscheidet sich von XrandR, Xinerama, etc.). Dazu muss Openbox je Bildschirm ein mal gestartet werden.

DISPLAY=:0.0 openbox
DISPLAY=:0.1 openbox

Hiermit wird Openbox auf dem ersten und dem zweiten Display gestartet. Alle Instanzen können interagieren. Siehe Funktionsbeschreibung von MoveResizeTo im Openbox-Wiki

Außerdem gibt es noch OBApps. Das ist eine GUI, mit der man die „per-application“ Fenstereinstellungen konfigurieren kann. OBApps ist im AUR verfügbar.

Hintergrundbild anpassen

Openbox ist nicht darauf ausgerichtet, Hintergrundbilder zu verwalten. Man kann hier zum Beispiel auf den Bildbetrachter Feh zurückgreifen. Jedoch könnten dafür auch display aus dem ImageMagick-Paket, xsetbg oder Nitrogen verwendet werden.

Der Wiki-Artikel Hintergrundbild anpassen bietet diesbezügliche, ausführliche Anleitungen, inklusive einiger Beispiele.

Weitere zusätzliche Dinge

Wie man X11-Maus-Cursor-Themes installiert wird im Wiki-Artikel Maus Cursor Themes beschrieben.

Openbox verfügt in der Grundinstallation nicht über einen Ausführ-Dialog. Der Wiki-Artikel Ausführen-Dialog zeigt verschiedene Programme auf, mit denen diese Funktionalität nachgerüstet werden kann.

Openbox hat keine eigene Funktion um Icons auf dem Desktop darzustellen. Wer darauf dennoch nicht verzichten möchte, kann z.B. iDesk, ROX, PCManFM oder auch Nautilus (plus 'gnome-settings-daemon') verwenden. ROX und PCManFM sind gleichzeitig auch noch schlanke Dateimanager.

Es gibt zahlreiche Panels, Pager, etc. die man mit Openbox verwenden kann. Zum Beispiel diese hier:

Um die gewünschten Programme beim Start von Openbox zu starten, sollte ein entsprechender Eintrag in der Openbox-Autostartdatei reichen.

Dateimanager

Da Openbox ein Fenstermanager ist, und keine Desktopumgebung, verfügt es nicht über einen Dateimanager. Hier im Wiki gibt es eine Dateimanager-Kategorie.

Desktopeffekte

Um auch unter Openbox Desktopeffekte wie Transparenz, Fensterschatten, Menü- und Fensteranimationen, etc. nutzen zu können, muss man einen Composite-Manager installieren. Für die Nutzung zusammen mit Openbox eignen sich zum Beispiel diese hier:

Weblinks