X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/c32011016e046e39ac53f81303c9f3b95b0e9c89..ad81ac24b07376ca3ca8899e2fa4eed19f7f32c7:/termcol.plp diff --git a/termcol.plp b/termcol.plp index 3dd1d1b..0e3c979 100644 --- a/termcol.plp +++ b/termcol.plp @@ -1,61 +1,186 @@ -<: -use utf8; -use strict; -use warnings; -use open IO => ':utf8'; +<(common.inc.plp)><: -our $VERSION = 'v1.0'; +Html({ + title => 'terminal colour cheat sheet', + version => 'v1.0', + description => [ + "Index of all terminal/console colour codes,", + "with an example result of various environments.", + ], + keywords => [qw' + color code terminal console escape table xterm rxvt + '], + stylesheet => [qw'light dark'], +}); -$header{content_type} = 'text/html; charset=utf-8'; +:> +

Terminal colours

-:> - +
+<: +use Shiar_Sheet::Colour; - -terminal colour cheat sheet - - - +sub colcell { + my $name = shift; + my $col = Shiar_Sheet::Colour->new(@_); + my $minhex = $col->rgb24; + my $css = '#' . $col->rgb48; + my $inverse = '#' . sprintf('%X', $col->luminance/255 < .3 ? 12 : 0) x 3; - -

Terminal colours

+ my $sample = [ qw(#000 #FFF) ]; + ($name, $sample) = @$name if ref $name eq 'ARRAY'; + + my $out = sprintf('%s', + join(',', map { int } @$col), + "background:$css; color:$inverse; padding:0 1ex", + $name, + ); + $out .= sprintf '%s', "background:$_; color:$css", $minhex + for @$sample; + return "$out\n"; +} - - -<: my %col = ( - -name => [ - qw/black red green orange blue magenta cyan gray - gray red green yellow blue magenta cyan white/, + -html => [ + sprintf('html', + 'HTML keywords (inherited by CSS≥2.1 and SVG), mostly identical to X11', + 'http://www.w3.org/TR/css3-color/#html4', + ), + qw/black maroon green olive navy purple cyan silver + gray red lime yellow blue fuchsia aqua white/, qw/reset bold dim italic underline blink fastblink reverse hidden/, ], - linux => [ - qw/000 CCC/, - qw/000 A00 0A0 A50 00A A0A 0AA AAA - 555 F55 5F5 FF5 55F F5F 5FF FFF/, + html => [ + qw/000000 800000 008000 808000 000080 800080 008080 C0C0C0 + 808080 FF0000 00FF00 FFFF00 0000FF FF00FF 00FFFF FFFFFF/, + ], +# -cga => linux console, kde? + cga => [ + qw/000000 AA0000 00AA00 AA5500 0000AA AA00AA 00AAAA AAAAAA + 555555 FF5555 55FF55 FFFF55 5555FF FF55FF 55FFFF FFFFFF/, ], +# -xterm => rxvt except for blues xterm => [ - qw/000 CCC/, - qw/000 C00 0C0 CC0 4682B4 C0C 0CC E5E5E5 - 4C4C4C F00 0F0 FF0 1E90FF F0F 0FF FFF/, + qw/000000 CC0000 00CC00 CCCC00 4682B4 CC00CC 00CCCC E5E5E5 + 4C4C4C FF0000 00FF00 FFFF00 1E90FF FF00FF 00FFFF FFFFFF/, ], +# -tango => default Gnome theme tango => [ - qw/000 CCC/, qw/2E3436 CC0000 4E9A06 C4A000 3465A4 75507B 06989A D3D7CF 555753 EF2929 8AE234 FCE94F 729FCF AD7FA8 34E2E2 EEEEEC/, ], + -xkcd => [ + sprintf('xkcd', + 'human averages in xkcd survey results', + 'http://blog.xkcd.com/2010/05/03/color-survey-results/', + ), + qw/black maroon green olive navy purple teal silver + grey red lime yellow blue fuchsia cyan white/, + ], + xkcd => [ + qw/000000 650021 15b01a 6e750e 01153e 7e1e9c 029386 c5c9c7 + 929591 e50000 aaff32 ffff14 0343df ed0dd9 00ffff ffffff/, + ], + -android => [ + sprintf('android', + 'http://developer.android.com/guide/practices/ui_guidelines/icon_design.html', + 'recommended colour palette for Android icons', + ), + qw/white light medium dark black blue1 blue2 blue3 + green1 green2 green3 orange1 orange2 orange3 red /, + ], + android => [ + qw/FFFFFF BFBFBF 808080 404040 000000 6699FF 3366CC 003399 + 99CC33 00CC00 669933 FFCC00 FF9900 FF6600 CC0000 /, + ], + -app => [ + 'Term.app', + ], + app => [ + qw/000000 C23621 25BC24 ADAD27 492EE1 D338D3 33BBC8 CBCCCD + 818383 FC391F 31E722 EAEC23 5833FF F935F8 14F0F0 E9EBEB /, + ], + putty => [ + qw/000000 BB0000 00BB00 BBBB00 0000BB BB00BB 00BBBB BBBBBB + 555555 FF5555 55FF55 FFFF55 5555FF FF55FF 55FFFF FFFFFF /, + ], + -slutty => [ + sprintf('SluTTY', + 'http://www.npjh.com/slutty.html', + 'PuTTY fork with light colour scheme', + ), + ], + slutty => [ + qw/000000 9C1D1D 6C9446 AC9A47 335786 8F6496 486768 E0DCDC + 2F2F2F CD5757 8FC35B D1C45E 5C81A9 BC95B7 76CBCB EEEEEC /, + ], ); -for my $num (0 .. 15) { - printf(''."\n", - $num, - $col{-name}[$num], - join('', map {sprintf '
#xterm
%d%s%s
 â–ª ', - 'background:#'.$col{$_}[0].'; color:#'.$col{$_}[$num + 2], - } qw/linux xterm tango/ ), - ); +for my $term (qw/cga xterm tango app html xkcd/) { + print '', "\n"; + printf "\n", $col{"-$term"}[0] || $term; + for my $num (0 .. $#{ $col{$term} }) { + my $rgb = $col{$term}[$num]; + my $name = $col{"-$term"}[$num + 1] || $num; + $name = [ $name, ['#333'] ] if $term eq 'xkcd'; + print '', colcell($name, $rgb); + } + print "
%s
\n\n"; +} +:> + +
+ +
+

88-colour space

+<: +for my $r (0 .. 3) { + print ''; + for my $g (0 .. 3) { + print ''; + for my $b (0 .. 3) { + my $index = $r*4*4 + $g*4 + $b + 16; + print colcell($index, map {(0, 139, 205, 255)[$_]} $r, $g, $b); + } + } + print "
\n"; } -:>
+print "\n"; + +print ''; +print colcell(80+$_, (($_ + 2 + ($_>0)) * 255/11) x 3) for 0 .. 7; +print "
\n\n"; + +:>
+<: if ($ENV{PATH_INFO} =~ /256/) { :> +
+ +
+

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); + } + } + print "
\n"; +} +print "\n"; + + print ''; +for my $row (0, 12) { + print ''; + print colcell(232+$_, ($_*10 + 8) x 3) for $row .. $row+11; +} + print "
\n"; +print "\n"; + +:>
+<: } :> +