Colors with Names

Keith Vetter 2003-03-21 :

Recently I needed to choose lots of different colors for a project. I'm not on Unix so I can't run xcolors. Also, I didn't find color values available for syntactic use in Tcl scripts with Jeff Hobb's utility until later.

Be that as it may, I went and wrote a little utility to display all of the colors that Tcl/Tk knows the name for. Moving your mouse over a color will display its name, RGB value and its numeric name. Double clicking will copy the color name to the clipboard.

It will also display the Windows-specific colors like SystemButtonFace and SystemHightlightText.


LV 2003-03-25: When I saw this page title, I thought the page was going to be about the idea of creating the equivalent of named fonts - in this case, the ability for a user to associate a symbolic name to a color setting, use the symbolic name through the application, then change the colors of all items using the symbolic name via one command.

KPV responds: See the original wiki page for this Named Colors.

LV continues: My second thought, having read the page, is how sad it is that Tk doesn't provide these names via some command.


It's also possible to go the other way programmatically. That's the job of closest color name.


KPV 2006-07-20: fixed a reformatting bug that allowed newlines into some color names. Also leveraged ::tk::Darken for prettier #xxyyzz display.

Zipguy 2013-02-09: I did copy, paste into a new file in Context (a nice editor for some purposes), commented out all these lines, added the two lines to the top, saved it as colornames.tcl (in the proper directory, re-opened it in ML - Heavily Modified & Improved, and it looked good. So I hit the gear in ML (to save and run it), and it did work. It looked like this:

https://www.geocities.ws/thezipguy/misc/colornames_1.png

which looked wonderful! You can see the rest of the screens at Color Names, running, all screens.

You did try real hard to hide that little, tiny button but I did find it:

https://www.geocities.ws/thezipguy/misc/colornames_kv.png

So, what I plan on doing is to make a slightly modified version that will also display a second version of the colors, sorted by name, and add a button somewhere to toggle them back and forth (Sorted vs By Color). This is what the code looks like in ML (colorized for syntax):

https://www.geocities.ws/thezipguy/misc/colornames_mlv.png

You don't see the "Procedures" window, which is now separate, but joined with the main window a la How do you make two windows act as one?. There, you can see the "Procedure" window slightly obscured (but you can see the first eight characters of it). Anyway, what I'm doing is trying to understand all of the code, first.


Jeff Smith 2019-06-14 : Below is an online demo using CloudTk

Please Note : This demo has a run time of 2 minutes.


##+#################################################################
#
# Named Colors -- lists and displays all of tcl's named colors
# by Keith Vetter, March 19 2003

package require Tk

set COLORS { snow {ghost white} {white smoke} gainsboro {floral white}
    {old lace} linen {antique white} {papaya whip} {blanched almond}
    bisque {peach puff} {navajo white} moccasin cornsilk ivory
    {lemon chiffon} seashell honeydew {mint cream} azure {alice blue}
    lavender {lavender blush} {misty rose} white black {dark slate gray}
    {dim gray} {slate gray} {light slate gray} gray {light grey}
    {midnight blue} navy {cornflower blue} {dark slate blue} {slate blue}
    {medium slate blue} {light slate blue} {medium blue} {royal blue}
    blue {dodger blue} {deep sky blue} {sky blue} {light sky blue}
    {steel blue} {light steel blue} {light blue} {powder blue}
    {pale turquoise} {dark turquoise} {medium turquoise} turquoise
    cyan {light cyan} {cadet blue} {medium aquamarine} aquamarine
    {dark green} {dark olive green} {dark sea green} {sea green}
    {medium sea green} {light sea green} {pale green} {spring green}
    {lawn green} green chartreuse {medium spring green} {green yellow}
    {lime green} {yellow green} {forest green} {olive drab} {dark khaki}
    khaki {pale goldenrod} {light goldenrod yellow} {light yellow} yellow
    gold {light goldenrod} goldenrod {dark goldenrod} {rosy brown}
    {indian red} {saddle brown} sienna peru burlywood beige wheat
    {sandy brown} tan chocolate firebrick brown {dark salmon} salmon
    {light salmon} orange {dark orange} coral {light coral} tomato
    {orange red} red {hot pink} {deep pink} pink {light pink}
    {pale violet red} maroon {medium violet red} {violet red}
    magenta violet plum orchid {medium orchid} {dark orchid} {dark violet}
    {blue violet} purple {medium purple} thistle snow2 snow3
    snow4 seashell2 seashell3 seashell4 AntiqueWhite1 AntiqueWhite2
    AntiqueWhite3 AntiqueWhite4 bisque2 bisque3 bisque4 PeachPuff2
    PeachPuff3 PeachPuff4 NavajoWhite2 NavajoWhite3 NavajoWhite4
    LemonChiffon2 LemonChiffon3 LemonChiffon4 cornsilk2 cornsilk3
    cornsilk4 ivory2 ivory3 ivory4 honeydew2 honeydew3 honeydew4
    LavenderBlush2 LavenderBlush3 LavenderBlush4 MistyRose2 MistyRose3
    MistyRose4 azure2 azure3 azure4 SlateBlue1 SlateBlue2 SlateBlue3
    SlateBlue4 RoyalBlue1 RoyalBlue2 RoyalBlue3 RoyalBlue4 blue2 blue4
    DodgerBlue2 DodgerBlue3 DodgerBlue4 SteelBlue1 SteelBlue2
    SteelBlue3 SteelBlue4 DeepSkyBlue2 DeepSkyBlue3 DeepSkyBlue4
    SkyBlue1 SkyBlue2 SkyBlue3 SkyBlue4 LightSkyBlue1 LightSkyBlue2
    LightSkyBlue3 LightSkyBlue4 SlateGray1 SlateGray2 SlateGray3
    SlateGray4 LightSteelBlue1 LightSteelBlue2 LightSteelBlue3
    LightSteelBlue4 LightBlue1 LightBlue2 LightBlue3 LightBlue4
    LightCyan2 LightCyan3 LightCyan4 PaleTurquoise1 PaleTurquoise2
    PaleTurquoise3 PaleTurquoise4 CadetBlue1 CadetBlue2 CadetBlue3
    CadetBlue4 turquoise1 turquoise2 turquoise3 turquoise4 cyan2 cyan3
    cyan4 DarkSlateGray1 DarkSlateGray2 DarkSlateGray3 DarkSlateGray4
    aquamarine2 aquamarine4 DarkSeaGreen1 DarkSeaGreen2 DarkSeaGreen3
    DarkSeaGreen4 SeaGreen1 SeaGreen2 SeaGreen3 PaleGreen1 PaleGreen2
    PaleGreen3 PaleGreen4 SpringGreen2 SpringGreen3 SpringGreen4
    green2 green3 green4 chartreuse2 chartreuse3 chartreuse4
    OliveDrab1 OliveDrab2 OliveDrab4 DarkOliveGreen1 DarkOliveGreen2
    DarkOliveGreen3 DarkOliveGreen4 khaki1 khaki2 khaki3 khaki4
    LightGoldenrod1 LightGoldenrod2 LightGoldenrod3 LightGoldenrod4
    LightYellow2 LightYellow3 LightYellow4 yellow2 yellow3 yellow4
    gold2 gold3 gold4 goldenrod1 goldenrod2 goldenrod3 goldenrod4
    DarkGoldenrod1 DarkGoldenrod2 DarkGoldenrod3 DarkGoldenrod4
    RosyBrown1 RosyBrown2 RosyBrown3 RosyBrown4 IndianRed1 IndianRed2
    IndianRed3 IndianRed4 sienna1 sienna2 sienna3 sienna4 burlywood1
    burlywood2 burlywood3 burlywood4 wheat1 wheat2 wheat3 wheat4 tan1
    tan2 tan4 chocolate1 chocolate2 chocolate3 firebrick1 firebrick2
    firebrick3 firebrick4 brown1 brown2 brown3 brown4 salmon1 salmon2
    salmon3 salmon4 LightSalmon2 LightSalmon3 LightSalmon4 orange2
    orange3 orange4 DarkOrange1 DarkOrange2 DarkOrange3 DarkOrange4
    coral1 coral2 coral3 coral4 tomato2 tomato3 tomato4 OrangeRed2
    OrangeRed3 OrangeRed4 red2 red3 red4 DeepPink2 DeepPink3 DeepPink4
    HotPink1 HotPink2 HotPink3 HotPink4 pink1 pink2 pink3 pink4
    LightPink1 LightPink2 LightPink3 LightPink4 PaleVioletRed1
    PaleVioletRed2 PaleVioletRed3 PaleVioletRed4 maroon1 maroon2
    maroon3 maroon4 VioletRed1 VioletRed2 VioletRed3 VioletRed4
    magenta2 magenta3 magenta4 orchid1 orchid2 orchid3 orchid4 plum1
    plum2 plum3 plum4 MediumOrchid1 MediumOrchid2 MediumOrchid3
    MediumOrchid4 DarkOrchid1 DarkOrchid2 DarkOrchid3 DarkOrchid4
    purple1 purple2 purple3 purple4 MediumPurple1 MediumPurple2
    MediumPurple3 MediumPurple4 thistle1 thistle2 thistle3 thistle4
    gray1 gray2 gray3 gray4 gray5 gray6 gray7 gray8 gray9 gray10
    gray11 gray12 gray13 gray14 gray15 gray16 gray17 gray18 gray19
    gray20 gray21 gray22 gray23 gray24 gray25 gray26 gray27 gray28
    gray29 gray30 gray31 gray32 gray33 gray34 gray35 gray36 gray37
    gray38 gray39 gray40 gray42 gray43 gray44 gray45 gray46 gray47
    gray48 gray49 gray50 gray51 gray52 gray53 gray54 gray55 gray56
    gray57 gray58 gray59 gray60 gray61 gray62 gray63 gray64 gray65
    gray66 gray67 gray68 gray69 gray70 gray71 gray72 gray73 gray74
    gray75 gray76 gray77 gray78 gray79 gray80 gray81 gray82 gray83
    gray84 gray85 gray86 gray87 gray88 gray89 gray90 gray91 gray92
    gray93 gray94 gray95 gray97 gray98 gray99
}
set WINDOWSCOLORS {
    SystemButtonFace SystemButtonText SystemDisabledText SystemHighlight
    SystemHightlightText SystemMenu SystemMenuText SystemScrollbar
    SystemWindow SystemWindowFrame SystemWindowText
}

set S(w) 130
set S(h) 20
set S(wrap) -1

proc DrawColors {} {
    global S COLORS WINDOWSCOLORS
    array set fill {0 black 1 white}
 
    set cwidth [winfo width .c]
    set wrap [expr {($cwidth - 20) / $S(w)}]
    if {$wrap <= 0} {set wrap 1}
    if {$wrap == $S(wrap)} return               ;# No need to redraw
    set S(wrap) $wrap
 
    .c delete all
    set cnt 0
    foreach color [concat $COLORS $WINDOWSCOLORS] {
        regsub -all {\s+} $color " " color
        set n [catch {set rgb [winfo rgb . $color]}]
        if {$n} continue
 
        # Convert to HSV and get the V value to determine fill color
        # see [Selecting visually different RGB colors]
        set value [lindex [lsort -integer $rgb] end]
        set value [expr {$value / double(65535)}]
 
        set tag "i$cnt"
        set row [expr {$cnt / $wrap}]     ; set col [expr {$cnt % $wrap}]
        set x1 [expr {10 + $col * $S(w)}] ; set y1 [expr {10 + $row * $S(h)}]
        set x2 [expr {$x1 + $S(w)}]       ; set y2 [expr {$y1 + $S(h)}]
        set xc [expr {($x1 + $x2) / 2.0}] ; set yc [expr {($y1 + $y2) / 2.0}]
        .c create rect $x1 $y1 $x2 $y2 -fill $color -outline $color -tag $tag
        .c create text $xc $yc -text $color -tag [list txt $tag] \
            -fill $fill([expr {$value < .6}])
 
        set rgb2 [eval format "\#%04X%04X%04X" [winfo rgb . $color]]
        set rgb2 [::tk::Darken $color 100]
        regsub -all { } $rgb { / } rgb
        .c bind $tag <Enter> [list set S(msg) "$color => $rgb => $rgb2"]
        .c bind $tag <Double-Button-1> [list Clipit $color]
 
        incr cnt
    }
    .c config -scrollregion [concat 0 0 [lrange [.c bbox all] end-1 end]]
    .c raise txt
}
proc Clipit {txt} {
    clipboard clear
    clipboard append $txt
}
wm title . "Tk Named Colors"
canvas .c -width 670 -height 600 -yscrollcommand {.sby set} -highlightthick 0
scrollbar .sby -orient v -command {.c yview}
label .msg -textvariable S(msg) -relief sunken -bg white
image create photo ::img::blank -width 1 -height 1
button .about -image ::img::blank -highlightthickness 0 -command \
    {tk_messageBox -message "Tk Named Colors\nby Keith Vetter, March 2003"}
place .about -in .msg -relx 1 -rely 1 -anchor se

bind Canvas <Button-2>   [bind Text <Button-2>]
bind Canvas <B2-Motion>  [bind Text <B2-Motion>]
#bind Canvas <MouseWheel> [bind Text <MouseWheel>]
bind Canvas <MouseWheel> {%W yview scroll [expr {%D > 0 ? -2 : 2}] units}
bind .c <Alt-c>          [list console show]
focus .c

grid .c .sby -row 0 -sticky news
grid .msg -   -sticky ew
grid rowconfigure . 0 -weight 1
grid columnconfigure . 0 -weight 1
bind .c <Configure> DrawColors

return

Grandclosing - 2014-07-16 04:20:37:

This is a really great program and very useful - I use it as a reference when creating my own scripts! However there is an issue with the scrollbar keybinding. Whenever I use the mousewheel to scroll, I get the following error message:

bad argument "pixels": must be units or pages
bad argument "pixels": must be units or pages
    while executing
".c yview scroll [expr {(2--120)/3}] pixels"
    invoked from within
"if {-120 >= 0} {
            .c yview scroll [expr {--120/3}] pixels
        } else {
            .c yview scroll [expr {(2--120)/3}] pixels
        }"
    (command bound to event)

A fix for this would be really great.

MG: has put a different mousewheel binding in, which works for him on Win7.