Changed: Set background image from html or body

--HG--
branch : develop
This commit is contained in:
Nimetu 2019-05-03 08:59:19 +03:00
parent 9f9c5d4106
commit 4f4ba7120d
2 changed files with 59 additions and 35 deletions

View file

@ -816,6 +816,9 @@ namespace NLGUI
// :before, :after rendering // :before, :after rendering
void renderPseudoElement(const std::string &pseudo, const CHtmlElement &elm); void renderPseudoElement(const std::string &pseudo, const CHtmlElement &elm);
// apply background from current style (for html, body)
void applyBackground(const CHtmlElement &elm);
// HTML elements // HTML elements
void htmlA(const CHtmlElement &elm); void htmlA(const CHtmlElement &elm);
void htmlAend(const CHtmlElement &elm); void htmlAend(const CHtmlElement &elm);

View file

@ -3379,6 +3379,13 @@ namespace NLGUI
bitmap->setRenderLayer(-2); bitmap->setRenderLayer(-2);
bitmap->setScale(scale); bitmap->setScale(scale);
bitmap->setTile(tile); bitmap->setTile(tile);
// clear size ref for non-scaled image or it does not show up
if (scale || tile)
bitmap->setSizeRef("wh");
else
bitmap->setSizeRef("");
addImageDownload(bgtex, view); addImageDownload(bgtex, view);
} }
} }
@ -5015,6 +5022,52 @@ namespace NLGUI
_CellParams.push_back (cellParams); _CellParams.push_back (cellParams);
} }
// ***************************************************************************
void CGroupHTML::applyBackground(const CHtmlElement &elm)
{
bool root = elm.Value == "html" || elm.Value == "body";
// non-empty image
if (_Style.hasStyle("background-image"))
{
// value '1' and 'background-scale' are ryzom only
bool repeat = _Style.checkStyle("background-repeat", "1") || _Style.checkStyle("background-repeat", "repeat");
bool scale = _Style.checkStyle("background-scale", "1") || _Style.checkStyle("background-size", "100% 100%");
std::string image = trim(_Style.getStyle("background-image"));
string::size_type texExt = toLower(image).find("url(");
if (texExt != string::npos)
{
image = image.substr(texExt+4, image.size()-texExt-5);
}
if (!image.empty())
{
if (root)
{
setBackground (image, scale, repeat);
}
// TODO: else
// default background color is transparent, so image does not show
if (!_Style.hasStyle("background-color"))
{
_Style.applyStyle("background-color: #fff;");
}
}
}
if (_Style.hasStyle("background-color"))
{
CRGBA bgColor = _Style.Current.BackgroundColor;
scanHTMLColor(elm.getAttribute("bgcolor").c_str(), bgColor);
if (root)
{
setBackgroundColor(bgColor);
}
// TODO: else
}
}
// *************************************************************************** // ***************************************************************************
void CGroupHTML::htmlA(const CHtmlElement &elm) void CGroupHTML::htmlA(const CHtmlElement &elm)
{ {
@ -5084,39 +5137,7 @@ namespace NLGUI
_Style.applyStyle("background-color: " + elm.getAttribute("bgcolor")); _Style.applyStyle("background-color: " + elm.getAttribute("bgcolor"));
} }
if (_Style.hasStyle("background-color")) applyBackground(elm);
{
CRGBA bgColor = _Style.Current.BackgroundColor;
scanHTMLColor(elm.getAttribute("bgcolor").c_str(), bgColor);
setBackgroundColor(bgColor);
}
if (elm.hasNonEmptyAttribute("style"))
{
string style = elm.getAttribute("style");
TStyle styles = parseStyle(style);
TStyle::iterator it;
it = styles.find("background-repeat");
bool repeat = (it != styles.end() && it->second == "1");
// Webig only
it = styles.find("background-scale");
bool scale = (it != styles.end() && it->second == "1");
it = styles.find("background-image");
if (it != styles.end())
{
string image = it->second;
string::size_type texExt = toLower(image).find("url(");
// Url image
if (texExt != string::npos)
// Remove url()
image = image.substr(4, image.size()-5);
setBackground (image, scale, repeat);
}
}
renderPseudoElement(":before", elm); renderPseudoElement(":before", elm);
} }
@ -5468,7 +5489,7 @@ namespace NLGUI
_Style.applyRootStyle(elm.getAttribute("style")); _Style.applyRootStyle(elm.getAttribute("style"));
_Style.Current = _Style.Root; _Style.Current = _Style.Root;
} }
setBackgroundColor(_Style.Current.BackgroundColor); applyBackground(elm);
} }
// *************************************************************************** // ***************************************************************************
@ -6278,7 +6299,7 @@ namespace NLGUI
if (_Style.checkStyle("background-repeat", "1") || _Style.checkStyle("background-repeat", "repeat")) if (_Style.checkStyle("background-repeat", "1") || _Style.checkStyle("background-repeat", "repeat"))
_Cells.back()->setTextureTile(true); _Cells.back()->setTextureTile(true);
if (_Style.checkStyle("background-scale", "1") || _Style.checkStyle("background-size", "cover")) if (_Style.checkStyle("background-scale", "1") || _Style.checkStyle("background-size", "100% 100%"))
_Cells.back()->setTextureScale(true); _Cells.back()->setTextureScale(true);
if (_Style.hasStyle("background-image")) if (_Style.hasStyle("background-image"))