latin: cmymap row of subtractive colour mix
[sheet.git] / writing-latn.inc.pl
index d8d0d53f27af92d45cf6aa4821b8156ed2e8e036..60b24f960d9b38ac07122b05eca283ff89fdb6b4 100644 (file)
@@ -49,6 +49,22 @@ sub dispbar {
        );
 }
 
+sub disphues {
+       my ($index, $hues, $opaque) = @_;
+       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(
+               '<svg width="16" height="16" viewBox="0 0 22 22">%s</svg>',
+               join '', map {
+                       my $colf = $lumf[ $lum[$_] ];
+                       !$colf ? () : sprintf('<circle cx="%d" cy="%d" r="%d" fill="%s"/>',
+                               10 + $_, $_ == 1 ? 12 : 10, 10, 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 }],
@@ -448,6 +464,30 @@ 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
+               0 .. 3*3*3 - 1
+       ],
+},
+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
+               0 .. 3*3*3 - 1
+       ],
+},
 dni => {
        title => "D'ni",
        list => [