mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-08 18:09:45 +01:00
Remove hardcoded textbox colours
We have a custom textbox colour system, why not use it? This also moves the map of colours from CustomLevels to Script.
This commit is contained in:
parent
c3e251fea9
commit
bd34af32de
5 changed files with 40 additions and 164 deletions
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
#include <SDL_stdinc.h>
|
#include <SDL_stdinc.h>
|
||||||
|
|
||||||
#include "CustomLevels.h"
|
#include "Script.h"
|
||||||
#include "Font.h"
|
#include "Font.h"
|
||||||
|
|
||||||
blockclass::blockclass(void)
|
blockclass::blockclass(void)
|
||||||
|
@ -48,80 +48,9 @@ void blockclass::rectset(const int xi, const int yi, const int wi, const int hi)
|
||||||
|
|
||||||
void blockclass::setblockcolour(const char* col)
|
void blockclass::setblockcolour(const char* col)
|
||||||
{
|
{
|
||||||
#ifndef NO_CUSTOM_LEVELS
|
bool exists = ::script.textbox_colours.count(col) != 0;
|
||||||
if (cl.customcolours.count(col) != 0)
|
|
||||||
{
|
r = ::script.textbox_colours[exists ? col : "gray"].r;
|
||||||
r = cl.customcolours[col].r;
|
g = ::script.textbox_colours[exists ? col : "gray"].g;
|
||||||
g = cl.customcolours[col].g;
|
b = ::script.textbox_colours[exists ? col : "gray"].b;
|
||||||
b = cl.customcolours[col].b;
|
|
||||||
}
|
|
||||||
else // Turn the if into an else if so we don't run the default colour processing
|
|
||||||
#endif
|
|
||||||
if (SDL_strcmp(col, "cyan") == 0)
|
|
||||||
{
|
|
||||||
r = 164;
|
|
||||||
g = 164;
|
|
||||||
b = 255;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "red") == 0)
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 60;
|
|
||||||
b = 60;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "green") == 0)
|
|
||||||
{
|
|
||||||
r = 144;
|
|
||||||
g = 255;
|
|
||||||
b = 144;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "yellow") == 0)
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 255;
|
|
||||||
b = 134;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "blue") == 0)
|
|
||||||
{
|
|
||||||
r = 95;
|
|
||||||
g = 95;
|
|
||||||
b = 255;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "purple") == 0)
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 134;
|
|
||||||
b = 255;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "white") == 0)
|
|
||||||
{
|
|
||||||
r = 244;
|
|
||||||
g = 244;
|
|
||||||
b = 244;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "gray") == 0)
|
|
||||||
{
|
|
||||||
r = 174;
|
|
||||||
g = 174;
|
|
||||||
b = 174;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "orange") == 0)
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 130;
|
|
||||||
b = 20;
|
|
||||||
}
|
|
||||||
else if (SDL_strcmp(col, "transparent") == 0)
|
|
||||||
{
|
|
||||||
r = 0;
|
|
||||||
g = 0;
|
|
||||||
b = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//use a gray
|
|
||||||
r = 174;
|
|
||||||
g = 174;
|
|
||||||
b = 174;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -387,7 +387,8 @@ void customlevelclass::reset(void)
|
||||||
|
|
||||||
onewaycol_override = false;
|
onewaycol_override = false;
|
||||||
|
|
||||||
customcolours.clear();
|
script.textbox_colours.clear();
|
||||||
|
script.add_default_colours();
|
||||||
map.specialroomnames.clear();
|
map.specialroomnames.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1309,7 +1310,7 @@ next:
|
||||||
colour.g = g;
|
colour.g = g;
|
||||||
colour.b = b;
|
colour.b = b;
|
||||||
|
|
||||||
customcolours[name] = colour;
|
script.textbox_colours[name] = colour;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -170,8 +170,6 @@ public:
|
||||||
SDL_Color getonewaycol(int rx, int ry);
|
SDL_Color getonewaycol(int rx, int ry);
|
||||||
SDL_Color getonewaycol(void);
|
SDL_Color getonewaycol(void);
|
||||||
bool onewaycol_override;
|
bool onewaycol_override;
|
||||||
|
|
||||||
std::map<std::string, SDL_Color> customcolours;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
std::string translate_title(const std::string& title, bool* is_gettext);
|
std::string translate_title(const std::string& title, bool* is_gettext);
|
||||||
|
|
|
@ -43,6 +43,8 @@ scriptclass::scriptclass(void)
|
||||||
r = 0;
|
r = 0;
|
||||||
textx = 0;
|
textx = 0;
|
||||||
texty = 0;
|
texty = 0;
|
||||||
|
textbox_colours.clear();
|
||||||
|
add_default_colours();
|
||||||
textflipme = false;
|
textflipme = false;
|
||||||
textcentertext = false;
|
textcentertext = false;
|
||||||
textpad_left = 0;
|
textpad_left = 0;
|
||||||
|
@ -53,6 +55,20 @@ scriptclass::scriptclass(void)
|
||||||
textlarge = false;
|
textlarge = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void scriptclass::add_default_colours(void)
|
||||||
|
{
|
||||||
|
textbox_colours["cyan"] = graphics.getRGB(164, 164, 255);
|
||||||
|
textbox_colours["red"] = graphics.getRGB(255, 60, 60);
|
||||||
|
textbox_colours["green"] = graphics.getRGB(144, 255, 144);
|
||||||
|
textbox_colours["yellow"] = graphics.getRGB(255, 255, 134);
|
||||||
|
textbox_colours["blue"] = graphics.getRGB(95, 95, 255);
|
||||||
|
textbox_colours["purple"] = graphics.getRGB(255, 134, 255);
|
||||||
|
textbox_colours["white"] = graphics.getRGB(244, 244, 244);
|
||||||
|
textbox_colours["gray"] = graphics.getRGB(174, 174, 174);
|
||||||
|
textbox_colours["orange"] = graphics.getRGB(255, 130, 20);
|
||||||
|
textbox_colours["transparent"] = graphics.getRGB(0, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
void scriptclass::clearcustom(void)
|
void scriptclass::clearcustom(void)
|
||||||
{
|
{
|
||||||
customscripts.clear();
|
customscripts.clear();
|
||||||
|
@ -452,91 +468,18 @@ void scriptclass::run(void)
|
||||||
}
|
}
|
||||||
else if (words[0] == "text")
|
else if (words[0] == "text")
|
||||||
{
|
{
|
||||||
//oh boy
|
// oh boy
|
||||||
//first word is the colour.
|
// first word is the colour.
|
||||||
#ifndef NO_CUSTOM_LEVELS
|
if (textbox_colours.count(words[1]) == 0)
|
||||||
if (cl.customcolours.count(words[1]) != 0)
|
|
||||||
{
|
{
|
||||||
r = cl.customcolours[words[1]].r;
|
// No colour named this, use gray
|
||||||
g = cl.customcolours[words[1]].g;
|
words[1] = "gray";
|
||||||
b = cl.customcolours[words[1]].b;
|
|
||||||
}
|
|
||||||
else // Turn the if into an else if so we don't run the default colour processing
|
|
||||||
#endif
|
|
||||||
if (words[1] == "cyan")
|
|
||||||
{
|
|
||||||
r = 164;
|
|
||||||
g = 164;
|
|
||||||
b = 255;
|
|
||||||
}
|
|
||||||
else if (words[1] == "player")
|
|
||||||
{
|
|
||||||
r = 164;
|
|
||||||
g = 164;
|
|
||||||
b = 255;
|
|
||||||
}
|
|
||||||
else if (words[1] == "red")
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 60;
|
|
||||||
b = 60;
|
|
||||||
}
|
|
||||||
else if (words[1] == "green")
|
|
||||||
{
|
|
||||||
r = 144;
|
|
||||||
g = 255;
|
|
||||||
b = 144;
|
|
||||||
}
|
|
||||||
else if (words[1] == "yellow")
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 255;
|
|
||||||
b = 134;
|
|
||||||
}
|
|
||||||
else if (words[1] == "blue")
|
|
||||||
{
|
|
||||||
r = 95;
|
|
||||||
g = 95;
|
|
||||||
b = 255;
|
|
||||||
}
|
|
||||||
else if (words[1] == "purple")
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 134;
|
|
||||||
b = 255;
|
|
||||||
}
|
|
||||||
else if (words[1] == "white")
|
|
||||||
{
|
|
||||||
r = 244;
|
|
||||||
g = 244;
|
|
||||||
b = 244;
|
|
||||||
}
|
|
||||||
else if (words[1] == "gray")
|
|
||||||
{
|
|
||||||
r = 174;
|
|
||||||
g = 174;
|
|
||||||
b = 174;
|
|
||||||
}
|
|
||||||
else if (words[1] == "orange")
|
|
||||||
{
|
|
||||||
r = 255;
|
|
||||||
g = 130;
|
|
||||||
b = 20;
|
|
||||||
}
|
|
||||||
else if (words[1] == "transparent")
|
|
||||||
{
|
|
||||||
r = 0;
|
|
||||||
g = 0;
|
|
||||||
b = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//use a gray
|
|
||||||
r = 174;
|
|
||||||
g = 174;
|
|
||||||
b = 174;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
r = textbox_colours[words[1]].r;
|
||||||
|
g = textbox_colours[words[1]].g;
|
||||||
|
b = textbox_colours[words[1]].b;
|
||||||
|
|
||||||
//next are the x,y coordinates
|
//next are the x,y coordinates
|
||||||
textx = ss_toi(words[2]);
|
textx = ss_toi(words[2]);
|
||||||
texty = ss_toi(words[3]);
|
texty = ss_toi(words[3]);
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#ifndef SCRIPT_H
|
#ifndef SCRIPT_H
|
||||||
#define SCRIPT_H
|
#define SCRIPT_H
|
||||||
|
|
||||||
|
#include <map>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
@ -8,6 +9,7 @@
|
||||||
|
|
||||||
#define filllines(lines) commands.insert(commands.end(), lines, lines + SDL_arraysize(lines))
|
#define filllines(lines) commands.insert(commands.end(), lines, lines + SDL_arraysize(lines))
|
||||||
|
|
||||||
|
#define TEXT_COLOUR(a) script.textbox_colours[a]
|
||||||
|
|
||||||
struct Script
|
struct Script
|
||||||
{
|
{
|
||||||
|
@ -76,6 +78,8 @@ public:
|
||||||
commands.push_back(t);
|
commands.push_back(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void add_default_colours(void);
|
||||||
|
|
||||||
void clearcustom(void);
|
void clearcustom(void);
|
||||||
|
|
||||||
void tokenize(const std::string& t);
|
void tokenize(const std::string& t);
|
||||||
|
@ -101,7 +105,8 @@ public:
|
||||||
int scriptdelay;
|
int scriptdelay;
|
||||||
bool running;
|
bool running;
|
||||||
|
|
||||||
//Textbox stuff
|
// Textbox stuff
|
||||||
|
std::map<std::string, SDL_Color> textbox_colours;
|
||||||
int textx;
|
int textx;
|
||||||
int texty;
|
int texty;
|
||||||
int r,g,b;
|
int r,g,b;
|
||||||
|
|
Loading…
Reference in a new issue