X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/53885bccd7945b6d1d39baef16290e086ce97027..f6124d71ef6b9a8d73e9efae33aa769855764416:/writing-latn.inc.pl diff --git a/writing-latn.inc.pl b/writing-latn.inc.pl index f0a3e40..2c9b59f 100644 --- a/writing-latn.inc.pl +++ b/writing-latn.inc.pl @@ -1,10 +1,45 @@ use 5.014; use utf8; +use warnings; use List::Util qw( pairs pairmap sum ); -my %C = qw(red #EC1C24 blue #3953A3 yellow #F9EC31 black #231F20); +my %C = ( + red => '#EC1C24', + blue => '#3953A3', + yellow => '#F9EC31', + black => '#231F20', +); my $U = 0; # optional unicode alternatives +my @wrapstyle = ( + 'td { white-space: normal; word-spacing: 10em }', # force line break between words + '.sample { word-spacing: 0 }', + '.sample span { margin-right: 1ex; white-space: nowrap; display: inline-block }', # larger space between letters +); +my $spacestyle = '.sample span { margin-right: 0.5ex }'; # separate multiple letters +my @tapstyle = ( + @wrapstyle, + '{ line-height: 1ex }', + '.sample { font-size: 80% }', +); + +my @hueorder = ( + 2,11,20,19,18,21,24,15,6,7,8,5,13, # red .. magenta, grey + 1,10,9,12,3,4,0, 14,23,22,25,16,17,26, # dark, light hues +); + +# Order to put similar sounds close to each other: +# ┌ R Y G C B M X +# ┌┼────────────── +# W│ o e y h s f - +# │muaixqgkdtbp l +# K│ w n j c z v r + +my @hueletters = ((26) x 27); +@hueletters[map { ord($_) - ord('a') } qw( + u a i x q g k d t b p m l w n j c z v r o e y h s f +)] = @hueorder; + sub disptap { my $code = shift; my ($prefix, @dots) = $code =~ m/\A(-?)(\d)(\d)/ or return $code; @@ -37,6 +72,23 @@ sub dispbar { ); } +sub disphues { + my ($index, $hues, $opaque) = @_; + $index >= 0 or $index = 26; + my @lum = ($index % 3, $index / 3 % 3, $index / 9); # hue opacities (0..2)x3 + my @lumf = $opaque ? ('hsl(%s,100%%,50%%)', 'hsl(%s,100%%,25%%)') : + ('hsl(%s,100%%,50%%)', 'hsla(%s,100%%,50%%,.5)'); + return sprintf( + '%s', + join '', map { + my $colf = $lumf[ $lum[$_] ]; + !$colf ? () : sprintf('', + 5 + $_, $_ == 1 ? 7 : 5, 5, sprintf($colf, $hues->[$_]) + ); + } 0 .. 2 + ); +} + ( uppercase => { list => [qw{ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z }], @@ -46,10 +98,21 @@ lowercase => { }, suetterlin => { title => 'Sütterlin', + style => [ + '@font-face { + font-family: Suetterlin; /* R. G. Arens */ + src: url("/suetterlin.ttf"); + }', + 'td { font-family: Suetterlin }', + ], list => [qw{ a b c d e f g h i j k l m n o p q r ſ s t u v w x y z }], }, roman => { title => 'Old Roman Cursive', + style => [ + 'svg path { stroke-linecap: round; stroke-linejoin: round }', + '.sample span { margin-right: -10px }', + ], list => [ map { !m/^(-?)(\w.+)/ ? $_ : @@ -85,6 +148,7 @@ roman => { }, sutton => { title => 'Sutton ASL', + style => $spacestyle, list => [ # American manual alphabet in Sutton (U+1D800+) notation map { !!$_ && pack 'W*', map { hex "1D$_" } unpack '(A3)*', $_ } qw{ @@ -99,6 +163,8 @@ sutton => { }, unistrokes => { title => 'Unistrokes', + url => 'https://www.google.com/patents/US5596656', # by Xerox + style => 'svg path { stroke-linecap: round; stroke-linejoin: round }', list => [ map { ''.$_.'' } map { @@ -134,11 +200,35 @@ unistrokes => { 'M3,4', ], }, +edgewrite => { + title => 'EdgeWrite', + url => 'http://depts.washington.edu/ewrite/', # patented US7729542 + style => 'svg path { stroke-linecap: round; stroke-linejoin: round }', + list => [ + map { ''.$_.'' } + map { + my @route = split //; + my @coords = map { $_ % 2 << 3, $_ >> 1 << 3 } @route; # x,y, + sprintf('', @coords[0, 1]) . # start point + sprintf('', join ' ', map { + my $pos = join(',', @coords[$_*2, $_*2 + 1]); + $_ > 1 && $route[$_] == $route[$_ - 2] ? 'Q4,4 '.$pos.'L' : # curve back + $pos + } 0 .. $#route) + } + # corners (0..3) clockwise from top-left in order + qw( + 213 0232 1023 1323 103 102 10132 0213 02 132 02123 023 20313 2031 + 10231 0102 10131 201 1032 013 0231 021 02131 0312 0313 0123 01 + ) + ], +}, #graffiti => { # title => 'Palm Graffiti', #}, ita2 => { title => 'ITA2', + style => [@wrapstyle, 'td { font-size: 50% }'], list => [map { tr/01/○●/r =~ s/..\K/ /r } qw( 11000 10011 01110 10010 10000 10110 01011 00101 01100 11010 11110 01001 00111 00110 00011 01101 11101 01010 10100 00001 11100 01111 11001 10111 10101 10001 @@ -167,6 +257,7 @@ tactile => { ], }, morse => { + style => $spacestyle, list => [map {tr/.-/‧‑/r} qw{ .- -... -.-. -.. . ..-. --. .... .. .--- -.- .-.. -- -. --- .--. --.- .-. ... - ..- ...- .-- -..- -.-- --.. @@ -174,6 +265,7 @@ morse => { }, tap => { title => 'Tap code', + style => \@tapstyle, list => [map { disptap($_) } qw{ 11 12 13 14 15 21 22 23 > 24 25 31 32 33 34 35 41 42 43 44 45 51 52 53 54 55 @@ -181,12 +273,14 @@ tap => { }, shorttap => { title => 'Short Tap', + style => \@tapstyle, list => [map { disptap($_) } qw{ 11 12 13 14 21 22 23 20 > 31 -13 32 33 30 41 42 -13 43 40 10 51 52 53 50 -31 -40 }], }, cards => { + style => 'td { font-family: Symbola, "DejaVu Sans", serif, sans }', list => [( map { chr(0x1F0A0 + $_), sprintf('%s', chr(0x1F0B0 + $_)) } # spades, hearts 1 .. 11, 13, 14 # A 2-10 J Q K @@ -194,6 +288,7 @@ cards => { }, maritime => { title => 'Maritime flags', + style => $spacestyle, list => [ # International Code of Signals, SVG fills map { !!$_ && ''.s/\n?\t+//gr.'' } @@ -386,7 +481,7 @@ code128 => { list => [map { dispbar($_) } qw( 111323 131123 131321 112313 132113 132311 211313 231113 231311 112133 112331 132131 113123 113321 133121 313121 211331 231131 213113 213311 - 213131 311123 311321 331121 312113 312311 212222 0 211412 2331112 + 213131 311123 311321 331121 312113 312311 212222 0 211412 23311120 )], }, rm4scc => { @@ -417,11 +512,39 @@ rm4scc => { '', 1, 3 # start/end ], }, +rgbmap => { + title => 'RGBmap', + style => [ + 'svg { isolation: isolate }', + 'svg circle { mix-blend-mode: screen }', + '.sample { background: black }', + ], + list => [ + map { disphues($_, [0, 240, 120], 1) } # Red, Blue, Green + @hueorder[23..25,20..22, 12, 6..11,0..5, 16..18, 13..15, 19, 26], + ], +}, +cmymap => { + title => 'CMYmap', + style => [ + 'svg { isolation: isolate }', # mix on white + 'svg circle { mix-blend-mode: multiply }', + '.sample { background: white }', + ], + list => [ + map { disphues($_, [180, 60, 300]) } # Cyan, Yellow, Magenta +# @hueorder[13..18, 19, 0..11, 20..25, 12, 26], + @hueletters + ], +}, dni => { title => "D'ni", + style => [ + 'svg { border: 1px solid #000 }', + '.sample span + span svg { border-left: 0 }', + ], list => [ map { - state $window = 'M-.5,-.5H8.5V8.5H-.5Z'; state $v = [ '', 'M0,4 8,4', @@ -438,12 +561,16 @@ dni => { 'M4,-.5 0,4 4,8.5', 'M4,8 4,2 8,2', ]; - sprintf '', - $window . ($h->[$_ % 5] . $v->[$_ / 5] || $v->[6]); + sprintf '', + $h->[$_ % 5] . $v->[$_ / 5] || $v->[6]; } 0 .. 5*5 ], }, pigpen => { + style => [ + 'svg path { stroke-linecap: square }', + '.sample svg { margin-right: 0.1em }', + ], list => [ map { qq($_) @@ -468,6 +595,14 @@ pigpen => { ], }, nyctographs => { + style => [ + 'svg path { stroke-linecap: round; stroke-linejoin: round }', + '.sample svg { + background: rgba(0,0,0, .1); + padding: 0.1em; + margin-right: 0.2em; + }', + ], list => [ map { s/M[\d,\hM]+(?=[M"])//gr } # clean up superfluous moves map { sprintf @@ -480,17 +615,18 @@ nyctographs => { # draw style (0=empty, 1=dot, 2=line connect) to right, down, left, up qw( 0010 0112 2022 2220 2000 2012 0122 0202 0020 0220 0012 0022 2202 - 0222 2222 0102 0200 2201 2002 2200 0100 0110 0120 2001 2010 2020 0 + 0222 2222 0102 0200 2201 2002 2200 0100 0110 0120 2001 2010 2020 0000 ), ], }, chromacons => { +# style => '.sample { word-break: break-all }', list => [ # Colour Alphabet by Paul Green-Armytage (2010) map { sprintf('%s', !!$_ && sprintf(' style="background:#%s" title="%s"', split /:/), - chr(8195), # em space + chr(8195) . (!$_ && chr(8203)) # em space (plus zwsp for spaces) ); } qw{