Qtile (简体中文)

From ArchWiki
Jump to: navigation, search

From Qtile web site:

Qtile 是一个全功能、可轻易修改(骇)的平铺式窗口管理程序。 Qtile 简单、轻巧、扩展性高。 撰写自订的窗口堆叠模式、插件以及指令是轻而易举的事情。程序以及设定均是以 python 写成,意味着:您可以使用语言所提供的所有能力及弹性来满足您对窗口管理的需求。

安装

Arch User Repository 安装 qtile-gitAUR

缺省配置可以参考Github源或从该源复制一份,存放于 ~/.config/qtile/config.py

$ mkdir -p ~/.config/qtile/
$ wget https://raw.github.com/qtile/qtile/develop/libqtile/resources/default_config.py -O - > ~/.config/qtile/config.py

若无法从Github获得缺省配置,也可以以下列方式获得一份复制:

$ rm ~/.config/qtile/config.py
$ cp  /usr/lib/python2.7/site-packages/libqtile/resources/default_config.py ~/.config/qtile/config.py

启动Qtile

将 Qtile 指令 exec qtile 加入 ~/.xinitrc 并启动 Xorg。 缺省启动一个新的 xterm 终端的按键组合是:Alt+Enter

配置

注意: 这个章节只会介绍基本的配置模式,若需更详尽的配置讯息请参见 官方文档

整个 Qtile 的配置均是以python写成,存放于 ~/.config/qtile/config.py。 若需对 python快速概览的需求,可以阅读 这份教程。 此教程将讲解关于 python 变数、函数、模组以及其他配置 qtile 所需要的预备知识。

透过以下指令测试你所编写的 config.py 文件是否有语法上的错误。

$ python2 -m py_compile ~/.config/qtile/config.py

若编译通过,此设定文件应该便无重大问题。

群(Groups)

在 Qtile, 称 工作区(workspaces or views) 为 群(Groups)。他们可透过下列方式定义:

from libqtile.config import Group, Match
...
groups = [
    Group("term"),
    Group("irc"),
    Group("web", match=Match(title=["Firefox"])),    #表示标题含此关键字的程序均放置于此群中
   ]
...

按键组合(Keys)

按键组合均放置于 key 这个类中。 底下是一个按键范例,按下 Alt+Shift+q 则离开 Qtile 回到console>

from libqtile.config import Key
from libqtile.command import lazy
...
keys = [
    Key(
        ["mod1", "shift"], "q",
        lazy.shutdown())
   ]
...

透过执行 Xmodmap 来得知系统按键与 modX 之间的对应关系。

显示器与资讯列(Screens and Bars)

为你的每一部显示器配置 Screen 类。而 资讯列(bar) 则配置于 Screen 类中。

from libqtile.config import Screen
from libqtile import bar, widget
...
screens = [
    Screen(                       # 一部显示器
        bottom=bar.Bar([          # 将资讯列(bar)放置于萤幕底部
            widget.GroupBox(),    # 插件,用于显示群的状态
            widget.WindowName()   # 插件,用于显示当前应用程序名称
            ], 30))
   ]
...

插件(Widgets)

可以从 官方文档 获得关于插件更进一步详细的说明。

若想新增插件,只需要像上面资讯列设定那样调用即可 (如 WindowName 插件)。 例如,要新增一个电源资讯显示的插件,我们使用 Battery

from libqtile.config import Screen
from libqtile import bar, widget
...
screens = [
    Screen(top=bar.Bar([
        widget.GroupBox(),    # 插件,用于显示群的状态
        widget.Battery()      # 插件,用于显示电池状态
       ], 30))
   ]
...

啟動(Startup)

透过捆绑 钩(hooks) 我们可以设定许多需要 Qtile 监视的事件。其中一个 startup 钩是关注 Qtile 初始化事件的钩,能够在 Qtile 初始化的时连带启动其他的应用程序(一次性指令或应用程序)。其他的 钩(hook) 请参件 官方文档.

底下是一个关于钩的例子:

import subprocess, re

def is_running(process):
    s = subprocess.Popen(["ps", "axw"], stdout=subprocess.PIPE)
    for x in s.stdout:
        if re.search(process, x):
            return True
    return False

def execute_once(process):
    if not is_running(process):
        return subprocess.Popen(process.split())

# 在 Qtile 初始化的时启动应用程式
@hook.subscribe.startup
def startup():
    execute_once("parcellite")
    execute_once("nm-applet")
    execute_once("dropboxd")
    execute_once("feh --bg-scale ~/Pictures/wallpapers.jpg")

音效(Sound)

能透过键组合来操控 alsamixer 来快速调整音量以及静音与否。使用者必须是 audio gropu 的成员。

keys= [
    ...
    # 音效设置,未绑定键配置!
    Key([], "XF86AudioMute", lazy.spawn("amixer -q set Master toggle")),
    Key([], "XF86AudioLowerVolume", lazy.spawn("amixer -c 0 sset Master 1- unmute")),
    Key([], "XF86AudioRaiseVolume", lazy.spawn("amixer -c 0 sset Master 1+ unmute"))
   ]

除错(Debugging)

有时候会因为插件的参数没有完整,或者设定之间有冲突情形发生、模组未 import 等,需要检查出错位置,可以以如下方式启动一个虚拟的 Xorg 并进行测试:

echo "exec qtile" > /tmp/.start_qtile ; xinit /tmp/.start_qtile -- :2

Hacking Qtile

注意: 本说明为非官方文件翻译而来,请勿将用于生产的桌面环境进行不保证稳定的修改行为。

目前官方的开发状况:

  • Qtile 官方文档 是 Qtile 0.5 的说明文件,而在函式库的呼叫上, 0.5 版与 0.6 版有不相容的差异;这些差异将会使 缺省配置 无法于 Qtile 0.5 上运行。
    • Ubuntu PPA 包含的是 Qtile 0.5
    • ArchLinux 的 qtile-gitAUR 则是最新的 Qtile 0.6
  • 依照邮件列表内开发者的意思, Qtile 并不打算撰写完整的说明文件,而是优先扩充 问与答 (FAQ) ,而若有细节需求,会请求直接阅读源码。
  • Qtile 可以很好的与其他桌面环境组件协调运作。

预备

  • 关于 Xephyr 使用方式的基本知识,请避免在实验期间重启 Qtile。
  • 关于 python 的操作能力。

关于钩(hook)

关于插件(widget)

相关文件