Openbox: Unterschied zwischen den Versionen
K rc.xml nicht rc.conf |
Dirk (Diskussion | Beiträge) |
||
(44 dazwischenliegende Versionen von 13 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|name=Openbox|repo=extra|paket=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 | 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 | ||
Zeile 26: | Zeile 23: | ||
Sollte die Datei nicht existieren, so ist sie anzulegen. | Sollte die Datei nicht existieren, so ist sie anzulegen. | ||
Wer Openbox per Login Manager starten will, sollte sich mal [[Login-Manager#SLiM|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 == | == Konfigurationswerkzeuge und -Dateien == | ||
Zeile 81: | Zeile 33: | ||
[[Bild:openbox-desktopwechsel.png|thumb|Die Desktopwechsel-Anzeige beim Wechseln auf einen mit „Temporär“ benannten Desktop]] | [[Bild:openbox-desktopwechsel.png|thumb|Die Desktopwechsel-Anzeige beim Wechseln auf einen mit „Temporär“ benannten Desktop]] | ||
[[Bild:Desktopmenu_openbox.png|thumb|Das Desktop-Menü mit Anwendungen auf allen Desktops]] | [[Bild:Desktopmenu_openbox.png|thumb|Das Desktop-Menü mit Anwendungen auf allen Desktops]] | ||
[[Bild:Obkey_config.png|thumb|Anzeige einer Konfiguration mittels obkey]] | |||
Konfigurieren kann man Openbox über die Datei | 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 - | pacman -S obconf | ||
Gestartet wird das Programm mittels des Aufrufes | 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 - | pacman -S obmenu | ||
Danach ist das Tool über den Aufruf von | 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 | 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. | ||
Damit der Pager beim Start von Openbox auch | |||
== Menüverwaltung == | == Menüverwaltung == | ||
Zeile 122: | 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 | 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 134: | 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+ | 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 | 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 153: | Zeile 96: | ||
openbox --reconfigure | openbox --reconfigure | ||
… bewerkstelligt, und ist sofort wirksam. Nun können über den Druck auf Strg+ | … 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 | 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 {{ic|~/.config/openbox/rc.xml}} im {{ic|<applications>}}-Block ein Unterblock {{ic|<application>}} mit folgender Syntax angelegt werden. | |||
<applications> | |||
... | |||
<application name="NAME" class="CLASS" role="ROLE" type="TYPE"> | |||
...PROPERTIES... | |||
</application> | |||
... | |||
</applications> | |||
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" | |||
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" | |||
=== Fenster von Firefox anpassen === | === Beispiel: Fenster von Firefox anpassen === | ||
Anhand der Angaben und der Anfangs erwähnten Idee kann man nun in der | 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 182: | Zeile 143: | ||
</application> | </application> | ||
Hier wird Firefox anhand seiner Klasse referenziert. | 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 | Nach der Definition muss Openbox neu konfiguriert werden, dies geschieht mittels … | ||
openbox --reconfigure | openbox --reconfigure | ||
Zeile 190: | 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 201: | Zeile 162: | ||
</application> | </application> | ||
Hierdurch wird Gajim (bzw. alle Fenster deren Klasse | 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 209: | Zeile 170: | ||
=== Weiteres === | === Weiteres === | ||
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 216: | Zeile 177: | ||
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. | 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 [http://openbox.org/wiki/Help:Actions#MoveResizeTo Funktionsbeschreibung von {{ic|MoveResizeTo}} im Openbox-Wiki] | |||
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 | 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 227: | 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], [ | 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: | ||
* [[Fbpanel]] | * [[Fbpanel]] | ||
* | * [https://github.com/vzxwco/neap neap], ein Systray-Pager | ||
* 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 | 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. 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== | |||
* [http://openbox.org/ Openbox Homepage und Wiki] {{sprache|en}} | |||
* [http://urukrama.wordpress.com/openbox-guide/ urukramas Openbox-Guide] {{sprache|en}} | |||
* [http://de.wikipedia.org/wiki/Openbox Wikipedia Artikel] {{sprache|de}} | |||
* [http://www.box-look.org Themes, Icons, Hintergrundbilder, ect.] {{sprache|en}} | |||
* [http://themes.freshmeat.net/browse/1086/ Themes auf freshmeat.net] {{sprache|en}} | |||
[[Kategorie:Fenstermanager]] | [[Kategorie:Fenstermanager]] | ||
[[ | [[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.
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
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
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
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:
- Fbpanel
- neap, ein Systray-Pager
- 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 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: