summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLex Neva <github.com@lexneva.name>2019-04-02 23:39:54 -0400
committerLex Neva <github.com@lexneva.name>2019-04-02 23:39:54 -0400
commit6c5e57d39c9a72a9a56acc3b7ffe93e67f38ecb1 (patch)
tree07664d1240f5efd2c59a8534c77828da946acbad
parenta6a86973dd54d623394fdbfc61e6e4c0ca263cc0 (diff)
implement lettering presets
-rw-r--r--lib/extensions/lettering.py38
-rw-r--r--lib/gui/presets.py11
2 files changed, 30 insertions, 19 deletions
diff --git a/lib/extensions/lettering.py b/lib/extensions/lettering.py
index 74d036cf..9193a723 100644
--- a/lib/extensions/lettering.py
+++ b/lib/extensions/lettering.py
@@ -33,17 +33,13 @@ class LetteringFrame(wx.Frame):
self.preview = SimulatorPreview(self, target_duration=1)
self.presets_panel = PresetsPanel(self)
- self.load_settings()
-
# options
self.options_box = wx.StaticBox(self, wx.ID_ANY, label=_("Options"))
self.back_and_forth_checkbox = wx.CheckBox(self, label=_("Stitch lines of text back and forth"))
- self.back_and_forth_checkbox.SetValue(self.settings.back_and_forth)
self.back_and_forth_checkbox.Bind(wx.EVT_CHECKBOX, lambda event: self.on_change("back_and_forth", event))
self.trim_checkbox = wx.CheckBox(self, label=_("Add trims"))
- self.trim_checkbox.SetValue(bool(self.settings.trim))
self.trim_checkbox.Bind(wx.EVT_CHECKBOX, lambda event: self.on_change("trim", event))
# text editor
@@ -53,10 +49,9 @@ class LetteringFrame(wx.Frame):
self.font_chooser = SubtitleComboBox(self, wx.ID_ANY, choices=self.get_font_names(),
subtitles=self.get_font_descriptions(), style=wx.CB_READONLY)
self.font_chooser.Bind(wx.EVT_COMBOBOX, self.update_preview)
- self.set_initial_font(self.settings.font)
- self.text_editor = wx.TextCtrl(self, style=wx.TE_MULTILINE | wx.TE_DONTWRAP, value=self.settings.text)
- self.Bind(wx.EVT_TEXT, lambda event: self.on_change("text", event))
+ self.text_editor = wx.TextCtrl(self, style=wx.TE_MULTILINE | wx.TE_DONTWRAP)
+ self.text_editor.Bind(wx.EVT_TEXT, lambda event: self.on_change("text", event))
self.cancel_button = wx.Button(self, wx.ID_ANY, _("Cancel"))
self.cancel_button.Bind(wx.EVT_BUTTON, self.cancel)
@@ -66,9 +61,12 @@ class LetteringFrame(wx.Frame):
self.apply_button.Bind(wx.EVT_BUTTON, self.apply)
self.__do_layout()
- # end wxGlade
+
+ self.load_settings()
+ self.apply_settings()
def load_settings(self):
+ """Load the settings saved into the SVG group element"""
try:
if INKSTITCH_LETTERING in self.group.attrib:
self.settings = DotDict(json.loads(b64decode(self.group.get(INKSTITCH_LETTERING))))
@@ -82,7 +80,16 @@ class LetteringFrame(wx.Frame):
"font": None
})
+ def apply_settings(self):
+ """Make the settings in self.settings visible in the UI."""
+ self.back_and_forth_checkbox.SetValue(self.settings.back_and_forth)
+ self.trim_checkbox.SetValue(bool(self.settings.trim))
+ self.set_initial_font(self.settings.font)
+ self.text_editor.SetValue(self.settings.text)
+
def save_settings(self):
+ """Save the settings into the SVG group element."""
+
# We base64 encode the string before storing it in an XML attribute.
# In theory, lxml should properly html-encode the string, using HTML
# entities like &#10; as necessary. However, we've found that Inkscape
@@ -186,12 +193,15 @@ class LetteringFrame(wx.Frame):
def get_preset_data(self):
# called by self.presets_panel
- preset = {}
- return preset
-
- def apply_preset_data(self):
- # called by self.presets_panel
- return
+ settings = dict(self.settings)
+ del settings["text"]
+ return settings
+
+ def apply_preset_data(self, preset_data):
+ settings = DotDict(preset_data)
+ settings["text"] = self.settings.text
+ self.settings = settings
+ self.apply_settings()
def get_preset_suite_name(self):
# called by self.presets_panel
diff --git a/lib/gui/presets.py b/lib/gui/presets.py
index 5337d879..bd0b1787 100644
--- a/lib/gui/presets.py
+++ b/lib/gui/presets.py
@@ -63,11 +63,12 @@ class PresetsPanel(wx.Panel):
self.delete_preset_button.Bind(wx.EVT_BUTTON, self.delete_preset)
presets_sizer = wx.StaticBoxSizer(self.presets_box, wx.HORIZONTAL)
- presets_sizer.Add(self.preset_chooser, 1, wx.ALIGN_CENTER_VERTICAL | wx.ALL, 10)
- presets_sizer.Add(self.load_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.ALL, 10)
- presets_sizer.Add(self.add_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.ALL, 10)
- presets_sizer.Add(self.overwrite_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.ALL, 10)
- presets_sizer.Add(self.delete_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.ALL, 10)
+ self.preset_chooser.SetMinSize((200, -1))
+ presets_sizer.Add(self.preset_chooser, 1, wx.ALIGN_CENTER_VERTICAL | wx.LEFT | wx.BOTTOM | wx.EXPAND, 10)
+ presets_sizer.Add(self.load_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.BOTTOM | wx.LEFT, 10)
+ presets_sizer.Add(self.add_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.BOTTOM | wx.LEFT, 10)
+ presets_sizer.Add(self.overwrite_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.BOTTOM | wx.LEFT, 10)
+ presets_sizer.Add(self.delete_preset_button, 0, wx.ALIGN_CENTER_VERTICAL | wx.BOTTOM | wx.LEFT | wx.RIGHT, 10)
self.SetSizerAndFit(presets_sizer)
self.Layout()