summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLex Neva <github.com@lexneva.name>2019-03-25 19:40:37 -0400
committerLex Neva <github.com@lexneva.name>2019-04-02 20:15:06 -0400
commit55505369496c0986e54fe5722e7e8ddce0a9294e (patch)
tree770ec9150d5f5aef7eefc952ff3bb24e23b63e1d
parent13b6c67644acaeff04918e8489e943b4a8795863 (diff)
implement font chooser
-rw-r--r--lib/extensions/lettering.py69
-rw-r--r--lib/lettering/__init__.py2
-rw-r--r--lib/lettering/font.py12
3 files changed, 72 insertions, 11 deletions
diff --git a/lib/extensions/lettering.py b/lib/extensions/lettering.py
index 3718b5ab..a33277df 100644
--- a/lib/extensions/lettering.py
+++ b/lib/extensions/lettering.py
@@ -5,20 +5,23 @@ import json
import os
import sys
+import appdirs
import inkex
import wx
from ..elements import nodes_to_elements
-from ..gui import PresetsPanel, SimulatorPreview
+from ..gui import PresetsPanel, SimulatorPreview, info_dialog
from ..i18n import _
-from ..lettering import Font
+from ..lettering import Font, FontError
from ..svg import get_correction_transform
from ..svg.tags import SVG_PATH_TAG, SVG_GROUP_TAG, INKSCAPE_LABEL, INKSTITCH_LETTERING
-from ..utils import get_bundled_dir, DotDict
+from ..utils import get_bundled_dir, DotDict, cache
from .commands import CommandsExtension
class LetteringFrame(wx.Frame):
+ DEFAULT_FONT = "small_font"
+
def __init__(self, *args, **kwargs):
# begin wxGlade: MyFrame.__init__
self.group = kwargs.pop('group')
@@ -46,8 +49,9 @@ class LetteringFrame(wx.Frame):
# text editor
self.text_editor_box = wx.StaticBox(self, wx.ID_ANY, label=_("Text"))
- self.font_chooser = wx.ComboBox(self, wx.ID_ANY)
+ self.font_chooser = wx.ComboBox(self, wx.ID_ANY, style=wx.CB_READONLY)
self.update_font_list()
+ 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))
@@ -73,7 +77,7 @@ class LetteringFrame(wx.Frame):
self.settings = DotDict({
"text": u"",
"back_and_forth": True,
- "font": "small_font"
+ "font": None
})
def save_settings(self):
@@ -87,13 +91,61 @@ class LetteringFrame(wx.Frame):
# https://bugs.launchpad.net/inkscape/+bug/1804346
self.group.set(INKSTITCH_LETTERING, b64encode(json.dumps(self.settings)))
+ def update_font_list(self):
+ font_paths = {
+ get_bundled_dir("fonts"),
+ os.path.expanduser("~/.inkstitch/fonts"),
+ os.path.join(appdirs.user_config_dir('inkstitch'), 'fonts'),
+ }
+
+ self.fonts = {}
+ self.fonts_by_id = {}
+
+ for font_path in font_paths:
+ try:
+ font_dirs = os.listdir(font_path)
+ except OSError:
+ continue
+
+ try:
+ for font_dir in font_dirs:
+ font = Font(os.path.join(font_path, font_dir))
+ self.fonts[font.name] = font
+ self.fonts_by_id[font.id] = font
+ except FontError:
+ pass
+
+ self.font_chooser.SetItems(sorted(self.fonts))
+
+ if len(self.fonts) == 0:
+ info_dialog(self, _("Unable to find any fonts! Please try reinstalling Ink/Stitch."))
+ self.cancel()
+
+ def set_initial_font(self, font_id):
+ if font_id is not None:
+ if font_id not in self.fonts_by_id:
+ info_dialog(self, _(
+ '''This text was created using the font "%s", but Ink/Stitch can't find that font. A default font will be substituted.''') % font_id)
+
+ try:
+ self.font_chooser.SetValue(self.fonts_by_id[font_id].name)
+ except KeyError:
+ self.font_chooser.SetValue(self.default_font.name)
+
+ @property
+ @cache
+ def default_font(self):
+ try:
+ return self.fonts[self.DEFAULT_FONT]
+ except KeyError:
+ return self.fonts.values()[0]
+
def on_change(self, attribute, event):
self.settings[attribute] = event.GetEventObject().GetValue()
self.preview.update()
def update_lettering(self):
- font_path = os.path.join(get_bundled_dir("fonts"), self.settings.font)
- font = Font(font_path)
+ font = self.fonts_by_id.get(self.settings.font, self.default_font)
del self.group[:]
font.render_text(self.settings.text, self.group, back_and_forth=self.settings.back_and_forth, trim=self.settings.trim)
@@ -120,9 +172,6 @@ class LetteringFrame(wx.Frame):
return patches
- def update_font_list(self):
- pass
-
def get_preset_data(self):
# called by self.presets_panel
preset = {}
diff --git a/lib/lettering/__init__.py b/lib/lettering/__init__.py
index c6201223..5d20d683 100644
--- a/lib/lettering/__init__.py
+++ b/lib/lettering/__init__.py
@@ -1 +1 @@
-from font import Font \ No newline at end of file
+from font import Font, FontError \ No newline at end of file
diff --git a/lib/lettering/font.py b/lib/lettering/font.py
index 28807cd6..6f749d28 100644
--- a/lib/lettering/font.py
+++ b/lib/lettering/font.py
@@ -7,6 +7,7 @@ import os
import inkex
from ..elements import nodes_to_elements
+from ..exceptions import InkstitchException
from ..i18n import _
from ..stitches.auto_satin import auto_satin
from ..svg import PIXELS_PER_MM
@@ -15,6 +16,10 @@ from ..utils import Point
from .font_variant import FontVariant
+class FontError(InkstitchException):
+ pass
+
+
def font_metadata(name, default=None, multiplier=None):
def getter(self):
value = self.metadata.get(name, default)
@@ -47,6 +52,9 @@ class Font(object):
self._load_license()
self._load_variants()
+ if self.variants.get(self.default_variant) is None:
+ raise FontError("font not found or has no default variant")
+
def _load_metadata(self):
try:
with open(os.path.join(self.path, "font.json")) as metadata_file:
@@ -81,6 +89,10 @@ class Font(object):
kerning_pairs = font_metadata('kerning_pairs', {})
auto_satin = font_metadata('auto_satin', True)
+ @property
+ def id(self):
+ return os.path.basename(self.path)
+
def render_text(self, text, destination_group, variant=None, back_and_forth=True, trim=False):
"""Render text into an SVG group element."""