Как я могу заставить Firefox работать в фоновом режиме, как хром?

Известной особенностью Chromium является возможность запуска его в фоновом режиме, что облегчает его открытие.

Можно ли сделать то же самое с Firefox (и другими приложениями)?

5
задан 28 November 2016 в 04:12

2 ответа

Запуск приложения в фоновом режиме

Решение ниже позволит Вам запускать Firefox (или любое другое приложение) в фоновом режиме, означая: без видимого окна. И при этом приложение не покажет в Тире как запущенное приложение:

enter image description here

enter image description here

При выборе Firefox Переключателя однако приложение сразу откроется:

enter image description here

Как это работает

  1. Если значок панелей (индикатор) запускает, он запускает новое firefox окно, но сразу скрывает его (включая существующий возможный firefox окна) от поверхности земли, с помощью xdotool:

    xdotool windowunmap <window_id>
    

    Это не только скроет окно, но также и скроет факт это firefox работает вообще, начиная с действий средства запуска единицы на явно существующих окнах.

  2. Индикатор хранит идентификатор всех неотображенных окон в ~/.config/hidden_windows, чтобы быть отображенными на следующем разе, Вы выбираете Toggle Firefox из меню.

Сценарий

#!/usr/bin/env python3
import subprocess
import os
import signal
import gi
gi.require_version('Gtk', '3.0')
gi.require_version('AppIndicator3', '0.1')
from gi.repository import Gtk, AppIndicator3
import time

app = "firefox"
winsdir = os.path.join(os.environ["HOME"], ".config/hidden_windows")

try:
    os.mkdir(winsdir)
except FileExistsError:
    pass

def checkruns(app):
    try:
        return subprocess.check_output(["pgrep", app]).decode("utf-8").strip()
    except subprocess.CalledProcessError:
        for w in os.listdir(winsdir):
            if w.startswith(app):
                os.remove(os.path.join(winsdir, w))

def get_currentwins(pid):
    wins = subprocess.check_output(["wmctrl", "-lp"]).decode("utf-8").splitlines()
    return [l.split()[0] for l in wins if pid in l]

def hide_currentwins(matches):
    # open(os.path.join(winsdir, "windowlist"), "wt").write("\n".join(matches))
    for w in matches:
        open(os.path.join(winsdir, app+"_"+w), "wt")
        subprocess.Popen(["xdotool", "windowunmap", w])

def run_app(app):
    subprocess.Popen(app)
    while True:
        time.sleep(1)
        pid = checkruns(app)
        matches = get_currentwins(pid) if pid else None
        if matches:
            hide_currentwins(matches)
            break

def restore_wins():
    for w in [w for w in os.listdir(winsdir) if w.startswith(app)]:
        wid = w.split("_")[-1]
        subprocess.Popen(["xdotool", "windowmap", wid])
        os.remove(os.path.join(winsdir, w))

def toggle_app(*args):
    pid = checkruns(app)
    if pid:
        matches = get_currentwins(pid)
        if matches:
            hide_currentwins(matches)
        else:
            restore_wins()
    else:
        subprocess.Popen(app)

run_app(app)

class Indicator():
    def __init__(self):
        self.app = 'toggle_app'
        self.indicator = AppIndicator3.Indicator.new(
            self.app, app,
            AppIndicator3.IndicatorCategory.OTHER)
        self.indicator.set_status(AppIndicator3.IndicatorStatus.ACTIVE)       
        self.indicator.set_menu(self.create_menu())

    def create_menu(self):
        self.menu = Gtk.Menu()
        item_toggle = Gtk.MenuItem('Toggle '+app)
        item_toggle.connect("activate", toggle_app)
        self.menu.append(item_toggle)
        sep1 = Gtk.SeparatorMenuItem()
        self.menu.append(sep1)
        item_quit = Gtk.MenuItem('Quit')
        item_quit.connect('activate', self.stop)
        self.menu.append(item_quit)
        self.menu.show_all()
        return self.menu

    def stop(self, source):
        Gtk.main_quit()

Indicator()
signal.signal(signal.SIGINT, signal.SIG_DFL)
Gtk.main()

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

  1. Для сценария нужны оба wmctrl и xdotool

    sudo apt-get install wmctrl xdotool
    
  2. Скопируйте сценарий в пустой файл, сохраните его как firefox_bg.py

  3. Test_run сценарий командой:

    python3 /path/to/firefox_bg.py
    
  4. Если все хорошо работает, добавьте его для Запущения Приложений: Тире> Приложения Запуска> Добавляет. Добавьте команду:

    /bin/bash -c "sleep 10 && python3 /path/to/firefox_bg.py"
    

    С другой стороны, скопируйте код ниже в пустой файл, сохраните его как firefox_bgrunner.desktop в ~/usr/share/applications, выйдите из системы и въезжайте задним ходом.

    [Desktop Entry]
    Type=Application
    Exec=python3 /path/to/firefox_bg.py
    Name=Firefox Webbrowser Background Runner
    Icon=firefox
    StartupWMClasss=nonsense
    

    *Последняя строка, StartupWMClasss=nonsense должен удостовериться Firefox windows will appear under their own icon, not the one of the indicator.

    Никакая потребность упомянуть, что необходимо отредактировать Exec= строка для отражения реального (абсолютного) пути туда, где Вы сохранили firefox_bg.py

    Затем Вы будете иметь бегуна панели в наличии от Тире:

    enter image description here

Другие приложения?

Я протестировал ту же процедуру с gnome-terminal иThunderbird (последний обычно не самое быстрое для запущений), и это работает отлично:

enter image description here

Для использования с другими приложениями просто отредактируйте строку:

app = "firefox"

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

Сценарий может даже затем отлично использоваться, хотя, но нуждался бы в маленьком редактировании. Если кто-либо когда-нибудь, возможно, должен был бы использовать его с Inkscape, оставьте комментарий.

5
ответ дан 28 November 2016 в 04:12
  • 1
    I' m на самом деле работающий 3.30 на 18,04. Я поднял учебное руководство о том, как сделать это на этом потоке. – thebunnyrules 19 January 2019 в 10:48

Я хотел бы предложить решение 2019 года этого для Ubuntu 18-19 + с GNOME, который немного более прост (IMO) и использует удар вместо Python для простоты. Я сделал это так, чтобы Firefox попросил мой Основной пароль, когда я регистрировался, но затем не спрашивают снова, если я не пошел для просмотра паролей. Я устал от него открывающийся каждый раз, когда я запустил Firefox.

Сначала установите зависимости:

sudo apt-get update && apt-get install -y wmctrl xdotool

Затем поместите этот сценарий где-нибудь, скажите /data/system/bin/firefox-background:

firefox "about:blank" &
WAITFOR="Mozilla Firefox"

APP=$(wmctrl -lp |grep "${WAITFOR}" |awk '{print $1}')
while [ -z "${APP}" ]; do
    sleep 1
    APP=$(wmctrl -lp |grep "${WAITFOR}" |awk '{print $1}')
done
xdotool windowunmap ${APP}

И:

chmod +x /data/system/bin/firefox-background

Теперь можно запустить этот скрипт однако, Вы хотели бы такой как из окна терминала или из запуска GNOME с файлом в .config/autostart/FirefoxBackground.desktop:

[Desktop Entry]
Name=Firefox Background
Exec=/data/system/bin/firefox-background
Terminal=false
Icon=firefox
Type=Application
StartupNotify=false
X-GNOME-Autostart-enabled=true
StartupWMClasss=nonsense

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

0
ответ дан 23 November 2019 в 09:21

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

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