From 1bd2dddab8c9e9b0188f11f2e36682ebc38d1629 Mon Sep 17 00:00:00 2001
From: Kaalleen <36401965+kaalleen@users.noreply.github.com>
Date: Tue, 20 May 2025 15:57:59 +0200
Subject: add force horiz_adv_x_default to generate json and fix edit-json
(#3735)
---
lib/extensions/lettering_generate_json.py | 15 +++++++++++----
lib/gui/edit_json/main_panel.py | 5 ++++-
templates/lettering_generate_json.xml | 10 +++++++++-
3 files changed, 24 insertions(+), 6 deletions(-)
diff --git a/lib/extensions/lettering_generate_json.py b/lib/extensions/lettering_generate_json.py
index 3d656625..f4a01ddb 100644
--- a/lib/extensions/lettering_generate_json.py
+++ b/lib/extensions/lettering_generate_json.py
@@ -35,10 +35,12 @@ class LetteringGenerateJson(InkstitchExtension):
self.arg_parser.add_argument("-z", "--size", type=float, default=15, dest="size")
self.arg_parser.add_argument("-i", "--min-scale", type=float, default=1.0, dest="min_scale")
self.arg_parser.add_argument("-a", "--max-scale", type=float, default=1.0, dest="max_scale")
- self.arg_parser.add_argument("-c", "--use-custom-leading", type=Boolean, default="false", dest="use_custom_leading")
- self.arg_parser.add_argument("-b", "--use-custom-spacing", type=Boolean, default="false", dest="use_custom_spacing")
- self.arg_parser.add_argument("-l", "--leading", type=int, default=0, dest="leading")
- self.arg_parser.add_argument("-w", "--word-spacing", type=int, default=26, dest="word_spacing")
+ self.arg_parser.add_argument("--use-custom-leading", type=Boolean, default="false", dest="use_custom_leading")
+ self.arg_parser.add_argument("--use-custom-spacing", type=Boolean, default="false", dest="use_custom_spacing")
+ self.arg_parser.add_argument("--use-custom-letter-spacing", type=Boolean, default="false", dest="use_custom_letter_spacing")
+ self.arg_parser.add_argument("-l", "--leading", type=int, default=100, dest="leading")
+ self.arg_parser.add_argument("-w", "--word-spacing", type=int, default=20, dest="word_spacing")
+ self.arg_parser.add_argument("-b", "--letter-spacing", type=int, default=100, dest="letter_spacing")
self.arg_parser.add_argument("-p", "--font-file", type=str, default="", dest="path")
for category in FONT_CATEGORIES:
@@ -59,12 +61,17 @@ class LetteringGenerateJson(InkstitchExtension):
hkern = font_info.hkern()
custom_leading = self.options.use_custom_leading
custom_spacing = self.options.use_custom_spacing
+ custom_letter_spacing = self.options.use_custom_letter_spacing
word_spacing = font_info.word_spacing()
# use user input in case that the default word spacing is not defined
# in the svg file or the user forces custom values
if custom_spacing or not word_spacing:
word_spacing = self.options.word_spacing
letter_spacing = font_info.letter_spacing()
+ # use user input in case that the default word spacing is not defined
+ # in the svg file or the user forces custom values
+ if custom_letter_spacing or not letter_spacing:
+ letter_spacing = self.options.letter_spacing
units_per_em = font_info.units_per_em() or self.options.leading
# use units_per_em for leading (line height) if defined in the font file,
# unless the user wishes to overwrite the value
diff --git a/lib/gui/edit_json/main_panel.py b/lib/gui/edit_json/main_panel.py
index cd2657ab..bd43f523 100644
--- a/lib/gui/edit_json/main_panel.py
+++ b/lib/gui/edit_json/main_panel.py
@@ -517,7 +517,10 @@ class LetteringEditJsonPanel(wx.Panel):
if horiz_adv_x_default in [0, None]:
horiz_adv_x_default = glyph.width + glyph.min_x
- position_x += self.font.horiz_adv_x.get(character, horiz_adv_x_default) - glyph.min_x
+ # in some rare cases, horiz_adv_x for a character returns None
+ # so we need to really ensure that the default is used in this case
+ horiz_adv_x = self.font.horiz_adv_x.get(character, horiz_adv_x_default) or horiz_adv_x_default
+ position_x += horiz_adv_x - glyph.min_x
self.font._update_commands(node, glyph)
self.font._update_clips(self.layer, node, glyph)
diff --git a/templates/lettering_generate_json.xml b/templates/lettering_generate_json.xml
index 9755652a..62675545 100644
--- a/templates/lettering_generate_json.xml
+++ b/templates/lettering_generate_json.xml
@@ -107,8 +107,16 @@
20
-
+
+
+ false
+ 100
+
+
+
--
cgit v1.2.3