我有一个辅助函数,它接受一个字符串和一个颜色矢量用于格式化字符串,现在我的解决方案是手动检查颜色矢量的大小并调用控制台打印颜色数量。
假设我的颜色向量为4,在代码中它会执行以下操作:
void helper_func(TCODConsole* con, std::string msg_str, std::vector<TCOD_colctrl_t> color_vector)
{
char* message = msg_str.c_str();
//this is repeated 1 through 16, adding another color_vector.at(n) for each.
...
else if (color_vector.size() == 2)
//message might be "%cHello%c was in red"
console->print(x, y, message, color_vector.at(0), color_vector.at(1))
...
else if (color_vector.size() == 4)
//message might be "%cThe octopus%c shimmers at %cnight%c"
console->print(x, y, message, color_vector.at(0), color_vector.at(1), color_vector.at(2), color_vector.at(3))
...
}
虽然这很有效,但它很糟糕,我正在研究不同的方式将它拉下来,允许超过16种颜色等。
我尝试为矢量中的每种颜色执行sprintf
,将其添加到out_string并重复。我试过用ostringstream做同样的事情。我尝试在"%c"
上拆分msg_str,然后在我为每个字符添加颜色后加入生成的字符串。它从来没有用过,总是要么使用第一种颜色,然后使用随机字符而不是那里的颜色。
我希望以上任何一种都能正常工作,因为只需sprintf(out_char, format_msg, TCOD_COLCTRL_1)
打印到控制台(使用console->print(out_char)
)就好了。
我的问题是:是否有一种很好的方法可以将不同数量的颜色传递到控制台&gt;打印功能并准确显示这些颜色,而不会出现严重的代码冗余?
作为后备,我可以将字符串的一部分打印到第一种颜色,计算其大小,将x
移动到那么多并打印下一部分,但这并不理想。
我认为这个问题可以概括为对常规printf
提出替换同样的问题。
答案 0 :(得分:2)
可变函数的一种可能替代方案可能涉及为&#34;%c&#34;解析msg_str。并根据color_vector以正确的颜色迭代打印字符串的每个片段。我不确定下面的代码是否会编译 - 我在记事本中写了它,所以它可能需要一些工作。希望你能得到我所建议的要点。
void helper_func(TCODConsole* con, std::string msg_str, std::vector<TCOD_colctrl_t> color_vector)
{
std::string str2;
std::size_t pos;
std::size_t pos2;
pos = msg_str.find("%c");
if (pos != std::string::npos)
str2 = msg_str.substr(0,pos);
else
str2 = msg_str;
console->print(x, y, str2.c_str());
int n = 0;
while (pos != std::string::npos) {
pos2 = msg_str.find("%c",pos+1);
if (pos2 != std::string::npos)
str2 = msg_str.substr(pos+2,pos2);
else
str2 = msg_str.substr(pos2+2,msg_str.length()-pos2+2);
console->print(x, y, str2.c_str(),color_vector.at(n));
pos = pos2;
n++;
}
}
我想我应该提一下,我的代码中存在问题。每次通过while循环时,需要计算第二个print语句中的 x 值,因为 x 会根据 pos2 进行更改。否则,一切都会在同一地点继续打印。 :)应该是一个简单的改变......