X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/796b36858c7d2dd94400f795459ac9802be66359..c37471e7de29ef22e46af32074478bd86a48a0b1:/termcol.plp diff --git a/termcol.plp b/termcol.plp index 0a164b7..d945079 100644 --- a/termcol.plp +++ b/termcol.plp @@ -28,10 +28,11 @@ print
<: -use Shiar_Sheet::Colour '1.01'; +use Shiar_Sheet::Colour '1.03'; +use List::Util qw( min max ); sub colcell { - my $name = shift; + my $name = shift or return "\n"; my $col = Shiar_Sheet::Colour->new(@_); my $minhex = $col->rgb24; my $css = '#' . $col->rgb48; @@ -193,6 +194,11 @@ my %col = ( if ($get{v}) { my %reorder = ( arnegame => [ 0,5,9,12 , 3,6,10,13,1 , 4,7,8,11,14,15,2 ], + arnegame => [ 0,3,10,6,12,9,13,1 , 5,7,11,8,14,4,15,2 ], + c64 => [ 0,2,5,9,6,4,3,15 , 11,10,13,7,14,8,12,1 ], + msx2 => [ 0,6,2,10,4,13,7,14 , 1,8,3,11,5,9,12,15 ], + risc => [ 7,11,13,14,8,12,15,1, 6,5,10,9,4,3,2,0], + mac2 => [ 15,3,9,11,6,5,7,12 , 14,2,8,1,13,4,10,0 ], ); $reorder{$_} = $reorder{msx2} for qw( msx1 arnejmp ); while (my ($name, $order) = each %reorder) { @@ -246,27 +252,68 @@ print "\n\n";

256-colour space

<: -for my $r (0 .. 5) { - print ''; - for my $g (0 .. 5) { - print ''; - for my $b (0 .. 5) { - my $index = $r*6*6 + $g*6 + $b + 16; - print colcell($index, map { $_ && $_*40 + 55 } $r, $g, $b); +sub coltable_hsv { + my ($dim, $rgbval, $greyramp) = @_; + + my $hmax = ($dim + $dim - 1) * 2 + ($dim - 2) * 2 + 3; + my $vmax = $dim - 1; + my $smax = $dim - 1; + + my %greymap; # name => value + my @colmap; # saturation => value => hue => [name, r,g,b] + my $offset = 16; + + for my $r (0 .. $dim - 1) { + for my $g (0 .. $dim - 1) { + for my $b (0 .. $dim - 1) { + my $index = $r*$dim*$dim + $g*$dim + $b + $offset; + my @rgb = map { &$rgbval } $r, $g, $b; + + my $h = Shiar_Sheet::Colour->new(@rgb)->hue * $hmax; + my $v = int(max(@rgb) / 255 * $vmax); + my $s = abs(min(@rgb) - max(@rgb)) / 255 * $smax; + + if (!$s) { + $greymap{$index} = $rgb[0]; + next; + } + + $v = $vmax - $v; + $s = $smax - $s - $v; + + $colmap[$s][$v][$h] = [$index, @rgb]; + } } } - print "
\n"; -} -print "\n"; - print ''; -for my $row (0, 12) { - print ''; - print colcell(232+$_, ($_*10 + 8) x 3) for $row .. $row+11; + my $out = '
'; + $out .= sprintf '', 3 * @{$_} for @colmap; + my $huerow = $colmap[0][0]; # first {$_} map { @{$_} } @colmap; + for my $h (grep { $huerow->[$_] } 0 .. $#{$huerow}) { + $out .= ''; + $out .= colcell(@$_) for map { $_->[$h] } map { @{$_} } @colmap; + } + $out .= "
\n\n"; + + $offset += $dim ** 3; + $greymap{$offset++} = $_ for @{$greyramp}; + + $out .= ''; + my $col = 0; + my $colbreak = keys(%greymap) / 2; # split into 2 rows + for my $num (sort { $greymap{$a} <=> $greymap{$b} } keys %greymap) { + $out .= '' unless $col++ % $colbreak; + $out .= colcell($num, ($greymap{$num}) x 3); + } + $out .= "
\n\n"; + + return $out; } - print "\n"; -print "\n"; +print coltable_hsv(6, + sub { $_ && $_*40 + 55 }, + [ map { $_ * 10 + 8 } 0 .. 23 ], +); :>
<: } :>