Несколько обоев рабочего пространства без использования ccsm

Есть ли способ получить различный фон для каждого рабочего пространства без использования CCSM? Я прочитал несколько страшных историй и предпочел бы избежать этого, если это возможно. Я использую Raring Ringtail (13.04)

4
задан 21 July 2017 в 23:53

1 ответ

Наличие различных обоев на различных рабочих областях, не используя ccsm

Сценарий ниже не использует compiz менеджера по настройкам, но он принимает:

  • python3 установлен (если не сообщенный мне)
  • wmctrl установлен (для выборки данных по рабочим областям). Вы, возможно, должны были бы установить его: склонные sudo - получают установку wmctrl

Это работает, неважно, количество рабочих областей; это вычисляет число столбцов рабочих областей и строки текущей рабочей области, и устанавливает определяемые пользователем обои для той (текущей) рабочей области.
После того, как сценарий запускается, просто переключитесь на различные рабочие области и установите обои в "нормальном" (GUI) путь. Сценарий отслеживает обои (обои) на рабочую область в маленьком файле, который это создает. Это не должно вызывать задержку в производительности, так как файл только читается, когда сценарий инициирует, или когда обои на рабочую область изменяются пользователем.

enter image description here

Сценарий

#!/usr/bin/env python3

import subprocess
import time
import os

key1 = "gsettings set org.gnome.desktop.background picture-uri "
key2 = "gsettings get org.gnome.desktop.background picture-uri"

def write_wspaces(file, current):
    with open(file, "wt") as wt:
        wt.write(current)

def read_wspaces(file):
    with open(file) as src:
        return src.read().strip()

def get_info(command):
    return subprocess.check_output(["/bin/bash", "-c", command]).decode("utf-8")

def get_currwallpaper():
    return get_info(key2).replace("file://", "").strip()

# get resolution
output = get_info("xrandr").split(); idf = output.index("current")
res = (int(output[idf+1]), int(output[idf+3].replace(",", "")))

def calculate_geometry():
    # get viewport data
    vp = get_info("wmctrl -d").split(" ")
    span = vp[4].split("x"), vp[7].split(",")
    # calculate number of (horizontal) viewports
    n_vps_hor = int(int(span[0][0])/int(res[0]))
    n_vps_vert = int(int(span[0][2])/int(res[1]))
    n_wspaces = int(n_vps_hor)*int(n_vps_vert)
    # calculate current viewport
    curr_vp_hor = int((int(span[1][0])/int(res[0]))+1)
    curr_vp_vert = int((int(span[1][3])/int(res[1]))+1)
    return ((curr_vp_vert-1)*n_vps_hor)+curr_vp_hor, n_wspaces

home = os.environ["HOME"]
wspaces = home+"/"+".config/wall_wspaces"
if not os.path.exists(wspaces):
    os.makedirs(wspaces)
if not os.path.exists(wspaces+"/wspaces.txt"):
    current = get_currwallpaper().replace("'", "")
    writelist = []; [writelist.append(current) for i in range(calculate_geometry()[1])]
    write_wspaces(wspaces+"/wspaces.txt", str(writelist))
wall_list = eval(read_wspaces(wspaces+"/wspaces.txt"))

while True:
    curr_vp1 = calculate_geometry()[0]; currwallpaper1 = get_currwallpaper()
    time.sleep(2)
    curr_vp2 = calculate_geometry()[0]; currwallpaper2 = get_currwallpaper()
    if curr_vp1 != curr_vp2:
        command = key1+"file://"+str(wall_list[curr_vp2-1])
        subprocess.Popen(["/bin/bash", "-c", command])
    elif currwallpaper1 != currwallpaper2:
        wall_list = eval(read_wspaces(wspaces+"/wspaces.txt"))
        wall_list[int(curr_vp2)-1] = currwallpaper2
        write_wspaces(wspaces+"/wspaces.txt", str(wall_list))
    else:
        pass

Как использовать

Просто скопируйте сценарий в пустой файл, сохраните его как workspace_walls.py и выполненный это командой:

python3 /path/to/workspace_walls.py

Если это работает, поскольку Вам нравится он к, добавьте его к своим приложениям запуска: Тире> Приложения Запуска> Добавляет


Править:

Ниже полностью переписанной версии сценария, к модели этого.

Сценарий (с несколькими незначительными различиями) + GUI также доступен как ppa:

enter image description here

sudo add-apt-repository ppa:vlijm/wswitcher
sudo apt-get update
sudo apt-get install wswitcher
#!/usr/bin/env python3
import subprocess    
import os
import time

workspace_data = os.environ["HOME"]+"/.wallpaper_data_"
key = [
    "gsettings get ",
    "gsettings set ",
    "org.gnome.desktop.background picture-uri",
    ]

def getwall():
    return subprocess.check_output(
        ["/bin/bash", "-c", key[0]+key[2]]
        ).decode("utf-8").strip()

def get_res():
    # get resolution
    xr = subprocess.check_output(["xrandr"]).decode("utf-8").split()
    pos = xr.index("current")
    return [int(xr[pos+1]), int(xr[pos+3].replace(",", "") )]

def current():
    # get the current viewport
    res = get_res()
    vp_data = subprocess.check_output(
        ["wmctrl", "-d"]
        ).decode("utf-8").split()
    dt = [int(n) for n in vp_data[3].split("x")]
    cols = int(dt[0]/res[0])
    curr_vpdata = [int(n) for n in vp_data[5].split(",")]
    curr_col = int(curr_vpdata[0]/res[0])+1
    curr_row = int(curr_vpdata[1]/res[1])
    return str(curr_col+curr_row*cols)

curr_ws1 = current()
currwall1 = getwall()

while True:
    time.sleep(1)
    currwall2 = getwall()
    # print(currwall2)
    curr_ws2 = current()
    datafile = workspace_data+curr_ws2
    if curr_ws2 == curr_ws1:
        if currwall2 != currwall1:
            open(datafile, "wt").write(currwall2)
    else:
        if not os.path.exists(datafile):
            open(datafile, "wt").write(currwall2)
        else:
            curr_set = open(datafile).read()
            command = key[1]+key[2]+' "'+str(curr_set)+'"'
            subprocess.Popen(["/bin/bash", "-c", command])
    curr_ws1 = curr_ws2
    currwall1 = getwall()

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

Добавленная поддержка Волнистого попугайчика 21 июля 2017 для Пикантного при установке от ppa (см. выше),

enter image description here

5
ответ дан 21 July 2017 в 23:53

Другие вопросы по тегам:

Похожие вопросы: