mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-08 18:09:45 +01:00
Refactor text box contents to not use a separate length-tracker
This removes the variable numlines from each text box object, in favor of using line.size().
This commit is contained in:
parent
2ec1080b3d
commit
09c9a6b862
3 changed files with 14 additions and 27 deletions
|
@ -591,14 +591,14 @@ void Graphics::drawgui()
|
||||||
{
|
{
|
||||||
if(flipmode)
|
if(flipmode)
|
||||||
{
|
{
|
||||||
for (j = 0; j < textbox[i].numlines; j++)
|
for (j = 0; j < (int) textbox[i].line.size(); j++)
|
||||||
{
|
{
|
||||||
Print(textbox[i].xp + 8, textbox[i].yp + (textbox[i].numlines*8) - (j * 8), textbox[i].line[j], 196, 196, 255 - help.glow);
|
Print(textbox[i].xp + 8, textbox[i].yp + (textbox[i].line.size()*8) - (j * 8), textbox[i].line[j], 196, 196, 255 - help.glow);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (j = 0; j < textbox[i].numlines; j++)
|
for (j = 0; j < (int) textbox[i].line.size(); j++)
|
||||||
{
|
{
|
||||||
Print(textbox[i].xp + 8, textbox[i].yp + 8 + (j * 8), textbox[i].line[j], 196, 196, 255 - help.glow);
|
Print(textbox[i].xp + 8, textbox[i].yp + 8 + (j * 8), textbox[i].line[j], 196, 196, 255 - help.glow);
|
||||||
}
|
}
|
||||||
|
@ -618,7 +618,7 @@ void Graphics::drawgui()
|
||||||
drawcoloredtile(textbox[i].xp + 8 + (k * 8), textbox[i].yp, 41, textbox[i].r, textbox[i].g, textbox[i].b);
|
drawcoloredtile(textbox[i].xp + 8 + (k * 8), textbox[i].yp, 41, textbox[i].r, textbox[i].g, textbox[i].b);
|
||||||
drawcoloredtile(textbox[i].xp + 8 + (k * 8), textbox[i].yp+textbox[i].h-8, 46, textbox[i].r, textbox[i].g, textbox[i].b);
|
drawcoloredtile(textbox[i].xp + 8 + (k * 8), textbox[i].yp+textbox[i].h-8, 46, textbox[i].r, textbox[i].g, textbox[i].b);
|
||||||
}
|
}
|
||||||
for (int k = 0; k < textbox[i].numlines; k++)
|
for (size_t k = 0; k < textbox[i].line.size(); k++)
|
||||||
{
|
{
|
||||||
drawcoloredtile(textbox[i].xp, textbox[i].yp + 8 + (k * 8), 43, textbox[i].r, textbox[i].g, textbox[i].b);
|
drawcoloredtile(textbox[i].xp, textbox[i].yp + 8 + (k * 8), 43, textbox[i].r, textbox[i].g, textbox[i].b);
|
||||||
drawcoloredtile(textbox[i].xp + textbox[i].w-8, textbox[i].yp + 8 + (k * 8), 44, textbox[i].r, textbox[i].g, textbox[i].b);
|
drawcoloredtile(textbox[i].xp + textbox[i].w-8, textbox[i].yp + 8 + (k * 8), 44, textbox[i].r, textbox[i].g, textbox[i].b);
|
||||||
|
@ -626,14 +626,14 @@ void Graphics::drawgui()
|
||||||
|
|
||||||
if(flipmode)
|
if(flipmode)
|
||||||
{
|
{
|
||||||
for (j = 0; j < textbox[i].numlines; j++)
|
for (j = 0; j < (int) textbox[i].line.size(); j++)
|
||||||
{
|
{
|
||||||
Print(textbox[i].xp + 8, textbox[i].yp + (textbox[i].numlines*8) - (j * 8), textbox[i].line[j], textbox[i].r, textbox[i].g, textbox[i].b);
|
Print(textbox[i].xp + 8, textbox[i].yp + (textbox[i].line.size()*8) - (j * 8), textbox[i].line[j], textbox[i].r, textbox[i].g, textbox[i].b);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (j = 0; j < textbox[i].numlines; j++)
|
for (j = 0; j < (int) textbox[i].line.size(); j++)
|
||||||
{
|
{
|
||||||
Print(textbox[i].xp + 8, textbox[i].yp +8 + (j * 8), textbox[i].line[j], textbox[i].r, textbox[i].g, textbox[i].b);
|
Print(textbox[i].xp + 8, textbox[i].yp +8 + (j * 8), textbox[i].line[j], textbox[i].r, textbox[i].g, textbox[i].b);
|
||||||
}
|
}
|
||||||
|
@ -1008,8 +1008,7 @@ void Graphics::createtextbox( std::string t, int xp, int yp, int r/*= 255*/, int
|
||||||
if(m<20)
|
if(m<20)
|
||||||
{
|
{
|
||||||
textboxclass text;
|
textboxclass text;
|
||||||
text.clear();
|
text.line.push_back(t);
|
||||||
text.line[0] = t;
|
|
||||||
text.xp = xp;
|
text.xp = xp;
|
||||||
int length = utf8::unchecked::distance(t.begin(), t.end());
|
int length = utf8::unchecked::distance(t.begin(), t.end());
|
||||||
if (xp == -1) text.xp = 160 - (((length / 2) + 1) * 8);
|
if (xp == -1) text.xp = 160 - (((length / 2) + 1) * 8);
|
||||||
|
|
|
@ -9,17 +9,10 @@ textboxclass::textboxclass()
|
||||||
void textboxclass::firstcreate()
|
void textboxclass::firstcreate()
|
||||||
{
|
{
|
||||||
//Like clear, only it creates the actual arrays, etc
|
//Like clear, only it creates the actual arrays, etc
|
||||||
for (int iter = 0; iter < 10; iter++)
|
|
||||||
{
|
|
||||||
std::string t;
|
|
||||||
t = "";
|
|
||||||
line.push_back(t);
|
|
||||||
}
|
|
||||||
x = 0;
|
x = 0;
|
||||||
y = 0;
|
y = 0;
|
||||||
w = 0;
|
w = 0;
|
||||||
h = 0;
|
h = 0;
|
||||||
numlines = 0;
|
|
||||||
lw = 0;
|
lw = 0;
|
||||||
tl = 0;
|
tl = 0;
|
||||||
tm = 0;
|
tm = 0;
|
||||||
|
@ -29,15 +22,11 @@ void textboxclass::firstcreate()
|
||||||
void textboxclass::clear()
|
void textboxclass::clear()
|
||||||
{
|
{
|
||||||
//Set all values to a default, required for creating a new entity
|
//Set all values to a default, required for creating a new entity
|
||||||
for (size_t iter = 0; iter < line.size(); iter++)
|
line.resize(1);
|
||||||
{
|
|
||||||
line[iter]="";
|
|
||||||
}
|
|
||||||
xp = 0;
|
xp = 0;
|
||||||
yp = 0;
|
yp = 0;
|
||||||
w = 0;
|
w = 0;
|
||||||
h = 0;
|
h = 0;
|
||||||
numlines = 1;
|
|
||||||
lw = 0;
|
lw = 0;
|
||||||
tl = 0;
|
tl = 0;
|
||||||
tm = 0;
|
tm = 0;
|
||||||
|
@ -130,7 +119,7 @@ void textboxclass::resize()
|
||||||
{
|
{
|
||||||
//Set the width and height to the correct sizes
|
//Set the width and height to the correct sizes
|
||||||
max = 0;
|
max = 0;
|
||||||
for (int iter = 0; iter < numlines; iter++)
|
for (size_t iter = 0; iter < line.size(); iter++)
|
||||||
{
|
{
|
||||||
unsigned int len = utf8::unchecked::distance(line[iter].begin(), line[iter].end());
|
unsigned int len = utf8::unchecked::distance(line[iter].begin(), line[iter].end());
|
||||||
if (len > (unsigned int)max) max = len;
|
if (len > (unsigned int)max) max = len;
|
||||||
|
@ -138,7 +127,7 @@ void textboxclass::resize()
|
||||||
|
|
||||||
lw = max;
|
lw = max;
|
||||||
w = (max +2) * 8;
|
w = (max +2) * 8;
|
||||||
h = (numlines + 2) * 8;
|
h = (line.size() + 2) * 8;
|
||||||
textrect.x = xp;
|
textrect.x = xp;
|
||||||
textrect.y = yp;
|
textrect.y = yp;
|
||||||
textrect.w = w;
|
textrect.w = w;
|
||||||
|
@ -147,8 +136,7 @@ void textboxclass::resize()
|
||||||
|
|
||||||
void textboxclass::addline(std::string t)
|
void textboxclass::addline(std::string t)
|
||||||
{
|
{
|
||||||
line[numlines] = t;
|
line.push_back(t);
|
||||||
numlines++;
|
|
||||||
resize();
|
resize();
|
||||||
if (numlines >= 12) numlines = 0;
|
if ((int) line.size() >= 12) line.clear();
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,7 @@ public:
|
||||||
public:
|
public:
|
||||||
//Fundamentals
|
//Fundamentals
|
||||||
std::vector<std::string> line;
|
std::vector<std::string> line;
|
||||||
int xp, yp, lw, w, h, numlines;
|
int xp, yp, lw, w, h;
|
||||||
int x,y;
|
int x,y;
|
||||||
int r,g,b;
|
int r,g,b;
|
||||||
int tr,tg,tb;
|
int tr,tg,tb;
|
||||||
|
|
Loading…
Reference in a new issue