1
0
Fork 0
mirror of https://github.com/deepfakes/faceswap synced 2025-06-09 04:36:50 -04:00
faceswap/lib/gui/popup_configure.py

178 lines
7.4 KiB
Python

#!/usr/bin python3
""" Configure Plugins popup of the Faceswap GUI """
from configparser import ConfigParser
import logging
import tkinter as tk
from tkinter import ttk
from .control_helper import ControlPanel
from .tooltip import Tooltip
from .utils import get_config, get_images
logger = logging.getLogger(__name__) # pylint: disable=invalid-name
POPUP = dict()
def popup_config(config, root):
""" Close any open popup and open requested popup """
if POPUP:
p_key = list(POPUP.keys())[0]
logger.debug("Closing open popup: '%s'", p_key)
POPUP[p_key].destroy()
del POPUP[p_key]
window = ConfigurePlugins(config, root)
POPUP[config[0]] = window
class ConfigurePlugins(tk.Toplevel):
""" Pop up for detailed graph/stats for selected session """
def __init__(self, config, root):
logger.debug("Initializing %s", self.__class__.__name__)
super().__init__()
name, self.config = config
self.title("{} Plugins".format(name.title()))
self.tk.call('wm', 'iconphoto', self._w, get_images().icons["favicon"])
self.set_geometry(root)
self.page_frame = ttk.Frame(self)
self.page_frame.pack(fill=tk.BOTH, expand=True)
self.plugin_info = dict()
self.config_dict_gui = self.get_config()
self.build()
self.update()
logger.debug("Initialized %s", self.__class__.__name__)
def set_geometry(self, root):
""" Set pop-up geometry """
scaling_factor = get_config().scaling_factor
pos_x = root.winfo_x() + 80
pos_y = root.winfo_y() + 80
width = int(720 * scaling_factor)
height = int(400 * scaling_factor)
logger.debug("Pop up Geometry: %sx%s, %s+%s", width, height, pos_x, pos_y)
self.geometry("{}x{}+{}+{}".format(width, height, pos_x, pos_y))
def get_config(self):
""" Format config into useful format for GUI and pull default value if a value has not
been supplied """
logger.debug("Formatting Config for GUI")
conf = dict()
for section in self.config.config.sections():
self.config.section = section
category = section.split(".")[0]
options = self.config.defaults[section]
conf.setdefault(category, dict())[section] = options
for key in options.keys():
if key == "helptext":
self.plugin_info[section] = options[key]
continue
options[key]["value"] = self.config.config_dict.get(key, options[key]["default"])
logger.debug("Formatted Config for GUI: %s", conf)
return conf
def build(self):
""" Build the config popup """
logger.debug("Building plugin config popup")
container = ttk.Notebook(self.page_frame)
container.pack(fill=tk.BOTH, expand=True)
categories = sorted(list(self.config_dict_gui.keys()))
if "global" in categories: # Move global to first item
categories.insert(0, categories.pop(categories.index("global")))
for category in categories:
page = self.build_page(container, category)
container.add(page, text=category.title())
self.add_frame_separator()
self.add_actions()
logger.debug("Built plugin config popup")
def build_page(self, container, category):
""" Build a plugin config page """
logger.debug("Building plugin config page: '%s'", category)
plugins = sorted(list(key for key in self.config_dict_gui[category].keys()))
if any(plugin != category for plugin in plugins):
page = ttk.Notebook(container)
page.pack(side=tk.TOP, fill=tk.BOTH, expand=True)
for plugin in plugins:
frame = ControlPanel(page,
self.config_dict_gui[category][plugin],
self.plugin_info[plugin])
title = plugin[plugin.rfind(".") + 1:]
title = title.replace("_", " ").title()
page.add(frame, text=title)
else:
page = ControlPanel(container,
self.config_dict_gui[category][plugins[0]],
self.plugin_info[plugins[0]])
logger.debug("Built plugin config page: '%s'", category)
return page
def add_frame_separator(self):
""" Add a separator between top and bottom frames """
logger.debug("Add frame seperator")
sep = ttk.Frame(self.page_frame, height=2, relief=tk.RIDGE)
sep.pack(fill=tk.X, pady=(5, 0), side=tk.BOTTOM)
logger.debug("Added frame seperator")
def add_actions(self):
""" Add Action buttons """
logger.debug("Add action buttons")
frame = ttk.Frame(self.page_frame)
frame.pack(fill=tk.BOTH, padx=5, pady=5, side=tk.BOTTOM)
btn_cls = ttk.Button(frame, text="Cancel", width=10, command=self.destroy)
btn_cls.pack(padx=2, side=tk.RIGHT)
Tooltip(btn_cls, text="Close without saving", wraplength=720)
btn_ok = ttk.Button(frame, text="OK", width=10, command=self.save_config)
btn_ok.pack(padx=2, side=tk.RIGHT)
Tooltip(btn_ok, text="Close and save config", wraplength=720)
btn_rst = ttk.Button(frame, text="Reset", width=10, command=self.reset)
btn_rst.pack(padx=2, side=tk.RIGHT)
Tooltip(btn_rst, text="Reset all plugins to default values", wraplength=720)
logger.debug("Added action buttons")
def reset(self):
""" Reset all config options to default """
logger.debug("Resetting config")
for section, items in self.config.defaults.items():
logger.debug("Resetting section: '%s'", section)
lookup = [section.split(".")[0], section] if "." in section else [section, section]
for item, def_opt in items.items():
if item == "helptext":
continue
default = def_opt["default"]
tk_var = self.config_dict_gui[lookup[0]][lookup[1]][item]["selected"]
logger.debug("Resetting: '%s' to '%s'", item, default)
tk_var.set(default)
def save_config(self):
""" Save the config file """
logger.debug("Saving config")
options = {sect: opts
for value in self.config_dict_gui.values()
for sect, opts in value.items()}
new_config = ConfigParser(allow_no_value=True)
for section, items in self.config.defaults.items():
logger.debug("Adding section: '%s')", section)
self.config.insert_config_section(section, items["helptext"], config=new_config)
for item, def_opt in items.items():
if item == "helptext":
continue
new_opt = options[section][item]
logger.debug("Adding option: (item: '%s', default: '%s' new: '%s'",
item, def_opt, new_opt)
helptext = def_opt["helptext"]
helptext = self.config.format_help(helptext, is_section=False)
new_config.set(section, helptext)
new_config.set(section, item, str(new_opt["selected"].get()))
self.config.config = new_config
self.config.save_config()
print("Saved config: '{}'".format(self.config.configfile))
self.destroy()
logger.debug("Saved config")