|
|
@ -547,6 +547,7 @@ CCtrlDraggable(param)
|
|
|
|
_RegenTextEnabled = true;
|
|
|
|
_RegenTextEnabled = true;
|
|
|
|
_RegenTextShadow = true;
|
|
|
|
_RegenTextShadow = true;
|
|
|
|
_RegenTextOutline = false;
|
|
|
|
_RegenTextOutline = false;
|
|
|
|
|
|
|
|
_RegenTextFctLua = false;
|
|
|
|
_RegenTextY = 2;
|
|
|
|
_RegenTextY = 2;
|
|
|
|
_RegenTextFontSize = 8;
|
|
|
|
_RegenTextFontSize = 8;
|
|
|
|
_RegenTextColor = NLMISC::CRGBA::White;
|
|
|
|
_RegenTextColor = NLMISC::CRGBA::White;
|
|
|
@ -672,6 +673,8 @@ bool CDBCtrlSheet::parse(xmlNodePtr cur, CInterfaceGroup * parentGroup)
|
|
|
|
XML_READ_COLOR(cur, "regen_text_color", _RegenTextColor, NLMISC::CRGBA::White);
|
|
|
|
XML_READ_COLOR(cur, "regen_text_color", _RegenTextColor, NLMISC::CRGBA::White);
|
|
|
|
XML_READ_COLOR(cur, "regen_text_shadow_color", _RegenTextShadowColor, NLMISC::CRGBA::Black);
|
|
|
|
XML_READ_COLOR(cur, "regen_text_shadow_color", _RegenTextShadowColor, NLMISC::CRGBA::Black);
|
|
|
|
XML_READ_COLOR(cur, "regen_text_outline_color", _RegenTextOutlineColor, NLMISC::CRGBA::Black);
|
|
|
|
XML_READ_COLOR(cur, "regen_text_outline_color", _RegenTextOutlineColor, NLMISC::CRGBA::Black);
|
|
|
|
|
|
|
|
XML_READ_STRING(cur, "regen_text_fct", _RegenTextFct, "");
|
|
|
|
|
|
|
|
_RegenTextFctLua = startsWith(_RegenTextFct, "lua:");
|
|
|
|
|
|
|
|
|
|
|
|
updateActualType();
|
|
|
|
updateActualType();
|
|
|
|
// Init size for Type
|
|
|
|
// Init size for Type
|
|
|
@ -2155,13 +2158,13 @@ void CDBCtrlSheet::drawRegenText()
|
|
|
|
_RegenText->setParent(_Parent);
|
|
|
|
_RegenText->setParent(_Parent);
|
|
|
|
_RegenText->setOverflowText(std::string());
|
|
|
|
_RegenText->setOverflowText(std::string());
|
|
|
|
_RegenText->setModulateGlobalColor(false);
|
|
|
|
_RegenText->setModulateGlobalColor(false);
|
|
|
|
_RegenText->setMultiLine(false);
|
|
|
|
_RegenText->setMultiLine(true);
|
|
|
|
_RegenText->setTextMode(CViewText::ClipWord);
|
|
|
|
_RegenText->setTextMode(CViewText::ClipWord);
|
|
|
|
_RegenText->setFontSize(_RegenTextFontSize);
|
|
|
|
_RegenText->setFontSize(_RegenTextFontSize);
|
|
|
|
_RegenText->setColor(_RegenTextColor);
|
|
|
|
_RegenText->setColor(_RegenTextColor);
|
|
|
|
// do not set shadow if outline is set to avoid clearing it on draw (would call invalidate)
|
|
|
|
// do not set shadow if outline is set to avoid clearing it on draw (would call invalidate)
|
|
|
|
_RegenText->setShadow(_RegenTextShadow && !_RegenTextOutline);
|
|
|
|
_RegenText->setShadow(_RegenTextShadow && !_RegenTextOutline);
|
|
|
|
_RegenText->setShadowOutline(false);//_RegenTextOutline);
|
|
|
|
_RegenText->setShadowOutline(false);
|
|
|
|
_RegenText->setShadowColor(_RegenTextShadowColor);
|
|
|
|
_RegenText->setShadowColor(_RegenTextShadowColor);
|
|
|
|
|
|
|
|
|
|
|
|
_RegenText->setActive(true);
|
|
|
|
_RegenText->setActive(true);
|
|
|
@ -2169,29 +2172,62 @@ void CDBCtrlSheet::drawRegenText()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// TODO: 10 hardcoded (ticks in second)
|
|
|
|
// TODO: 10 hardcoded (ticks in second)
|
|
|
|
uint32 nextValue = _RegenTickRange.EndTick > LastGameCycle ? (_RegenTickRange.EndTick - LastGameCycle) / 10 : 0;
|
|
|
|
sint32 nextValue;
|
|
|
|
|
|
|
|
if (_RegenTickRange.EndTick > LastGameCycle)
|
|
|
|
|
|
|
|
nextValue = (_RegenTickRange.EndTick - LastGameCycle) / 10;
|
|
|
|
|
|
|
|
else if (_RegenTextFctLua)
|
|
|
|
|
|
|
|
nextValue = ((sint64)_RegenTickRange.EndTick - (sint64)LastGameCycle) / 10;
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
nextValue = 0;
|
|
|
|
|
|
|
|
|
|
|
|
if (_RegenTextValue != nextValue)
|
|
|
|
if (_RegenTextValue != nextValue)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_RegenTextValue = nextValue;
|
|
|
|
_RegenTextValue = nextValue;
|
|
|
|
// format as "10m", "9'59", "59"
|
|
|
|
if (_RegenTextFct.empty())
|
|
|
|
if (_RegenTextValue > 600)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_RegenText->setText(toString("%dm", _RegenTextValue / 60));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (_RegenTextValue > 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (_RegenTextValue < 60)
|
|
|
|
// format as "10m", "9'59", "59"
|
|
|
|
_RegenText->setText(toString("%d", _RegenTextValue));
|
|
|
|
if (_RegenTextValue > 600)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_RegenText->setText(toString("%dm", _RegenTextValue / 60));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (_RegenTextValue > 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (_RegenTextValue < 60)
|
|
|
|
|
|
|
|
_RegenText->setText(toString("%d", _RegenTextValue));
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
_RegenText->setText(toString("%d'%02d", _RegenTextValue / 60, _RegenTextValue % 60));
|
|
|
|
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
_RegenText->setText(toString("%d'%02d", _RegenTextValue / 60, _RegenTextValue % 60));
|
|
|
|
{
|
|
|
|
|
|
|
|
_RegenText->setText(ucstring());
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_RegenText->setText(ucstring());
|
|
|
|
std::string fct;
|
|
|
|
|
|
|
|
if (_RegenTextFctLua)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
CCDBNodeBranch *root = getRootBranch();
|
|
|
|
|
|
|
|
if (root)
|
|
|
|
|
|
|
|
fct = toString("%s(%d, '%s')", _RegenTextFct.c_str(), _RegenTextValue, root->getFullName().c_str());
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
fct = toString("%s(%d, nil)", _RegenTextFct.c_str(), _RegenTextValue);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
fct = toString("%s(%d)", _RegenTextFct.c_str(), _RegenTextValue);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// if using color tags in format, then RegenText color should be set to CRGBA::White
|
|
|
|
|
|
|
|
// as tag color is modulated with main color
|
|
|
|
|
|
|
|
std::string result;
|
|
|
|
|
|
|
|
if (CInterfaceExpr::evalAsString(fct, result))
|
|
|
|
|
|
|
|
_RegenText->setTextFormatTaged(result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
_RegenText->updateTextContext();
|
|
|
|
_RegenText->updateTextContext();
|
|
|
|
// todo: posref
|
|
|
|
// todo: posref
|
|
|
|
|
|
|
|
// note: if x,y is moved outside icon area it might get cliped and not be visible (wreal/hreal == 0)
|
|
|
|
_RegenText->setX(_WReal / 2 -_RegenText->getMaxUsedW() / 2);
|
|
|
|
_RegenText->setX(_WReal / 2 -_RegenText->getMaxUsedW() / 2);
|
|
|
|
// move RegenTextY=0 to baseline
|
|
|
|
// move RegenTextY=0 to baseline
|
|
|
|
_RegenText->setY(_RegenTextY - _RegenText->getFontLegHeight());
|
|
|
|
_RegenText->setY(_RegenTextY - _RegenText->getFontLegHeight());
|
|
|
@ -4813,6 +4849,12 @@ std::string CDBCtrlSheet::getContextHelpWindowName() const
|
|
|
|
return CCtrlBase::getContextHelpWindowName();
|
|
|
|
return CCtrlBase::getContextHelpWindowName();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// ***************************************************************************
|
|
|
|
|
|
|
|
void CDBCtrlSheet::setRegenTextFct(const std::string &s)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_RegenTextFct = s;
|
|
|
|
|
|
|
|
_RegenTextFctLua = startsWith(s, "lua:");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ***************************************************************************
|
|
|
|
// ***************************************************************************
|
|
|
|
void CDBCtrlSheet::setRegenTickRange(const CTickRange &tickRange)
|
|
|
|
void CDBCtrlSheet::setRegenTickRange(const CTickRange &tickRange)
|
|
|
|