-
Notifications
You must be signed in to change notification settings - Fork 65
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add Saudi Arabia national shields #851
base: main
Are you sure you want to change the base?
Changes from 1 commit
f508517
a65d52f
56ff0cf
84931c4
fd71cb4
c4fd133
5b7c2d3
f1f10a6
8184ac7
02a74c6
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -303,6 +303,23 @@ export function getRouteDef(id) { | |
}; | ||
} | ||
|
||
/** | ||
* Reformats an alphanumeric ref as Eastern Arabic numerals, preserving any | ||
* alphabetic suffix. | ||
*/ | ||
export const latinToArabicDigits = (ref) => | ||
`${ref}` | ||
.replaceAll("0", "\u0660") | ||
.replaceAll("1", "\u0661") | ||
.replaceAll("2", "\u0662") | ||
.replaceAll("3", "\u0663") | ||
.replaceAll("4", "\u0664") | ||
.replaceAll("5", "\u0665") | ||
.replaceAll("6", "\u0666") | ||
.replaceAll("7", "\u0667") | ||
.replaceAll("8", "\u0668") | ||
.replaceAll("9", "\u0669"); | ||
claysmalley marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
/** | ||
* Reformats an alphanumeric ref as Roman numerals, preserving any alphabetic | ||
* suffix. | ||
|
@@ -382,8 +399,15 @@ export function generateShieldCtx(map, id) { | |
// Convert numbering systems. Normally alternative numbering systems should be | ||
// tagged directly in ref=*, but some shields use different numbering systems | ||
// for aesthetic reasons only. | ||
if (routeDef.ref && shieldDef.numberingSystem === "roman") { | ||
routeDef.ref = romanizeRef(routeDef.ref); | ||
if (routeDef.ref) { | ||
switch (shieldDef.numberingSystem) { | ||
case "arab": | ||
routeDef.ref = latinToArabicDigits(routeDef.ref); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
In #676, I included a Roman numeral conversion function because the Roman numerals were purely decorative. In plain text (and even some signs), the route numbers are in Western Arabic numerals. By contrast, Eastern Arabic is the local language’s numeral system. Would it be more appropriate to render the number however it’s tagged in /ref https://github.com/ZeLonewolf/openstreetmap-americana/issues/467#issuecomment-1169234746 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is a philosophical question indeed. Off the cuff I would say the ref should have the Eastern Arabic numbers in them, which we would render with the right font. This PR takes a more resilient approach and papers over the difference at the expense of not exposing what we might agree is an error. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It would be worth asking the folks that implemented the scheme though I'm not sure who to ask. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Note that most of Saudi Arabia’s highways are also part of the Arab Mashreq International Road Network, which is signposted and tagged in Western Arabic numerals: #466. |
||
break; | ||
claysmalley marked this conversation as resolved.
Show resolved
Hide resolved
|
||
case "roman": | ||
routeDef.ref = romanizeRef(routeDef.ref); | ||
break; | ||
} | ||
} | ||
|
||
// Add the halo around modifier plaque text | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3687,6 +3687,20 @@ export function loadShields() { | |
}, | ||
}; | ||
|
||
// Saudi Arabia | ||
shields["SA:national"] = { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
The one |
||
spriteBlank: "shield_sa_national", | ||
textLayout: textConstraint("diamond"), | ||
textColor: Color.shields.black, | ||
numberingSystem: "arab", | ||
padding: { | ||
left: 3, | ||
right: 2, | ||
top: 4, | ||
bottom: 3, | ||
}, | ||
}; | ||
|
||
// Turkey | ||
shields["TR:motorway"] = hexagonVerticalShield( | ||
2, | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I picked a few Naskh fonts that are available by default on most operating systems. I'm not 100% sure these are all the best choices, but they look close enough to the style as shown on Saudi shields.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Legibility doesn't look good on my system:
Why not use the packaged Americana fontstacks that have Arabic?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shields are rendered client-side using fonts available to the browser. We would have to re-engineer shields to render text from a PBF fontstack instead of standard web formats.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh duh good point. Don't you need some kind of
<link>
tag to use the Google Noto fonts?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Something like
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not if it's already installed on the system, as with Android. But downloading and displaying Noto on all systems is an option.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a reason we wouldn't? I assume it's just a one time download into browser cache.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I suppose not. Though we might as well include Noto Sans Armenian as well, if consistency is what we're going for.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess we'll need whatever scripts would get rendered into shields.