i3 (Русский)

From ArchWiki

Состояние перевода: На этой странице представлен перевод статьи i3. Дата последней синхронизации: 14 апреля 2022. Вы можете помочь синхронизировать перевод, если в английской версии произошли изменения.

i3 — это динамический тайловый оконный менеджер, вдохновлённый wmii и нацеленный на разработчиков и опытных пользователей.

Среди заявленных целей i3 — понятная документация, надлежащая поддержка нескольких мониторов, древовидная структура для окон и различные режимы, как в vim.

Установка

Установите пакет i3-wm.

Также есть группа пакетов i3. В её состав входят менеджер окон, блокировщик экрана и две программы, которые записывают строку статуса в i3bar через stdout.

Примечание: i3-wm конфликтует с i3-gaps (форк i3), и при установке этой группы по умолчанию выбирается i3-gaps.

Запуск

Из консоли

Запустите i3 с помощью xinit.

Экранный менеджер

В состав i3-wm входят i3.desktop и Xsession, который запускает оконный менеджер. i3-with-shmlog.desktop включает журнал (полезно для отладки). i3-gnomeAUR интегрирует i3 с GNOME.

Использование

Для большей информации смотрите официальную документацию, а именно i3 Пользовательское Руководство.

Назначение клавиш

В i3 команды вызываются с помощью клавиши-модификатора, называющейся $mod. По умолчанию (Mod1) это Alt, но также популярна альтернатива (Mod4), которая известна как Super. Клавиша Super обычно изображается на клавиатуре со значком Windows, а на клавиатуре Apple она представлена в виде клавиши Command.

Смотрите справочную карту i3 и Использование i3 по умолчанию. Смотрите назначение клавиш чтобы добавить новые сочетания/горячие клавиши.

Пользователи не-Qwerty раскладок могут захотеть обойтись без «мастера настройки, как описано ниже.

Если вы переключаетесь между несколькими оконными менеджерами или средами рабочего стола, можно использовать sxhkd или другую программу, не зависящую от среды, для управления сочетаниями клавиш. Дополнительную информацию можно найти в статье Горячие клавиши#Xorg.

Контейнеры

i3 управляет окнами в виде древовидной структуры, с контейнерами, как со строительными блоками. Эта структура разделяется по горизонтали и вертикали. Контейнеры по умолчанию тайловые (tiled), но могут быть установлены как стэковые лэйауты (stacked layouts), таки в плавающем режиме (floating) (например для диалоговых окон). Плавающие окна всегда поверх.

Для подробностей смотрите Дерево i3 и Данные древовидной структуры и контейнеров.

Запуск приложений

i3 использует dmenu в качестве запуска приложений, которое вызывается по умолчанию $mod+d. Так как это опциональная зависимость, перед использованием нужно вручную установить пакет dmenu.

i3-wm содержит i3-dmenu-desktop, Perl оболочку для dmenu который использует ярлыки приложений для создания списка всех установленных приложений. Кроме того, можно использовать j4-dmenu-desktop-gitAUR.

rofi — это популярная замена dmenu и других программ, которые могут отображать список ярлыков приложений.

Использование KRunner для запуска приложений в KDE Plasma/i3

Можно запустить i3 вместе с KDE Plasma, как описано здесь: KDE (Русский)#Использование альтернативного оконного менеджера

При запуске Plasma с KDEWM=/usr/bin/i3 можно установить KRunner в качестве альтернативной программы запуска приложений с помощью $mod+d, добавив следующее в конфигурацию i3:

~/.config/i3/config
set $menu --no-startup-id qdbus org.kde.krunner /App display
bindsym $mod+d exec $menu

Настройка

Для подробностей смотрите Настройку i3. Данная статья предполагает, что файл настроек i3 расположен в папке ~/.config.

Мастер настройки и альтернативные раскладки клавиатуры

При первом запуске i3 предлагает запустить мастер настройки i3-config-wizard. Этот инструмент создаёт файл ~/.config/i3/config, беря за основу шаблон /etc/i3/config.keycodes. Он вносит в шаблон два изменения:

  1. Он просит пользователя выбрать клавишу-модификатор по умолчанию, который он добавляет в шаблон в виде одной строки, например, set $mod Mod1; и
  2. заменяет все строки bindcode на строки bindsym, соответствующие текущей раскладке клавиатуры пользователя.

Шаг 2 предназначен для того, чтобы гарантировать, что четыре навигационных сочетания клавиш, j, k, l и ; на Qwerty-клавиатуре будут отображены на символы клавиш, которые имеют такое же расположение, например, h, t, n, s на клавиатуре Dvorak. Побочным эффектом этой магии является то, что до пятнадцати других клавиш могут быть переадресованы таким образом, что это нарушит мнемонику — так, для пользователя Dvorak "перезапуск" ("restart") будет привязан к $mod1+p вместо $mod1+r, "разделение по горизонтали" ("split horizontally") будет привязано к $mod1+d вместо $mod1+h, и так далее.

Поэтому пользователи альтернативных раскладок клавиатуры, которым нужны простые привязки клавиш, соответствующие привязкам, приведённым в руководствах, могут предпочесть обойтись без «мастера настройки». Это можно сделать, просто скопировав /etc/i3/config в ~/.config/i3/config (или ~/.i3/config) и отредактировав этот файл.

Обратите внимание, что также возможна конфигурация на основе кодов клавиш, например, для пользователей, которые часто переключаются между раскладками клавиатуры, но хотят, чтобы привязки i3 оставались неизменными.

Автозапуск программ

Добавьте команду exec в файл ~/.config/i3/config. Например:

exec terminator

Также можно использовать XDG Autostart.

i3bar

В дополнение к показу информации рабочих областей, i3 bar может выступать в качестве входных данных для i3status или альтернативы, такие как те, которые упомянуты в следующем разделе. Например:

~/.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
    }
}

За дополнительной информацией обращайтесь в раздел Configuring i3bar официального руководства пользователя.

Альтернативы i3bar

Некоторые пользователи предпочитают панели, такие как те, которые предусмотрены обычными средами рабочего стола. Это может быть реализовано в i3 путём запуска приложения панели во время загрузки.

Для панели XFCE (xfce4-panel), добавьте следующую строку в любом месте ~/.config/i3/config:

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

Можно отключить i3bar, закомментировав секцию bar{ } в ~/.config/i3/config, или добавить сочетание клавиш для его переключения:

~/.config/i3/config
# bar toggle, hide or show 
bindsym $mod+m bar mode toggle

Таким образом, вы можете показать или скрыть бар когда пожелаете.

Альтернативы, не привязанные к среде рабочего стола:

  • polybar — Быстрый и простой в использовании инструмент для создания панелей статуса.
https://github.com/jaagr/polybar || polybar
  • excalibar — Лёгкий, но настраиваемый статус-бар, написанный на языке C.
https://github.com/cylgom/excalibar || excalibar-gitAUR

i3status

Скопируйте файлы настроек по умолчанию в домашний каталог:

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

Не все плагины определены в настройках по умолчанию, и некоторые значения настроек могут быть недействительными для вашей системы, поэтому должны быть внесены соответствующие изменения. Для подробностей смотрите i3status(1).

Замены i3status

  • conky — Высоко расширяемая система мониторинга. Для использования с i3bar смотрите этот учебник.
https://github.com/brndnmtthws/conky || conky
  • i3blocks — Расширяется с помощью shell-скриптов. Может обрабатывать события мыши, прерывания, и определение интервалов регенерации на основе каждого блока.
https://github.com/vivien/i3blocks || i3blocks
  • i3pystatus — Расширяемый Python 3 статус бар со множеством плагинов и опций настроек по умолчанию.
https://github.com/enkore/i3pystatus i3pystatus || i3pystatus-gitAUR
  • j4status — Обеспечивает строку статуса, настраиваемую с помощью плагинов, написан на C. Пакет j4status-plugins-gitAUR предоставляет дополнительные плагины.
https://sardemff7.github.io/j4status/ || j4status-gitAUR
  • goi3bar — Замена i3status, написанная на языке Go. Управляемый конфигурационным файлом, с несколькими плагинами, опциями параллелизма и богатой поддержкой плагинов.
https://github.com/denbeigh2000/goi3bar/ || goi3bar-gitAUR
  • goblocks — Быстрая, лёгкая замена i3status, написанная на языке Go.
https://github.com/davidscholberg/goblocks || goblocksAUR
  • bumblebee-status — Генератор строк состояния Python с возможностью оформления.
https://github.com/tobi-wan-kenobi/bumblebee-status || bumblebee-statusAUR
  • ty3status — Замена i3status, написанная на языке Typescript. Построена с первоклассной поддержкой блоков javascript.
https://github.com/mrkmg/ty3status || ty3status-gitAUR
  • i3status-rust — Высокоэффективная и многофункциональная замена, написанная на языке Rust. Может обрабатывать push-обновления, индивидуальные интервалы обновления, тематизацию и события нажатия.
https://github.com/greshake/i3status-rust || i3status-rust
  • Barista — Замена i3status, написанная на языке Go.
https://github.com/soumya92/barista || not packaged? search in AUR

Оболочки для i3status

  • i3cat — Оболочка, написанная на Go, которая может объединить ввод данных из нескольких внешних источников. Может обрабатывать события мыши и перенаправление указаных пользователем сигналов для своих подпроцессов.
https://vincent-petithory.github.io/i3cat/ || i3cat-gitAUR
  • py3status — Расширяемая оболочка i3status написанная на Python.
https://github.com/ultrabug/py3status || py3status
  • YaGoStatus — Еще одна оболочка для i3status (и не только) написанная на Go.
https://github.com/burik666/yagostatus || yagostatus-gitAUR

Шрифты-иконки в строке состояния

Поддержка иконочных шрифтов встроена с i3 версии 4.20.

  • ttf-font-awesome — Масштабируемые векторные иконки, которые могут быть настроены с помощью CSS. Шпаргалка[устаревшая ссылка 2022-09-18], показывающая пункт Unicode для каждого символа.
https://fortawesome.github.io/Font-Awesome/[устаревшая ссылка 2022-09-18] || ttf-font-awesome
  • ttf-font-icons — Непересекающаяся и последовательная смесь Awesome и Ionicons. Она также позволяет избежать дублирования между DejaVu Sans и Awesome.
https://www.dropbox.com/s/9iysh2i0gadi4ic/icons.pdf || ttf-font-iconsAUR.
  • ttf-ionicons — Premium шрифт иконок для Ionic Framework.
https://ionicframework.com/docs/ionicons/ || ttf-ionicons.

Чтобы использовать несколько шрифтов, в файле настроек укажите резервные шрифты через запятую:

~/.config/i3/config
bar {
  ...
  font pango:DejaVu Sans Mono, Icons 8
  ...
}

В соответствии с синтаксисом pango, размер шрифта задается только один раз, в конце списка шрифтов. Установка размера для каждого шрифта приведёт к тому, что все шрифты, кроме последнего, будут игнорироваться.

Добавьте иконки в формат строки в ~/.config/i3status/config используя числа Unicode, приведенные в шпаргалке, указанной выше. Метод ввода будет варьироваться между текстовыми редакторами. Например, чтобы вставить значок "heart" (номер unicode f004):

  • в различных текстовых редакторах графического интерфейса (например gedit, Leafpad) и терминалов (например GNOME Terminal, xfce4-terminal): ctrl+shift+u, f004, Enter
  • в Emacs: ctrl+x, 8, Enter, f004, Enter
  • в Vim (Русский) (в режиме вставки): Ctrl+v, uf004
  • в urxvt (Русский): удерживая Ctrl+Shift, наберите f004

Эмулятор терминала

По умолчанию при нажатии $mod+Enter запускается i3-sensible-terminal — скрипт, вызывающий терминал. Порядок терминалов, которые он пытается запустить, описан в i3-sensible-terminal(1).

Чтобы вместо него запускался выбранный вами терминал, измените эту строку в ~/.config/i3/config:

bindsym $mod+Return exec i3-sensible-terminal

В качестве альтернативы можно установить переменную окружения $TERMINAL.

Отключение клика по заголовку

Добавьте bindsym button1 nop, чтобы не переключать фокус на окно, когда вы щелкёете по его заголовку. Полезно, если ваша разметка по умолчанию имеет вкладки, и вы часто не успеваете щёлкнуть вкладки i3, а не что-то в приложении.

Советы и рекомендации

Быстрый переход к открытому окну

  • quickswitch-i3 — Python-утилита для быстрого перехода к окнам и определения их местоположения в i3
https://github.com/OliverUv/quickswitch-for-i3/ || quickswitch-i3AUR
  • i3-wm-scripts — поиск и переход к окнам с поиском по регулярному выражению
https://github.com/yiuin/i3-wm-scripts || not packaged? search in AUR
  • rofi — Search and jump to open and scratchpad window
https://github.com/davatorium/rofi || rofi
  • i3-easyfocus — Фокус и выбор окон в i3
https://github.com/cornerman/i3-easyfocus || i3-easyfocus-gitAUR
  • wmfocus — Фокус и выбор окон в i3 и других оконных менеджерах
https://github.com/svenstaro/wmfocus || wmfocus
  • i3-cycle-focus — Функциональность Alt-Tab для i3
https://github.com/acrisci/i3ipc-python/blob/master/examples/i3-cycle-focus.py || not packaged? search in AUR
  • i3-winmotion — Фокус и выбор видимых окон вi3
https://github.com/iiKoe/i3-winmotion || not packaged? search in AUR

Быстро перейти к необходимому окну

Добавьте в ~/.config/i3/config: [1]

bindsym $mod+x [urgent=latest] focus

Сохранить и восстановить расположение окон

Начиная с версии 4.8, i3 может сохранить и восстановить рабочее пространство слоёв (лэйаутов). Чтобы это сделать, необходимы пакеты perl-anyevent-i3 и perl-json-xs.

Примечание: В этом разделе предоставлен быстрый урок о том как сохранить текущую раскладку окон из одного рабочего пространства, и как восстановить его для дальнейшего использования. Обратитесь к официальной документации для подробностей.

Сохранить текущее расположение окон одного рабочего пространства

Чтобы сохранить текущее расположение окон, выполните следующие действия:

  1. Во-первых, выполните различные команды, чтобы открыть окна в предпочтительной рабочей области и измените их размер, если это необходимо. Совершите запись каждой выполненной команды для каждого окна.
  2. Теперь, в новой рабочей области откройте терминал и запустите следующее:
    $ i3-save-tree --workspace N > ~/.config/i3/workspace_N.json
    где N есть число предпочтительной рабочей области. Это позволит сохранить текущую структуру рабочей области N в файл ~/.config/i3/workspace_N.json.
  3. Вновь созданный файл должен быть отредактирован, однако это может быть сделано с помощью следующих команд:
    $ sed -i 's|^\(\s*\)// "|\1"|g; /^\s*\/\//d' ~/.config/i3/workspace_N.json

Восстановить расположение окон на рабочем пространстве

Есть два способа восстановить расположение окон на рабочем пространстве: написать скрипт или отредактировать ~/.config/i3/config для автоматической загрузки макета. В этом разделе будет рассмотрен только первый случай; обратитесь к официальной документации для второго случая.

Для восстановления сохраненного макета в предыдущем разделе, создайте файл с именемload_layout.sh со следующим содержанием:

  • Первые строки:
~/load_layout.sh
#!/bin/sh
i3-msg "workspace M; append_layout ~/.config/i3/workspace_N.json"

где М - номер рабочей области, в которую вы хотели бы загрузить ранее сохраненный макет, и N это номер рабочей области сохранённой в предыдущем разделе.

  • И команды исполльзуемые в предыдущей секции чтобы получить нужные окна, но заключённые в круглые скобки и амперсандом (&) перед последней скобкой.

Например, если сохранённый макет содержит три uxterm окна:

~/load_layout.sh
#!/bin/sh

# Во-первых, мы добавим сохраненный макет рабочей области N в рабочую область M
i3-msg "workspace M; append_layout ~/.config/i3/workspace_N.json"

# И, наконец, мы заполним контейнеры программами
(uxterm &)
(uxterm &)
(uxterm &)

Сделайте файл исполняемым. И, наконец, расположение рабочих областей N может быть загружено в рабочие области М, запустив:

$ ~/load_layout.sh
Совет: Добавьте bindsym $mod+g exec ~/load_layout.sh в ~/.config/i3/config и перезапустите i3, после чего сочетание клавиш Mod+g будет запускать этот скрипт.
Примечание: Если скрипт, описанный выше, не работает как следует, обратитесь к официальной документации. Секции swallows в ~/.config/i3/workspace_N.json нужно редактировать вручную.

Контейнер для электронного блокнота

По умолчанию, scratchpads (блокноты) содержат только одно окно. Однако контейнеры также могут быть сделаны блокнотом.

Создайте новый контейнер (например, Mod+Enter), разделите их (Mod+v) и создайте другой контейнер. Сфокусируйтесь на родительском (Mod+a), разделите в противоположном направлении (Mod+h), и создайте снова.

Фокус на первом контейнере (с акцентом родительского по мере необходимости), сделайте окно плавающим (floating) (Mod+Shift+Space), и переместите его в блокнот (Mod+Shift+-). Теперь вы можете разделить контейнеры по предпочтению.

Примечание: Контейнеры не могут быть изменены индивидуально в плавающих окнах. Измените размер контейнеров до создания плавающих окон.
Совет: При использовании только терминальных приложений подумайте об использовании мультиплексора вроде tmux.

Хранитель экрана и управление питанием

С Power management#xss-lock вы можете зарегистрировать экранный блокировщик для вашего сеанса i3. Кроме того, вы можете использовать xautolock для блокировки экрана после заданного периода времени:

xautolock -time 10 -locker "i3lock -i background_image.png" &

Можно использовать service-файл systemd для блокировки экрана перед уходом в ждущий или спящий режим; смотрите Power management#Suspend/resume service files. Обратите внимание, что i3lock требует, чтобы тип службы был forking.

Смотрите также DPMS.

Другой вариант — использовать xidlehookAUR с betterlockscreenAUR или любым другим хранителем экрана. xidlehook — это замена xautolock, написанная на Rust и имеющая дополнительные возможности. Сюда входит возможность отключения блокировки при воспроизведении звука или при полноэкранном режиме. Параметр --timer задаётся в секундах:

xidlehook --not-when-audio --not-when-fullscreen --timer 360 "betterlockscreen -l dim" "" &

Выключение, перезагрузка, блокировка экрана

Так как нет иконок на экране для Выключения, Перезагрузки и Блокировки Экрана, для удобства, мы можем задать комбинацию горячих клавиш. Ниже предпологается, что установлен polkit, чтобы позволять обычным (не привелигелированным) пользователям запускать команды управления питанием.

Добавьте следующие строки в ваш ~/.config/i3/config, по завершению вам будет предложен запрос, когда вы нажимаете $mod+pause.

set $Locker i3lock && sleep 1

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 $Locker, mode "default"
    bindsym e exec --no-startup-id i3-msg exit, mode "default"
    bindsym s exec --no-startup-id $Locker && systemctl suspend, mode "default"
    bindsym h exec --no-startup-id $Locker && systemctl hibernate, mode "default"
    bindsym r exec --no-startup-id systemctl reboot, mode "default"
    bindsym Shift+s exec --no-startup-id systemctl poweroff -i, mode "default"

    # выход: Enter или Escape
    bindsym Return mode "default"
    bindsym Escape mode "default"
}

bindsym $mod+Pause mode "$mode_system"

Теперь при каждом нажатии $mod+pause будет появляться запрос. Для более сложного поведения используйте отдельный скрипт и ссылайтесь на него в режиме. [2]

Примечание:
  • sleep 1 добавляет небольшую задержку, чтобы предотвратить возможное состояние гонки при уходе в ждущий режим [3]
  • Аргумент -i команды systemctl poweroff позволяет выключить систему, даже если в неё вошли другие пользователи (для этого нужен polkit) или когда logind (ошибочно) предполагает это. [4]

Список альтернативных блокировщиков экрана есть в статье Список приложений/Безопасность#Блокировка экрана.

Перекрытие окна терминала

Подобно dwm, в i3 можно «поглощать» (swallow) текущее окно терминала новым окном программы, запущенной через этот терминал. Это позволяет сделать пакет i3-swallow-gitAUR.

Например, чтобы mpv при запуске перекрыл собой окно терминала:

$ swallow mpv video.mp4

Также можно сымитировать подобное поведение, используя tabbed или stacked контейнер, чтобы скрыть неиспользуемое окно терминала. Недостаток этого способа в том, что в верхней части контейнера всегда будет список окон.

Ручное управление внешними дисплеями

Благодаря xrandr есть много способов лёгкого управления дисплеями. Приведённый ниже пример ведёт себя подобно показанному ранее примеру управления питанием.

Пример меню для включения/выключения выходов VGA и HDMI на ноутбуке:

## Ручное управление внешними дисплеями
# Сочетания клавиш и что они делают
set $mode_display Ext Screen (v) VGA ON, (h) HDMI ON, (x) VGA OFF, (y) HDMI OFF
mode "$mode_display" {
    bindsym v exec --no-startup-id xrandr --output VGA1 --auto --right-of LVDS1, mode "default"
    bindsym h exec --no-startup-id xrandr --output HDMI1 --auto --right-of LVDS1, mode "default"
    bindsym x exec --no-startup-id xrandr --output VGA1 --auto --off, mode "default"
    bindsym y exec --no-startup-id xrandr --output HDMI1 --auto --off, mode "default"

    # выход: Enter или Escape
    bindsym Return mode "default"
    bindsym Escape mode "default"
}
# Сочетание клавиш для вызова меню
bindsym $mod+x mode "$mode_display"

Любое окно, которое всё ещё открыто на выключенном дисплее, автоматически возвращается на оставшийся активным дисплей.

Самый простой способ определить имена ваших устройств — подключить устройство, которое вы хотите использовать, и выполнить команду:

$ xrandr --query

которая выведет доступные распознанные устройства и их внутренние имена, которые можно использовать для настройки.

Список доступных опций есть в статье xrandr (Русский). Смотрите также i3 userguide и/или i3 FAQ на reddit.

Вкладки или стековый просмотр веб-страниц

Некоторые веб-браузеры намеренно не внедряют вкладки, управление вкладками считается задачей менеджера окон, не задачей браузера.

Чтобы i3 управлял вкладками веб-браузера (в этом примере для uzbl), добавьте следующую строку в ваш ~/.config/i3/config

for_window [class="Uzbl-core"] focus child, layout stacking, focus

Это для стекового просмотра веб-страниц, это означает, что окна будут показаны вертикально. Преимущество над вкладками является то, что названия окон полностью видны, даже если открыто много окон браузера.

Если вы предпочитаете вкладки, с окнами в горизонтальном направлении ('tabs'), используйте:

for_window [class="Uzbl-core"] focus child, layout tabbed, focus

Переменные рабочих областей

Так как рабочих областей в i3 определено много, будет полезно присвоить переменные рабочим областям. Например:

set $WS1 term
set $WS2 web
set $WS3 misc
set $WS4 media
set $WS5 code

Затем замените имена рабочих области в соответствии с их переменной:

bindsym $mod+1          workspace $WS1
...
bindsym $mod+Shift+1    move container to workspace $WS1

Для болшей информации смотрите изменение названий рабочих областей.

Правильное обращение с плавающими диалогами

Хотя диалоги должны открываться по умолчанию в плавающем режиме (floating) [5], многие до сих пор открываются в тайловом режиме (tiling). Чтобы изменить это поведение, проверьте WM_WINDOW_ROLE с помощью xorg-xprop и добавьте правильные правила в ~/.config/i3/config (используя pcre синтаксис):

for_window [window_role="pop-up"] floating enable
for_window [window_role="task_dialog"] floating enable

Вы также можете использовать в качестве правила заголовок и регулярные выражения:

for_window [title="Preferences$"] floating enable

или WM_CLASS:

for_window [class="(?i)mplayer"] floating enable

Скорость Загрузки/Отдачи сети в statusbar

Можно адаптировать этот скрипт. Для этого:

  • переименуйте обе ваши сетевые карты в соответствии с вашей системой (используйте ip addr)
  • найдите их /sys/devices затем замените соответствующими:
$ find /sys/devices -name network_interface
Совет: Использование /sys/class/net/interface/statistics/ не зависит от расположения PCI.

Теперь просто сохраните скрипт в подходящем месте (например ~/.config/i3) и пропишите его в вашу программу статуса.

Автоматическое переключение горизонтальной / вертикальной ориентации

Пакет autotilingAUR позволяет автоматически переключаться между горизонтальной и вертикальной ориентациями окон, что приводит к поведению, похожему на спиральный тайлинг bspwm. После установки добавьте следующее в ~/.config/i3/config и перезагрузите i3.

exec_always --no-startup-id autotiling

Решение проблем

Общее

Часто ошибки уже исправлены в разрабатываемых версиях i3-gitAUR и i3status-gitAUR, и в апстриме попросят воспроизвести какие-либо ошибки в этих версиях. [6] Смотрите также Отладка/Трассировка#Параметры компиляции.

Искажённый текст

Установите какие-нибудь шрифты TrueType.

Кнопки в строке сообщений i3 не работают

Кнопки, такие как "Edit config" в i3-nagbar вызывают i3-sensible-terminal, поэтому убедитесь, что i3 распознаёт ваш #Эмулятор терминала.

Неисправная строка оболочки в тайловом терминале

i3 v4.3 и выше игнорирует размер инкремента подсказки для тайловых окон [7]. This may cause terminals to wrap lines prematurely, amongst other issues. As a workaround, make the offending window floating, before tiling it again.

Курсор мыши остается в режиме ожидания

При запуске приложения или скрипта, которое не поддерживает протокол startup notification, курсор мыши будет оставаться в режиме занят/часы/и т.п. в течение 60 секунд.

Чтобы решить эту проблему для конкретного приложения, используйте параметр --no-startup-id, например:

exec --no-startup-id ~/script
bindsym $mod+d exec --no-startup-id dmenu_run

Чтобы полностью отключить эту анимацию, смотрите Темы курсора#Создание ссылок на недостающие курсоры.

Не реагируют сочетания клавиш

Некоторые утилиты, такие как scrot могут не работать при использовании регулярных горячих клавиш (выполнятся после нажатия клавиш). В таких случаях, выполняйте команду после ключа "освобождения" с параметром --release [8]:

bindsym --release Print exec --no-startup-id scrot
bindsym --release Shift+Print exec --no-startup-id scrot -s

Тиринг (разрыв картинки по горизонтали)

i3 не осуществляет двойную буферизацию должным образом [9] следовательно, может появится тиринг или мерцание. Чтобы предотвратить это, установите и настройте picom.

Значки трея не видны

Директива tray_output primary может потребовать установки первичного вывода с помощью xrandr, явного указания вывода или просто удаления этой директивы. [10] Подробности в статье xrandr (Русский). Конфигурация по умолчанию, которую создаёт i3-config-wizard, больше не добавляет эту директиву в конфигурацию, начиная с i3 версии 4.12.

Рабочая область по умолчанию для Spotify

Чтобы назначить рабочую область по умолчанию для окон Spotify, нельзя использовать стандартный путь с командой assign, а лучше использовать команду for_window, например

~/.config/i3/config
...
for_window [class="Spotify"] move container to workspace $ws10

Чтобы for_window не перемещал окно, если оно уже находится в $ws10, можно вместо этого использовать move --no-auto-back-and-forth.

Смотрите также

Arch Linux Forums

Screencasts