celestia/src/celutil/color.cpp

280 lines
18 KiB
C++

// color.cpp
//
// Copyright (C) 2001-2008, the Celestia Development Team
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
#include "color.h"
#include <celmath/mathlib.h>
using namespace std;
using namespace celmath;
Color::ColorMap Color::x11Colors;
const Color Color::White = Color(1.0f, 1.0f, 1.0f);
const Color Color::Black = Color(0.0f,0.0f, 0.0f);
Color::Color()
{
c[Red] = c[Green] = c[Blue] = 0;
c[Alpha] = 0xff;
}
Color::Color(float r, float g, float b)
{
c[Red] = (unsigned char) (clamp(r) * 255.99f);
c[Green] = (unsigned char) (clamp(g) * 255.99f);
c[Blue] = (unsigned char) (clamp(b) * 255.99f);
c[Alpha] = 0xff;
}
Color::Color(float r, float g, float b, float a)
{
c[Red] = (unsigned char) (clamp(r) * 255.99f);
c[Green] = (unsigned char) (clamp(g) * 255.99f);
c[Blue] = (unsigned char) (clamp(b) * 255.99f);
c[Alpha] = (unsigned char) (clamp(a) * 255.99f);
}
Color::Color(unsigned char r, unsigned char g, unsigned char b) :
Color(r, g, b, 0xff)
{
}
Color::Color(unsigned char r, unsigned char g, unsigned char b, unsigned char a)
{
c[Red] = r;
c[Green] = g;
c[Blue] = b;
c[Alpha] = a;
}
Color::Color(const Eigen::Vector3f &c) :
Color(c.x(), c.y(), c.z())
{
}
Color::Color(const Eigen::Vector4f &c) :
Color(c.x(), c.y(), c.z(), c.w())
{
}
Color::Color(const Color& color, float alpha)
{
*this = color;
c[Alpha] = (unsigned char) (clamp(alpha) * 255.99f);
}
/*! Parse a color string and return true if it was a valid color, otherwise
* false. Accetable inputs are HTML/X11 style #xxxxxx colors (where x is
* hexadecimal digit) or one of a list of named colors.
*/
bool Color::parse(const char* s, Color& c)
{
// Initialize the color dictionary if this is the first
// time Color::parse has been called.
if (x11Colors.empty())
{
buildX11ColorMap();
}
if (s[0] == '#')
{
s++;
int length = strlen(s);
// Verify that the string contains only hex digits
for (int i = 0; i < length; i++)
{
if (isxdigit(s[i]) == 0)
return false;
}
unsigned int n;
sscanf(s, "%x", &n);
switch(length)
{
case 3:
c = Color((unsigned char) ((n >> 8) * 17),
(unsigned char) (((n & 0x0f0) >> 4) * 17),
(unsigned char) ((n & 0x00f) * 17));
return true;
case 6:
c = Color((unsigned char) (n >> 16),
(unsigned char) ((n & 0x00ff00) >> 8),
(unsigned char) (n & 0x0000ff));
return true;
default:
return false;
}
}
else
{
if (x11Colors.find(s) != x11Colors.end())
{
c = x11Colors.find(s)->second;
return true;
}
return false;
}
}
// X11 Colors STL map
void Color::buildX11ColorMap()
{
x11Colors["aliceblue"] = Color((unsigned char)240, (unsigned char)248, (unsigned char)255);
x11Colors["antiquewhite"] = Color((unsigned char)250, (unsigned char)235, (unsigned char)215);
x11Colors["aqua"] = Color((unsigned char)0, (unsigned char)255, (unsigned char)255);
x11Colors["aquamarine"] = Color((unsigned char)127, (unsigned char)255, (unsigned char)212);
x11Colors["azure"] = Color((unsigned char)240, (unsigned char)255, (unsigned char)255);
x11Colors["beige"] = Color((unsigned char)245, (unsigned char)245, (unsigned char)220);
x11Colors["bisque"] = Color((unsigned char)255, (unsigned char)228, (unsigned char)196);
x11Colors["black"] = Color((unsigned char)0, (unsigned char)0, (unsigned char)0);
x11Colors["blanchedalmond"] = Color((unsigned char)255, (unsigned char)235, (unsigned char)205);
x11Colors["blue"] = Color((unsigned char)0, (unsigned char)0, (unsigned char)255);
x11Colors["blueviolet"] = Color((unsigned char)138, (unsigned char)43, (unsigned char)226);
x11Colors["brown"] = Color((unsigned char)165, (unsigned char)42, (unsigned char)42);
x11Colors["burlywood"] = Color((unsigned char)222, (unsigned char)184, (unsigned char)135);
x11Colors["cadetblue"] = Color((unsigned char)95, (unsigned char)158, (unsigned char)160);
x11Colors["chartreuse"] = Color((unsigned char)127, (unsigned char)255, (unsigned char)0);
x11Colors["chocolate"] = Color((unsigned char)210, (unsigned char)105, (unsigned char)30);
x11Colors["coral"] = Color((unsigned char)255, (unsigned char)127, (unsigned char)80);
x11Colors["cornflowerblue"] = Color((unsigned char)100, (unsigned char)149, (unsigned char)237);
x11Colors["cornsilk"] = Color((unsigned char)255, (unsigned char)248, (unsigned char)220);
x11Colors["crimson"] = Color((unsigned char)220, (unsigned char)20, (unsigned char)60);
x11Colors["cyan"] = Color((unsigned char)0, (unsigned char)255, (unsigned char)255);
x11Colors["darkblue"] = Color((unsigned char)0, (unsigned char)0, (unsigned char)139);
x11Colors["darkcyan"] = Color((unsigned char)0, (unsigned char)139, (unsigned char)139);
x11Colors["darkgoldenrod"] = Color((unsigned char)184, (unsigned char)134, (unsigned char)11);
x11Colors["darkgray"] = Color((unsigned char)169, (unsigned char)169, (unsigned char)169);
x11Colors["darkgreen"] = Color((unsigned char)0, (unsigned char)100, (unsigned char)0);
x11Colors["darkkhaki"] = Color((unsigned char)189, (unsigned char)183, (unsigned char)107);
x11Colors["darkmagenta"] = Color((unsigned char)139, (unsigned char)0, (unsigned char)139);
x11Colors["darkolivegreen"] = Color((unsigned char)85, (unsigned char)107, (unsigned char)47);
x11Colors["darkorange"] = Color((unsigned char)255, (unsigned char)140, (unsigned char)0);
x11Colors["darkorchid"] = Color((unsigned char)153, (unsigned char)50, (unsigned char)204);
x11Colors["darkred"] = Color((unsigned char)139, (unsigned char)0, (unsigned char)0);
x11Colors["darksalmon"] = Color((unsigned char)233, (unsigned char)150, (unsigned char)122);
x11Colors["darkseagreen"] = Color((unsigned char)143, (unsigned char)188, (unsigned char)143);
x11Colors["darkslateblue"] = Color((unsigned char)72, (unsigned char)61, (unsigned char)139);
x11Colors["darkslategray"] = Color((unsigned char)47, (unsigned char)79, (unsigned char)79);
x11Colors["darkturquoise"] = Color((unsigned char)0, (unsigned char)206, (unsigned char)209);
x11Colors["darkviolet"] = Color((unsigned char)148, (unsigned char)0, (unsigned char)211);
x11Colors["deeppink"] = Color((unsigned char)255, (unsigned char)20, (unsigned char)147);
x11Colors["deepskyblue"] = Color((unsigned char)0, (unsigned char)191, (unsigned char)255);
x11Colors["dimgray"] = Color((unsigned char)105, (unsigned char)105, (unsigned char)105);
x11Colors["dodgerblue"] = Color((unsigned char)30, (unsigned char)144, (unsigned char)255);
x11Colors["firebrick"] = Color((unsigned char)178, (unsigned char)34, (unsigned char)34);
x11Colors["floralwhite"] = Color((unsigned char)255, (unsigned char)250, (unsigned char)240);
x11Colors["forestgreen"] = Color((unsigned char)34, (unsigned char)139, (unsigned char)34);
x11Colors["fuchsia"] = Color((unsigned char)255, (unsigned char)0, (unsigned char)255);
x11Colors["gainsboro"] = Color((unsigned char)220, (unsigned char)220, (unsigned char)220);
x11Colors["ghostwhite"] = Color((unsigned char)248, (unsigned char)248, (unsigned char)255);
x11Colors["gold"] = Color((unsigned char)255, (unsigned char)215, (unsigned char)0);
x11Colors["goldenrod"] = Color((unsigned char)218, (unsigned char)165, (unsigned char)32);
x11Colors["gray"] = Color((unsigned char)128, (unsigned char)128, (unsigned char)128);
x11Colors["green"] = Color((unsigned char)0, (unsigned char)128, (unsigned char)0);
x11Colors["greenyellow"] = Color((unsigned char)173, (unsigned char)255, (unsigned char)47);
x11Colors["honeydew"] = Color((unsigned char)240, (unsigned char)255, (unsigned char)240);
x11Colors["hotpink"] = Color((unsigned char)255, (unsigned char)105, (unsigned char)180);
x11Colors["indianred"] = Color((unsigned char)205, (unsigned char)92, (unsigned char)92);
x11Colors["indigo"] = Color((unsigned char)75, (unsigned char)0, (unsigned char)130);
x11Colors["ivory"] = Color((unsigned char)255, (unsigned char)255, (unsigned char)240);
x11Colors["khaki"] = Color((unsigned char)240, (unsigned char)230, (unsigned char)140);
x11Colors["lavender"] = Color((unsigned char)230, (unsigned char)230, (unsigned char)250);
x11Colors["lavenderblush"] = Color((unsigned char)255, (unsigned char)240, (unsigned char)245 );
x11Colors["lawngreen"] = Color((unsigned char)124, (unsigned char)252, (unsigned char)0);
x11Colors["lemonchiffon"] = Color((unsigned char)255, (unsigned char)250, (unsigned char)205);
x11Colors["lightblue"] = Color((unsigned char)173, (unsigned char)216, (unsigned char)230);
x11Colors["lightcoral"] = Color((unsigned char)240, (unsigned char)128, (unsigned char)128);
x11Colors["lightcyan"] = Color((unsigned char)224, (unsigned char)255, (unsigned char)255);
x11Colors["lightgoldenrodyellow"] = Color((unsigned char)250, (unsigned char)250, (unsigned char)210);
x11Colors["lightgreen"] = Color((unsigned char)144, (unsigned char)238, (unsigned char)144);
x11Colors["lightgrey"] = Color((unsigned char)211, (unsigned char)211, (unsigned char)211);
x11Colors["lightpink"] = Color((unsigned char)255, (unsigned char)182, (unsigned char)193);
x11Colors["lightsalmon"] = Color((unsigned char)255, (unsigned char)160, (unsigned char)122);
x11Colors["lightseagreen"] = Color((unsigned char)32, (unsigned char)178, (unsigned char)170);
x11Colors["lightskyblue"] = Color((unsigned char)135, (unsigned char)206, (unsigned char)250);
x11Colors["lightslategray"] = Color((unsigned char)119, (unsigned char)136, (unsigned char)153);
x11Colors["lightsteelblue"] = Color((unsigned char)176, (unsigned char)196, (unsigned char)222);
x11Colors["lightyellow"] = Color((unsigned char)255, (unsigned char)255, (unsigned char)224);
x11Colors["lime"] = Color((unsigned char)0, (unsigned char)255, (unsigned char)0);
x11Colors["limegreen"] = Color((unsigned char)50, (unsigned char)205, (unsigned char)50);
x11Colors["linen"] = Color((unsigned char)250, (unsigned char)240, (unsigned char)230);
x11Colors["magenta"] = Color((unsigned char)255, (unsigned char)0, (unsigned char)255);
x11Colors["maroon"] = Color((unsigned char)128, (unsigned char)0, (unsigned char)0);
x11Colors["mediumaquamarine"] = Color((unsigned char)102, (unsigned char)205, (unsigned char)170);
x11Colors["mediumblue"] = Color((unsigned char)0, (unsigned char)0, (unsigned char)205);
x11Colors["mediumorchid"] = Color((unsigned char)186, (unsigned char)85, (unsigned char)211);
x11Colors["mediumpurple"] = Color((unsigned char)147, (unsigned char)112, (unsigned char)219);
x11Colors["mediumseagreen"] = Color((unsigned char)60, (unsigned char)179, (unsigned char)113);
x11Colors["mediumslateblue"] = Color((unsigned char)123, (unsigned char)104, (unsigned char)238);
x11Colors["mediumspringgreen"] = Color((unsigned char)0, (unsigned char)250, (unsigned char)154);
x11Colors["mediumturquoise"] = Color((unsigned char)72, (unsigned char)209, (unsigned char)204);
x11Colors["mediumvioletred"] = Color((unsigned char)199, (unsigned char)21, (unsigned char)133);
x11Colors["midnightblue"] = Color((unsigned char)25, (unsigned char)25, (unsigned char)112);
x11Colors["mintcream"] = Color((unsigned char)245, (unsigned char)255, (unsigned char)250);
x11Colors["mistyrose"] = Color((unsigned char)255, (unsigned char)228, (unsigned char)225);
x11Colors["moccasin"] = Color((unsigned char)255, (unsigned char)228, (unsigned char)181);
x11Colors["navajowhite"] = Color((unsigned char)255, (unsigned char)222, (unsigned char)173);
x11Colors["navy"] = Color((unsigned char)0, (unsigned char)0, (unsigned char)128);
x11Colors["oldlace"] = Color((unsigned char)253, (unsigned char)245, (unsigned char)230);
x11Colors["olive"] = Color((unsigned char)128, (unsigned char)128, (unsigned char)0);
x11Colors["olivedrab"] = Color((unsigned char)107, (unsigned char)142, (unsigned char)35);
x11Colors["orange"] = Color((unsigned char)255, (unsigned char)165, (unsigned char)0);
x11Colors["orangered"] = Color((unsigned char)255, (unsigned char)69, (unsigned char)0);
x11Colors["orchid"] = Color((unsigned char)218, (unsigned char)112, (unsigned char)214);
x11Colors["palegoldenrod"] = Color((unsigned char)238, (unsigned char)232, (unsigned char)170);
x11Colors["palegreen"] = Color((unsigned char)152, (unsigned char)251, (unsigned char)152);
x11Colors["paleturquoise"] = Color((unsigned char)175, (unsigned char)238, (unsigned char)238);
x11Colors["palevioletred"] = Color((unsigned char)219, (unsigned char)112, (unsigned char)147);
x11Colors["papayawhip"] = Color((unsigned char)255, (unsigned char)239, (unsigned char)213);
x11Colors["peachpuff"] = Color((unsigned char)255, (unsigned char)218, (unsigned char)185);
x11Colors["peru"] = Color((unsigned char)205, (unsigned char)133, (unsigned char)63);
x11Colors["pink"] = Color((unsigned char)255, (unsigned char)192, (unsigned char)203);
x11Colors["plum"] = Color((unsigned char)221, (unsigned char)160, (unsigned char)221);
x11Colors["powderblue"] = Color((unsigned char)176, (unsigned char)224, (unsigned char)230);
x11Colors["purple"] = Color((unsigned char)128, (unsigned char)0, (unsigned char)128);
x11Colors["red"] = Color((unsigned char)255, (unsigned char)0, (unsigned char)0);
x11Colors["rosybrown"] = Color((unsigned char)188, (unsigned char)143, (unsigned char)143);
x11Colors["royalblue"] = Color((unsigned char)65, (unsigned char)105, (unsigned char)225);
x11Colors["saddlebrown"] = Color((unsigned char)139, (unsigned char)69, (unsigned char)19);
x11Colors["salmon"] = Color((unsigned char)250, (unsigned char)128, (unsigned char)114);
x11Colors["sandybrown"] = Color((unsigned char)244, (unsigned char)164, (unsigned char)96);
x11Colors["seagreen"] = Color((unsigned char)46, (unsigned char)139, (unsigned char)87);
x11Colors["seashell"] = Color((unsigned char)255, (unsigned char)245, (unsigned char)238);
x11Colors["sienna"] = Color((unsigned char)160, (unsigned char)82, (unsigned char)45);
x11Colors["silver"] = Color((unsigned char)192, (unsigned char)192, (unsigned char)192);
x11Colors["skyblue"] = Color((unsigned char)135, (unsigned char)206, (unsigned char)235);
x11Colors["slateblue"] = Color((unsigned char)106, (unsigned char)90, (unsigned char)205);
x11Colors["slategray"] = Color((unsigned char)112, (unsigned char)128, (unsigned char)144);
x11Colors["snow"] = Color((unsigned char)255, (unsigned char)250, (unsigned char)250);
x11Colors["springgreen"] = Color((unsigned char)0, (unsigned char)255, (unsigned char)127);
x11Colors["steelblue"] = Color((unsigned char)70, (unsigned char)130, (unsigned char)180);
x11Colors["tan"] = Color((unsigned char)210, (unsigned char)180, (unsigned char)140);
x11Colors["teal"] = Color((unsigned char)0, (unsigned char)128, (unsigned char)128);
x11Colors["thistle"] = Color((unsigned char)216, (unsigned char)191, (unsigned char)216);
x11Colors["tomato"] = Color((unsigned char)255, (unsigned char)99, (unsigned char)71);
x11Colors["turquoise"] = Color((unsigned char)64, (unsigned char)224, (unsigned char)208);
x11Colors["violet"] = Color((unsigned char)238, (unsigned char)130, (unsigned char)238);
x11Colors["wheat"] = Color((unsigned char)245, (unsigned char)222, (unsigned char)179);
x11Colors["white"] = Color((unsigned char)255, (unsigned char)255, (unsigned char)255);
x11Colors["whitesmoke"] = Color((unsigned char)245, (unsigned char)245, (unsigned char)245);
x11Colors["yellow"] = Color((unsigned char)255, (unsigned char)255, (unsigned char)0);
x11Colors["yellowgreen"] = Color((unsigned char)154, (unsigned char)205, (unsigned char)50);
}