i3

Aus wiki.archlinux.de

i3 ist ein durch wmii inspirierter Tiling-Windowmanager mit Floating-Support, der sich momentan noch stark in der Entwicklung befindet.

Installation

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

# i3 an sich
pacman -S i3

# ein gut mit i3 zusammenarbeitender Launcher
pacman -S dmenu

Wenn man nur den Fenstermanager möchte, nimmt man stattdessen i3-wm. Wer die fortwährende Entwicklung benutzen möchte, findet das Paket i3-gitAUR im AUR.

Um i3 über startx starten zu können, ist die xinitrc zu editieren, diese sollte den folgenden Eintrag enthalten.

exec i3

Wenn stattdessen i3 mit log gestartet werden soll, muss folgendes in die xinitrc

exec i3 -V >> ~/.i3/i3log-$(date +'%F-%k-%M-%S') 2>&1

Das log ist unter ~/.i3 zu finden.

Benutzer des Nvidia-Treibers in Kombination mit mehreren Ausgabegeräten für das Bildsignal sollten ferner die Option --force-xinerama benutzen.

exec i3 --force-xinerama

Alternative: i3-gaps

i3-gaps ist ein fork von i3-wm. In Grunde genommen sind sie identisch, jedoch kann man bei i3-gaps, wie der Name schon sagt, Lücken zwischen den Fenstern erstellen. Das hört sich zuerst etwas befremdet an, jedoch kann man auf der Webseite von i3-gaps ein gutes Beispielbild erkennen. Die Einstellungen von i3-wm gibt's auch bei i3-gaps, somit muss man beim wechseln nichts verändern, sondern (man kann) eher etwas hinzufügen :). Sie können also einfach, wenn sie sich für i3-gaps entscheiden, dieser Anleitung folgen.

Konfiguration

Um die Konfiguration anpassen zu können ist es nötig die globale Konfiguration in den entsprechenden Unterordner des Benutzerverzeichnisses zu kopieren:

cp /etc/i3/config ~/.i3/config 

Nun sollte man vor der Anpassung unbedingt die Manpage lesen, die sehr griffig die Konfigurationsmöglichkeiten erklärt.

man 1 i3

Um ein Desktop-Hintergrund zu setzten muss ein externes Programm genutzt werden.

Unter i3 User Guide findet man Details, wie die i3-config zu konfigurieren ist.

Anwendungsstarter

i3 benutzt dmenu als Anwendungsstarter, was per Default mit $mod+d aufzurufen ist.

i3-wm beinhaltet i3-dmenu-desktop, ein Perl-Wrapper für dmenu, welcher die Desktop Einträge benutzt um eine Liste von allen installierten Anwendungen zu erstellen. Alternativ kann das Paket j4-dmenu-desktop-gitAUR benutzt werden, ein Ersatz für i3-dmenu-desktop, welcher um einiges schneller ist. Eine weitere Möglichkeit ist dmenu-extendedAUR. Es funktioniert wie dmenu ist aber um einige Funktionen erweitert.

Keybindings

In i3 werden Kommandos mit einem modifier key ausgeführt, welcher mit $mod referenziert wird. Standardmäßig ist das die Alt-Taste(Mod1); eine populäre Alternative ist Super(Mod4). Will man zum Beispiel für alle Shortcuts Super benutzen, geht es schnell mit einem einfachen Text-Editor die i3-config zu öffnen, und alle Mod1 durch Mod4 zu ersetzen.

i3 Reference Card und using i3 geben hier gute Hilfestellungen auf englisch.

Farbverwaltung

Die i3-config erlaubt die Konfiguration der Farbverzierungen. Die Syntax macht es unpraktisch Themes zu erstellen oder auszutauschen. Es gibt allerdings mehrere Projekte, die das Ganze einfacher gestalten und beinhaltet - von Usern beigetragene - Themes.

  • i3-style — Modifiziert deine Config aus einem Theme, welches in einem JSON Object gespeichert wird. Für häufiges Bearbeiten der Farben designed.

https://github.com/acrisci/i3-style || nodejs-i3-styleAUR

  • j4-make-config — Füge deine Config mit einer Sammlung von Themes oder Stücken von Configs zusammen.

https://github.com/okraits/j4-make-config || j4-make-config-gitAUR

i3bar

Als Ergänzung, um Arbeitsplatz-Informationen anzuzeigen, kann i3bar als Input oder Alternative für i3status dienen, so, wie im nächsten Abschnitt gezeigt. Zum Beispiel:

~/.config/i3/config

bar {

   output            LVDS1
   status_command    i3status
   position          top
   mode              hide
   workspace_buttons yes
   tray_output       none
   font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1

   colors {
       background #000000
       statusline #ffffff
       focused_workspace  #ffffff #285577
       active_workspace   #ffffff #333333
       inactive_workspace #888888 #222222
       urgent_workspace   #ffffff #900000
   }
}

Unter i3 User Guide gibt es mehr Informationen - auf englisch.

i3bar Alternativen

Einige User ziehen eventuell andere Panels - wie z.B. die von den regulären Desktops angebotenen - vor. Dies kann innerhalb von i3 erreicht werden, indem das Panel der Wahl während des Startens gestartet wird.

Für das xfce4-panel muss folgendes in ~/.config/i3/config eingefügt werden:

exec --no-startup-id xfce4-panel --disable-wm-check

Alternativ kann das Starten auch über die xinitrc geregelt werden.

xfce4-panel --disable-wm-check &

i3bar kann abgeschaltet werden, indem der bar{}-Bereich in ~/.config/i3/config auskommentiert wird.

Polybar

Es kann auch polybar anstatt i3-bar verwendet werden. polybar bietet sehr viele Konfigurationsmöglichkeiten, unter anderem hinzufügen von Icons, durchsichtigkeit, eigene Programme an der Bar anheften und vieles mehr! Polybar steckt in den AURs. Sie können also mithilfe von ihrem AUR_Hilfsprogramm die polybar installieren:

trizen -S polybar

polybar bietet ein Beispielskript namens example an, welches sie zuerst kopieren sollten:

$ install -Dm644 /usr/local/share/doc/polybar/config $HOME/.config/polybar/config

Hinweis: Die Datei könnte sich auch unter /usr/share/doc/polybar/config befinden.

Nun können sie ihre Bar anzeigen lassen:

$ polybar example

Für weitere Informationen können Sie hier draufdrücken.

i3status

Zuerst muss die default config in das Homeverzeichnis kopiert werden:

$ cp /etc/i3status.conf ~/.config/i3status/config

In der default config sind nicht alle plugins definiert, siehe man 1 i3status für mehr Informationen

Hinweis: Die Beispiel config nutzt eth0 und wlan0 als Schnittstellen. Falls diese nicht passen, kann man mit Hilfe von ip link die richtige Schnittstellen ermitteln. Möglicherweise passen andere Sachen, wie zum Beispiel der Pfad für den Akku, ebenfalls nicht, siehe dafür unter man i3status nach.

Ersatz für i3status

  • conky — Extrem gut erweiterbares Tool zum Überwachen des Systems. In diesem Tutorial findet man Hilfe, wie man conky mit i3bar benutzt.

http://conky.sourceforge.net/ || conky

  • i3blocks — Via Shellscripts erweiterbar.

https://github.com/vivien/i3blocks || i3blocksAUR

  • i3pystatus — Erweiterbare Python 3 Statusbar mit vielen Plugins und Konfigurationsmöglichkeiten von Haus aus.

i3pystatus https://github.com/enkore/i3pystatus i3pystatus || i3pystatus-gitAUR

  • i3situation — Eine weitere Python 3 Statusbar

https://github.com/HarveyHunt/i3situation || i3situation-gitAUR

  • j4status — Unterstützt eine Statusleiste, konfigurierbar via Plugins, wurde in C geschrieben.

http://j4status.j4tools.org/ || j4status-gitAUR

Terminal Emulator

Standardmäßig wird, wenn $mod+Return gedrückt wird, das i3-sensible-terminal Script gestartet, welches ein Terminal aufruft. Siehe man i3-sensible-terminal für Informationen darüber, in welcher Reihenfolge Terminals aufgerufen werden.

Wenn man stattdessen ein Terminal seiner Wahl starten möchte, muss folgende Zeile in der ~/.config/i3/config bearbeitet werden:

bindsym $mod+Return exec i3-sensible-terminal

und zum Beispiel durch

bindsym $mod+Return exec urxvt

ersetzt werden.

Systemtray

Das Systemtray kann aktiviert werden, indem man einen der folgenden Werte in die ~/.config/i3/config in den bar{ }-Abschnitt einträgt.

bar {
   tray_output primary
}

für den Hauptbildschirm

oder

bar {
   tray_output LVDS1
}

für einen bestimmten Bildschirm.

Den richtigen Bildschirmnamen findet man leicht mit RandR heraus.

Soll die i3bar oben am Bildschirmrand platziert werden, muss man folgendes, ebenfalls in den bar{ } -Bereich eingetragen:

position top

Lautstärke im Systemtray

Mit Hilfe folgenden Eintrages in die i3stats config bekommt man eine Anzeige im Systemtray, welche die Lautstärke anzeigt.

order += "volume master"
volume master {
       format = "%volume"
       format_muted = "muted (%volume)"
       device = "default"
       mixer = "Master"
       mixer_idx = 0
}

NetworkManager im Systemtray

Möchte man den NetworkManager im Systemtray aktivieren, müssen folgende Dinge vorher bedacht worden sein:

Danach muss folgendes in die ~/.xinitrc eingetragen werden - vor exec i3:

nm-applet --sm-disable &

Numlock aktivieren

Eine einfache und schnelle Möglichkeit Numlock zu aktivieren bietet numlockx

Multimedia Tasten

Selbstverständlich ist es auch in i3 möglich seine Multimedia Tasten zu benutzen.

Mit dem Befehl xev lässt sich der benötigte Keycode herausfinden.

Mit Xmodmap -pke lässt sich der passende Name des dazugehörigen Keycodes finden.

Hier ein beispielhafter Auszug aus meiner Config für Helligkeits-, sowie die Lautstärke-Tasten:

Hinweis: Für meine Config werden alsa-utils für die Musik und xbacklight für die Bildschirmhelligkeit benutzt.

#####Custom settings#####

#Brightness Up/Down
bindcode 232 exec xbacklight -10
bindcode 233 exec xbacklight +10

#Volume Up/Down
bindcode 122 exec amixer -q set Master 5%-
bindcode 123 exec amixer -q set Master 5%+
bindcode 121 exec amixer -q set Master toggle

Weitere Informationen sind im i3 User Guide zu finden.

Bildschirmschoner und Energieverwaltung

Mit DPMS kann man den Bildschirm abdunkeln, in den Ruhezustand bringen oder ausschalten. Folgendes in der ~/.config/i3/config sorgt dafür, dass der Monitor sich nach 10 Minuten ausschaltet.

exec --no-startup-id xset dpms 600

Mit xss-lock-gitAUR kann eine Bildschirmsperre für die i3-Session angelegt werden.

xss-lock -- i3lock -i background_image &

Alternativ kann xautolock benutzt werden, um den Bildschirm nach einer gewissen Zeitspanne zu sperren.

xautolock -time 10 -locker i3lock &

Herunterfahren, Neustarten, Bildschirmsperre

In i3 gibt es keine Herunterfahr-, Neustart- oder Bildschirmsperr-Knöpfe. Es ist aber möglich sich Hotkeys dafür dafür einzurichten. Als erstes müssen wir ein Script dafür erstellen und unter dem Namen i3exit speichern. Unbedingt dran denken die datei mit chmod +x ausführbar zu machen und irgendwo in dem $PATH platzieren. Das Script benötigt polkit, damit auch unprivilegierte User Zugriff auf die Systemverwaltung haben.

#!/bin/sh
lock() {
   i3lock
}

case "$1" in
   lock)
       lock
       ;;
   logout)
       i3-msg exit
       ;;
   suspend)
       lock && systemctl suspend
       ;;
   hibernate)
       lock && systemctl hibernate
       ;;
   reboot)
       systemctl reboot
       ;;
   shutdown)
       systemctl poweroff
       ;;
   *)
       echo "Usage: $0 {lock|logout|suspend|hibernate|reboot|shutdown}"
       exit 2
esac

exit 0

Hinweis:

  • Wenn xss-lock-gitAUR benutzt wird, muss xset s activate aufgerufen werden um die Sperre zu aktivieren.
  • Mit xautolockAUR lautet der Befehl xautolock -locknow

Jetzt müssen die folgenden Zeilen in die ~/.config/i3/config eingefügt werden.

set $mode_system System (l) lock, (e) logout, (s) suspend, (h) hibernate, (r) reboot, (Shift+s) shutdown
mode "$mode_system" {
   bindsym l exec --no-startup-id i3exit lock, mode "default"
   bindsym e exec --no-startup-id i3exit logout, mode "default"
   bindsym s exec --no-startup-id i3exit suspend, mode "default"
   bindsym h exec --no-startup-id i3exit hibernate, mode "default"
   bindsym r exec --no-startup-id i3exit reboot, mode "default"
   bindsym Shift+s exec --no-startup-id i3exit shutdown, mode "default"  

   # back to normal: Enter or Escape
   bindsym Return mode "default"
   bindsym Escape mode "default"
}
bindsym $mod+Pause mode "$mode_system"

Hier ist eine Liste weiterer Screenlocker

Weblinks