[gimp] Issue #230: ruler subdivision is wrong for inches.
- From: Jehan <jehanp src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp] Issue #230: ruler subdivision is wrong for inches.
- Date: Sun, 23 Jun 2019 14:40:54 +0000 (UTC)
commit 2b22dffc49077a8978507b70b2224bd77f66cae6
Author: Jehan <jehan girinstud io>
Date: Sun Jun 23 16:29:47 2019 +0200
Issue #230: ruler subdivision is wrong for inches.
Make better subvision, as well as ruler steps, based on what seems to be
the common trends for rulers of these 3 units (inch, foot and yard), but
also based on common conversion needs.
Main changes are:
- Always subdivide inches by 2, down to 1/256, and get rid of the gap
where inches division jumped from 1/16 to 1/192 (which is not even a
multiple of 2).
- Add the 72 steps to inch ruler (1 fathom).
- Replace the 2 feet by a 3 feet (1 yard) step.
- Use base-10 steps for yard (there don't seem to be bigger units in the
imperial/US measurement system which needs specific steps).
- Add the 1/36 yard (= 1 inch) division.
- Below 1/12 feet and 1/36 yard, divide by multiples of 2 (inch-style).
libgimpwidgets/gimpruler.c | 32 ++++++++++++++++++++++++++------
1 file changed, 26 insertions(+), 6 deletions(-)
---
diff --git a/libgimpwidgets/gimpruler.c b/libgimpwidgets/gimpruler.c
index 6582db6e1d..9a898e0676 100644
--- a/libgimpwidgets/gimpruler.c
+++ b/libgimpwidgets/gimpruler.c
@@ -94,20 +94,33 @@ static const RulerMetric ruler_metric_decimal =
static const RulerMetric ruler_metric_inches =
{
- { 1, 2, 6, 12, 36, 100, 250, 500, 1000, 2500, 5000, 10000, 25000, 50000, 100000 },
- { 1, 4, 8, 16, 12 * 16 }
+ /* 12 inch = 1 foot; 36 inch = 1 yard; 72 inchs = 1 fathom */
+ { 1, 2, 6, 12, 36, 72, 100, 250, 500, 1000, 2500, 5000, 10000, 25000, 50000, 100000 },
+
+ /* Inches are divided by multiples of 2. */
+ { 1, 2, 4, 8, 16, 32, 64, 128, 256 }
};
static const RulerMetric ruler_metric_feet =
{
- { 1, 2, 6, 12, 36, 100, 250, 500, 1000, 2500, 5000, 10000, 25000, 50000, 100000 },
- { 1, 3, 6, 12, 12 * 8 }
+ /* 3 feet = 1 yard; 6 feet = 1 fathom */
+ { 1, 3, 6, 12, 36, 100, 250, 500, 1000, 2500, 5000, 10000, 25000, 50000, 100000 },
+
+ /* 1 foot = 12 inches, so let's divide up to 12. */
+ { 1, 3, 6, 12,
+ /* then since inches are divided by 2, continue by 2-divisions. */
+ 24, 48, 96, 192 }
};
static const RulerMetric ruler_metric_yards =
{
- { 1, 2, 6, 12, 36, 100, 250, 500, 1000, 2500, 5000, 10000, 25000, 50000, 100000 },
- { 1, 3, 6, 12, 12 * 12 }
+ /* 1 fathom = 2 yards. Should we go back to base-10 digits? */
+ { 1, 2, 5, 10, 25, 50, 100, 250, 500, 1000, 2500, 5000, 10000, 25000, 50000, 100000 },
+
+ /* 1 yard = 3 feet = 36 inches. */
+ { 1, 3, 6, 12, 36,
+ /* Then divide by 2, inch style */
+ 72, 144, 288 }
};
@@ -1389,6 +1402,13 @@ gimp_ruler_get_metric (GimpUnit unit)
{
return &ruler_metric_inches;
}
+ /* XXX: recognizing feet or yard unit this way definitely sucks.
+ * Actually the subdvision and rule scale rules should probably become
+ * settable values in unitrc instead of hardcoded rules.
+ * This way, people would be able to set how they want a unit to be
+ * shown (we could definitely imagine someone wanting to see inches
+ * with base-10 divisions).
+ */
else if (FACTOR_EQUAL (unit, 0.083333))
{
return &ruler_metric_feet;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]