I3: Unterschied zwischen den Versionen

Aus wiki.archlinux.de
Schreibfehler "Wer die wer die" ausgebessert
K Verschiebung community -> extra
 
(19 dazwischenliegende Versionen von 8 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
{{SEITENTITEL:i3}}{{righttoc}}
{{SEITENTITEL:i3}}{{righttoc}}
i3 ist ein durch [[wmii]] inspirierter Tiling Windowmanager mit Floating Support, welcher sich momentan noch stark in der Entwicklung befindet.
i3 ist ein durch [[wmii]] inspirierter Tiling-Windowmanager mit Floating-Support, der sich momentan noch stark in der Entwicklung befindet.


==Installation==
{{installation
i3 ist mittels des community Repositories verfügbar, man kann entweder die Gruppe i3 installieren:
|name=i3
# pacman -S i3
|repo=extra
oder wenn man nur den Fenstermanager möchte das Paket i3-wm:
|paket=i3
# pacman -S i3-wm
|zusatz=dmenu
Wer die fortwährende Entwicklung benutzen möchte, findet das Paket [http://aur.archlinux.org/packages.php?ID=24665 i3-git] im [[AUR]].
|zusatzinfo=ein gut mit i3 zusammenarbeitender Launcher}}


Ferner sollte man '''dmenu''' installieren um einen Launcher zur Verfügung zu haben, dies geschieht mittels:
Wenn man nur den Fenstermanager möchte, nimmt man stattdessen {{paket|i3-wm}}. Wer die fortwährende Entwicklung benutzen möchte, findet das Paket {{AUR|i3-git}} im [[AUR]].
# pacman -S dmenu
 
Um i3 über {{ic|startx}} starten zu können, ist die [[xinitrc]] zu editieren, diese sollte den folgenden Eintrag enthalten.


Um '''i3''' über startx starten zu können, ist die Datei '''~/.xinitrc''' zu editieren, diese sollte den folgenden Eintrag enthalten:
  exec i3
  exec i3


Benutzer des [[Nvidia]] Treibers in Kombination mit mehreren Ausgabegeräten für das Bildsignal sollten ferner zur '''--force-xinerama''' Option greifen:
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 {{ic|--force-xinerama}} benutzen.
 
  exec i3 --force-xinerama
  exec i3 --force-xinerama


== Alternative: i3-gaps ==
[https://github.com/Airblader/i3 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==
== Konfiguration ==
Um die Konfiguration anpassen zu können ist es nötig die globale Konfiguration in den entsprechenden Unterordner des Benutzerverzeichnisses zu kopieren:
Um die Konfiguration anpassen zu können ist es nötig die globale Konfiguration in den entsprechenden Unterordner des Benutzerverzeichnisses zu kopieren:


  $ install -Dm644 /etc/i3/config ~/.i3/config  
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 [[Hintergrundbild_anpassen|externes Programm]] genutzt werden.
 
Unter [http://i3wm.org/docs/userguide.html#configuring i3 User Guide] findet man Details, wie die i3-config zu konfigurieren ist.
 
== Anwendungsstarter ==
i3 benutzt {{paket|dmenu}} als Anwendungsstarter, was per Default mit {{ic|$mod+d}} aufzurufen ist.
 
{{paket|i3-wm}} beinhaltet ''i3-dmenu-desktop'', ein {{wikipedia|Perl_(Programmiersprache)|Perl}}-Wrapper für dmenu, welcher die Desktop Einträge benutzt um eine Liste von allen installierten Anwendungen zu erstellen.
Alternativ kann das Paket {{AUR|j4-dmenu-desktop-git}} benutzt werden, ein Ersatz für i3-dmenu-desktop, welcher um einiges schneller ist.
Eine weitere Möglichkeit ist {{AUR|dmenu-extended}}. Es funktioniert wie dmenu ist aber um einige [https://github.com/markjones112358/dmenu-extended Funktionen] erweitert.
 
== Keybindings ==
In i3 werden Kommandos mit einem modifier key ausgeführt, welcher mit {{ic|$mod}} referenziert wird. Standardmäßig ist das die {{ic|Alt}}-Taste(Mod1); eine populäre Alternative ist {{ic|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.
 
[http://i3wm.org/docs/refcard.html i3 Reference Card] und [http://i3wm.org/docs/userguide.html#_using_i3 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 https://github.com/acrisci/i3-style] || {{AUR|nodejs-i3-style}}
 
*'''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 https://github.com/okraits/j4-make-config] || {{AUR|j4-make-config-git}}
 
== 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 [http://i3wm.org/docs/userguide.html#_configuring_i3bar 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 [[:en:Desktop environment|Desktops]] angebotenen - vor. Dies kann innerhalb von i3 erreicht werden, indem das Panel der Wahl während des Startens gestartet wird.
 
Für das {{Paket|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 {{ic|bar{}}}-Bereich in {{ic|~/.config/i3/config}} auskommentiert wird.
 
'''Polybar'''
 
Es kann auch {{ic|polybar}} anstatt i3-bar verwendet werden.
[https://github.com/polybar/polybar 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 [https://wiki.archlinux.de/title/AUR_Hilfsprogramme AUR_Hilfsprogramm] die polybar installieren:
trizen -S polybar
 
{{ic|polybar}} bietet ein Beispielskript namens {{ic|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 {{ic|/usr/share/doc/polybar/config}} befinden.
 
Nun können sie ihre Bar anzeigen lassen:
$ polybar example
 
Für weitere Informationen können Sie [https://github.com/polybar/polybar 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 {{ic|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 {{ic|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 {{ic|man i3status}} nach.}}
 
== Ersatz für i3status ==
*[[conky]] — Extrem gut erweiterbares Tool zum Überwachen des Systems. In diesem [http://i3wm.org/docs/user-contributed/conky-i3bar.html Tutorial] findet man Hilfe, wie man conky mit i3bar benutzt.
 
[http://conky.sourceforge.net/ http://conky.sourceforge.net/] || {{paket|conky}}
 
*'''i3blocks''' — Via Shellscripts erweiterbar.
 
[https://github.com/vivien/i3blocks https://github.com/vivien/i3blocks] || {{AUR|i3blocks}}
 
*'''i3pystatus''' — Erweiterbare [[Python]] 3 Statusbar mit vielen Plugins und Konfigurationsmöglichkeiten von Haus aus.
 
[https://github.com/enkore/i3pystatus i3pystatus https://github.com/enkore/i3pystatus i3pystatus] || {{AUR|i3pystatus-git}}
 
*'''i3situation''' — Eine weitere [[Python]] 3 Statusbar
 
[https://github.com/HarveyHunt/i3situation https://github.com/HarveyHunt/i3situation] || {{AUR|i3situation-git}}
 
*'''j4status''' — Unterstützt eine Statusleiste, konfigurierbar via Plugins, wurde in C geschrieben.
 
[http://j4status.j4tools.org/ http://j4status.j4tools.org/] || {{AUR|j4status-git}}
 
== Terminal Emulator ==
Standardmäßig wird, wenn {{ic|$mod+Return}} gedrückt wird, das {{ic|i3-sensible-terminal}} Script gestartet, welches ein Terminal aufruft. Siehe {{ic|man i3-sensible-terminal}} für Informationen darüber, in welcher Reihenfolge Terminals aufgerufen werden.
 
Wenn man stattdessen ein [[:en:list_of_applications#Terminal_emulators|Terminal]] seiner Wahl starten möchte, muss folgende Zeile in der {{ic|~/.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 {{ic|~/.config/i3/config}} in den {{ic|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 {{ic|bar{ } }}-Bereich eingetragen:
 
position top
 
== Lautstärke im Systemtray ==
Mit Hilfe folgenden Eintrages in die {{ic|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:
*Der [[Networkmanager]] muss installiert und [[Networkmanager#Dienst_aktivieren|aktiviert]] worden sein.
*Es muss das [[Networkmanager#Gnome|Networkmanager-applet]] installiert sein.
 
Danach muss folgendes in die ~/.xinitrc eingetragen werden - vor {{ic|exec i3}}:
nm-applet --sm-disable &
 
== Numlock aktivieren ==
Eine einfache und schnelle Möglichkeit Numlock zu aktivieren bietet [[Numlock|numlockx]]
 
== Multimedia Tasten ==
Selbstverständlich ist es auch in i3 möglich seine Multimedia Tasten zu benutzen.
 
Mit dem Befehl [[Xmodmap#xev|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 {{paket|alsa-utils}} für die Musik und {{paket|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 [http://i3wm.org/docs/userguide.html#keybindings i3 User Guide] zu finden.
 
== Bildschirmschoner und Energieverwaltung ==
Mit [[DPMS]] kann man den Bildschirm abdunkeln, in den Ruhezustand bringen oder ausschalten. Folgendes in der {{ic|~/.config/i3/config}} sorgt dafür, dass der Monitor sich nach 10 Minuten ausschaltet.
exec --no-startup-id xset dpms 600
 
Mit {{AUR|xss-lock-git}} kann eine Bildschirmsperre für die i3-Session angelegt werden.
xss-lock -- i3lock -i background_image &
 
Alternativ kann {{paket|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 {{wikipedia|Tastenkombination|Hotkeys}} dafür dafür einzurichten. Als erstes müssen wir ein Script dafür erstellen und unter dem Namen {{ic|i3exit}} speichern. Unbedingt dran denken die datei mit chmod +x ausführbar zu machen und irgendwo in dem $PATH platzieren. Das Script benötigt {{paket|polkit}}, damit auch unprivilegierte User Zugriff auf die [[Systemd#Systemverwaltung_mit_systemctl|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 {{AUR|xss-lock-git}} benutzt wird, muss {{ic|xset s activate}} aufgerufen werden um die Sperre zu aktivieren.
*Mit {{AUR|xautolock}} lautet der Befehl {{ic| xautolock -locknow}}
}}
 
Jetzt müssen die folgenden Zeilen in die {{ic|~/.config/i3/config}} eingefügt werden.


Nun sollte man vor der Anpassung unbedingt die man page lesen, welche sehr griffig die Konfigurationsmöglichkeiten erklärt.
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"


$ man 1 i3
Hier ist eine Liste weiterer [[:en:List_of_applications/Security#Screen_lockers|Screenlocker]]


==Weblinks==
== Weblinks ==
* [http://i3.zekjur.net/ Homepage] {{sprache|en}}
* [http://www.i3wm.org/ Homepage] {{sprache|en}}
* [http://i3.zekjur.net/docs/userguide.html User Guide] {{sprache|en}}
* [http://i3wm.org/docs/userguide.html User Guide] {{sprache|en}}


[[Kategorie:Fenstermanager]]
[[Kategorie:Fenstermanager]]
[[en:i3]]
[[en:i3]]

Aktuelle Version vom 24. Mai 2023, 18:23 Uhr

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