1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-07 12:54:00 +00:00

Fix Lua UI atlasing

This commit is contained in:
uramer 2023-10-26 20:46:34 +02:00
parent 8380da2e1d
commit f9888230af

View File

@ -8,9 +8,7 @@ namespace LuaUi
{ {
void LuaTileRect::_setAlign(const MyGUI::IntSize& _oldsize) void LuaTileRect::_setAlign(const MyGUI::IntSize& _oldsize)
{ {
mCurrentCoord.set(0, 0, mCroppedParent->getWidth(), mCroppedParent->getHeight()); mCoord.set(0, 0, mCroppedParent->getWidth(), mCroppedParent->getHeight());
mAlign = MyGUI::Align::Stretch;
MyGUI::TileRect::_setAlign(_oldsize);
mTileSize = mSetTileSize; mTileSize = mSetTileSize;
// zero tilesize stands for not tiling // zero tilesize stands for not tiling
@ -25,6 +23,8 @@ namespace LuaUi
mTileSize.width = 1e7; mTileSize.width = 1e7;
if (mTileSize.height <= 0) if (mTileSize.height <= 0)
mTileSize.height = 1e7; mTileSize.height = 1e7;
MyGUI::TileRect::_updateView();
} }
void LuaImage::initialize() void LuaImage::initialize()
@ -55,13 +55,13 @@ namespace LuaUi
if (texture != nullptr) if (texture != nullptr)
textureSize = MyGUI::IntSize(texture->getWidth(), texture->getHeight()); textureSize = MyGUI::IntSize(texture->getWidth(), texture->getHeight());
mTileRect->updateSize(MyGUI::IntSize(tileH ? textureSize.width : 0, tileV ? textureSize.height : 0));
setImageTile(textureSize);
if (atlasCoord.width == 0) if (atlasCoord.width == 0)
atlasCoord.width = textureSize.width; atlasCoord.width = textureSize.width;
if (atlasCoord.height == 0) if (atlasCoord.height == 0)
atlasCoord.height = textureSize.height; atlasCoord.height = textureSize.height;
mTileRect->updateSize(MyGUI::IntSize(tileH ? atlasCoord.width : 0, tileV ? atlasCoord.height : 0));
setImageTile(atlasCoord.size());
setImageCoord(atlasCoord); setImageCoord(atlasCoord);
setColour(propertyValue("color", MyGUI::Colour(1, 1, 1, 1))); setColour(propertyValue("color", MyGUI::Colour(1, 1, 1, 1)));