Openbox: Unterschied zwischen den Versionen

Aus wiki.archlinux.de
KKeine Bearbeitungszusammenfassung
(→‎Desktopeffekte: compton verlinkt)
(38 dazwischenliegende Versionen von 11 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 -Sy openbox


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


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 Datei „~/.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.


== Einloggen ==
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]].
Das Einloggen in Openbox (bzw. X) ist einerseits mittels Login-Manager möglich, andererseits geht es aber auch ohne. Wer nur einen Fenstermanager verwendet, braucht nicht unbedingt einen Login-Manager, nur um sein Benutzernamen und sein Kennwort einzugeben.
 
=== Ohne Login-Manager ===
Das Einloggen funktioniert hier direkt nach dem Start von der Befehlszeile aus. Dort sieht man das Login-Prompt, an dem man seine Login-Daten eingeben muss, um in das System zu kommen. Man macht sich bei dieser Methode die Standardkonfiguration der Bash zunutze, die bei jedem Login gewisse Dateien ausführt.
 
==== Konfiguration ====
Zuerst öffnet oder erstellt man die Datei „.[[bashrc]]“ (bzw. „.bash_profile“ – siehe nächster Abschnitt) und erstellt dort eine If-Abrage.
 
if [ "$(tty)" = "/dev/vc/1" ]; then
  startx
  logout
fi
 
Diese Abfrage prüft, ob das verwendete Terminal das erste ist. Dies ist nach dem booten bei Standardkonfiguration der Fall. Wenn man sich hier nun mit seinem Benutzernamen anmeldet, und die .bashrc ausgeführt wird, wird über „startx“ umgehend X gestartet. Wenn man X wieder beendet (entweder durch Ausloggen aus Openbox, oder z.B. das Drücken von Strg+Alt+Backspace), wird man automatisch wieder ausgeloggt.
 
==== Problembehebung ====
Sollte die vorgestellte Technik nicht funktionieren, so kann man über einen Befehl nachprüfen, unter welchem Namen das aktuelle Terminal dem System bekannt ist.
 
tty
 
Das, was dieser Befehl zurückgibt, baut man nun anstelle von „/dev/vc/1“ in die If-Abfrage ein und loggt sich aus. Wenn man sich nun wieder einloggt, aber X immer noch nicht startet, kann es daran liegen, dass anstelle der „.bashrc“ die „.bash_profile“ automatisch ausgeführt wird. Nun hat man zwei Möglichkeiten: Entweder, man schreibt die Abfrage in die „.bash_profile“, oder man schreibt in die „.bash_profile“, dass die „.bashrc“ ausgeführt werden soll.
 
source .bashrc
 
Dies hat den Vorteil, dass man alles über die „.bashrc“ hat. Diese Datei wird wesentlich häufiger erwähnt, und man muss sich beim Konfigurieren nicht erst Gedanken darüber machen, ob und wo man etwas reinschreiben muss, da „.bash_profile“ auf einem so konfigurierten System ja nichts weiter macht, als „.bashrc“ zu starten.
 
Man kann auch einen Link anlegen, wovon aber abzuraten ist. Falls man doch irgendwann mal die „.bashrc“ und die „.bash_profile“ mit unterschiedlichen Inhalten füllen möchte, muss man nämlich erst wieder den Link entfernen und die Datei neu anlegen. Mit der Ausführungsanweisung erspart man sich im vorherein unnötige Arbeit.
 
==== Automatisch ====
Es besteht auch die Möglichkeit, beim Systemstart automatisch in X zu starten. Dies wird mittels [[Runlevel]]s kontrolliert. Diese Runlevel werden in der Datei „/etc/inittab“ definiert. Diese Datei ist also zu bearbeiten. Es gibt dort einen Abschnitt, der Standardmäßig so aussehen wird:
 
## Only one of the following two lines can be uncommented!
# Boot to console
id:3:initdefault:
# Boot to X11
#id:5:initdefault:
 
Dieser Abschnitt muss geändert werden, so dass standardmäßig in ''Runlevel 5'' gebootet wird. Dazu wird die Zeile „id:3:initdefault:“ auskommentiert, und die Zeile „#id:5:initdefault:“ einkommentiert. Zusätzlich muss weiter unten in dem Abschnitt „# Example lines for starting a login manager“ ebenfalls etwas angepasst werden. Dort müssen entweder alle Zeilen auskommentiert werden, und eine neue Zeile hinzugefügt werden, oder die vorhandene bereits einkommentierte Zeile geändert werden:
 
x:5:once:/bin/su BENUTZERNAME -l -c "/bin/bash -l -c startx"
 
BENUTZERNAME muss natürlich durch den tatsächlichen Benutzernamen ersetzt werden. Es ist hierbei zudem  zu beachten, dass nach dem Booten automatisch X mit den Rechten und den sonstigen Einstellungen des angegebenen Benutzers gestartet wird, und zwar ohne dass das Kennwort für diesen Benutzer angegeben werden muss, und ebenfalls, ohne dass man den X-Start je Systemstart wählen kann.
 
Diese Option eignet sich daher nur, wenn man sich sicher ist, dass man immer automatisch nach dem Starten des Systems mit diesem Benutzer eingeloggt sein möchte. Jeder, der Zugriff auf den Rechner hat, kann mit diesem Benutzeraccount dann nach dem Start ohne Passworteingabe arbeiten. Man sollte diese Technik also nicht an Mehrbenutzersystemen oder sicherheitskritischen Systemen anwenden.


=== Mit Login-Manager ===
Weitere Informationen hierzu finden sich im Artikel über [[X#Xorg starten]].
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]].


== Konfigurationswerkzeuge und -Dateien ==
== Konfigurationswerkzeuge und -Dateien ==
Zeile 81: Zeile 31:
[[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 „~/.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 „~/.config/openbox/rc.xml“, jedoch gibt es für diese Aufgabe auch das grafische Interface "OBconf", welches zunächst installiert werden muss


  pacman -Sy 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 „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 -Sy 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 – derzeit 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 „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.


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 ==
Zeile 154: Zeile 105:


… 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 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 ===
[[Bild:openbox_icons_menu.png|thumb|Beispielmenü mit Icons]]
Wenn man Menü-Icons verwenden möchte, muss man deren Verwendung zuerst in der <code>rc.xml</code> aktivieren, hierzu muss der <code>menu</code>-Abschnitt um <code><showIcons>yes</showIcons></code> erweitert werden. Nun können in der <code>menu.xml</code> 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 <code>openbox --reconfigure</code> oder, falls die Icons nicht übernommen werden, <code>openbox --restart</code> 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“ entweder der Fenstername, die „Rolle“ des Fensters oder dessen Typ angegeben werden. Diese Angaben können auch kombiniert werden, um die Fenster spezieller zu definieren. Ermitteln kann man die nötigen Informationen mittels des Programms „xprop“, das Teil des Paketes „xorg-utils“ ist.
Damit Openbox dies bewerkstelligen kann, muss in der Datei <code>~/.config/openbox/rc.xml</code> im <code><applications></code>-Block ein Unterblock <code><application></code> mit folgender Syntax angelegt werden.
 
<applications>
  ...
  <application name="NAME" class="CLASS" role="ROLE" type="TYPE">
    ...PROPERTIES...
  </application>
  ...
</applications>


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


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 …
obxprop | grep "^_OB_APP"


WM_CLASS(STRING) = "Navigator", "Firefox"
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
WM_NAME(COMPOUND_TEXT) = "Openbox – wiki.archlinux.de - Mozilla Firefox"
WM_WINDOW_ROLE(STRING) = "browser"
_NET_WM_WINDOW_TYPE(ATOM) = _NET_WM_WINDOW_TYPE_NORMAL


Das System dahinter ist sehr einfach zu erkennen. WM_CLASS definiert die Fensterklasse. In diesem Fall „Navigator“ und „Firefox“. WM_NAME zeigt den Fenstertitel an. Also das, was in der Fensterleiste von Openbox angezeigt wird. WM_WINDOW_ROLE gibt an, was für eine „Rolle“ das Fenster hat, wobei diese Angabe nicht genormt ist. _NET_WM_WINDOW_TYPE definiert schlussendlich den Typen des Fensters.
_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 „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 <code>rc.xml</code> eine Anwendungsregel für Firefox definieren. Dazu erstellt man im Abschnitt <code><applications></code> 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 151:
  </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 neukonfiguriert werden, dies geschieht mittels …
Zeile 190: Zeile 159:
… 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 170:
  </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 <code>Gajim.py</code> 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 178:


=== Weiteres ===
=== Weiteres ===
Über weitere, 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 <code>rc.xml</code> 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 185:


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 <code>MoveResizeTo</code> 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 ==
Zeile 227: Zeile 205:
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:
Zeile 233: Zeile 211:
* [[Pypanel]]
* [[Pypanel]]
* [[Fbpanel]]
* [[Fbpanel]]
* [https://github.com/vzxwco/neap neap], ein Systray-Pager
* ObPager (siehe oben)
* ObPager (siehe oben)
* Weitere Panels siehe [[Liste von Panels]]
* Weitere Panels siehe [[Liste von Panels]]
Zeile 239: Zeile 218:


=== Dateimanager ===
=== Dateimanager ===
Es gibt zahlreiche Dateimanager. Deshalb hier nur eine kleine Auswahl.
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]].
 
=== 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:


* [[Thunar]] ist der Standard-Dateimanager der Xfce-Desktop-Umgebung
* [[Cairo Composite Manager]]
* [http://www.fly-bird.org/news.php FlyBird]
* [[Compton]]
* [[PCManFM]]
* [https://wiki.archlinux.org/index.php/Xcompmgr Xcompmgr] {{sprache|en}}
* [http://roscidus.com/desktop/ ROX] kann auch Desktop Icons darstellen
* [http://roland65.free.fr/xfe/ X File Explorer] – erinnert an den „Explorer“ von Windows
* [http://emelfm.sourceforge.net/ emelFM] sehr schlank, Gtk-1
* [http://www.obsession.se/gentoo/ gentoo] sehr schlank, Gtk-1
* [http://tuxcmd.sourceforge.net/ TuxCmd] sehr schlank, Bedienung wie bei mc


Natürlich kann auch der [[GNOME]]-Dateimanager Nautilus verwendet werden. Er ist zwar nicht so schlank wie die oben genannten, hat aber den Vorteil, dass z.B. remote SSH, FTP und Samba direkt unterstüzt werden. Zudem kann Nautilus, ebenso wie einige der oben genannten Dateimanager die Desktop-Icons anzeigen.
==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}}


== Links ==
* http://www.icculus.org/openbox
* http://de.wikipedia.org/wiki/Openbox
* http://www.box-look.org
* http://themes.freshmeat.net/browse/1086/
* http://urukrama.wordpress.com/openbox-guide/


[[Kategorie:Fenstermanager]]
[[Kategorie:Fenstermanager]]
[[Kategorie:Konfiguration]]
[[en:Openbox]]
[[Kategorie: X11]]
__NOEDITSECTION__

Version vom 26. Dezember 2015, 16:44 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 Datei „~/.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 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.

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 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 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.

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 obpager nicht in den Repositories, sondern derzeit nur im 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 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

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 neukonfiguriert 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 (s.o.) reichen.

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 Dateimanager-Wiki-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