|
|
@ -25,11 +25,52 @@
|
|
|
|
#include <components/misc/strings/algorithm.hpp>
|
|
|
|
#include <components/misc/strings/algorithm.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
#include <components/myguiplatform/myguitexture.hpp>
|
|
|
|
#include <components/myguiplatform/myguitexture.hpp>
|
|
|
|
|
|
|
|
#include <components/myguiplatform/scalinglayer.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
#include <components/settings/settings.hpp>
|
|
|
|
#include <components/settings/settings.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
namespace
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
MyGUI::xml::ElementPtr getProperty(MyGUI::xml::ElementPtr resourceNode, const std::string propertyName)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
MyGUI::xml::ElementPtr propertyNode = nullptr;
|
|
|
|
|
|
|
|
MyGUI::xml::ElementEnumerator propertyIterator = resourceNode->getElementEnumerator();
|
|
|
|
|
|
|
|
while (propertyIterator.next("Property"))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::string key = propertyIterator->findAttribute("key");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (key == propertyName)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
propertyNode = propertyIterator.current();
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return propertyNode;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
MyGUI::IntSize getBookSize(MyGUI::IDataStream* layersStream)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
MyGUI::xml::Document xmlDocument;
|
|
|
|
|
|
|
|
xmlDocument.open(layersStream);
|
|
|
|
|
|
|
|
MyGUI::xml::ElementPtr root = xmlDocument.getRoot();
|
|
|
|
|
|
|
|
MyGUI::xml::ElementEnumerator layersIterator = root->getElementEnumerator();
|
|
|
|
|
|
|
|
while (layersIterator.next("Layer"))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::string name = layersIterator->findAttribute("name");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (name == "JournalBooks")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
MyGUI::xml::ElementPtr sizeProperty = getProperty(layersIterator.current(), "Size");
|
|
|
|
|
|
|
|
const std::string& sizeValue = sizeProperty != nullptr ? sizeProperty->findAttribute("value") : std::string();
|
|
|
|
|
|
|
|
if (!sizeValue.empty())
|
|
|
|
|
|
|
|
return MyGUI::IntSize::parse(sizeValue);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return MyGUI::RenderManager::getInstance().getViewSize();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
unsigned long utf8ToUnicode(std::string_view utf8)
|
|
|
|
unsigned long utf8ToUnicode(std::string_view utf8)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (utf8.empty())
|
|
|
|
if (utf8.empty())
|
|
|
@ -165,6 +206,8 @@ namespace Gui
|
|
|
|
|
|
|
|
|
|
|
|
MyGUI::ResourceManager::getInstance().unregisterLoadXmlDelegate("Resource");
|
|
|
|
MyGUI::ResourceManager::getInstance().unregisterLoadXmlDelegate("Resource");
|
|
|
|
MyGUI::ResourceManager::getInstance().registerLoadXmlDelegate("Resource") = MyGUI::newDelegate(this, &FontLoader::overrideLineHeight);
|
|
|
|
MyGUI::ResourceManager::getInstance().registerLoadXmlDelegate("Resource") = MyGUI::newDelegate(this, &FontLoader::overrideLineHeight);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
loadFonts();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void FontLoader::loadFonts()
|
|
|
|
void FontLoader::loadFonts()
|
|
|
@ -203,6 +246,11 @@ namespace Gui
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TODO: it may be worth to take in account resolution change, but it is not safe to replace used assets
|
|
|
|
|
|
|
|
std::unique_ptr<MyGUI::IDataStream> layersStream(dataManager->getData("openmw_layers.xml"));
|
|
|
|
|
|
|
|
MyGUI::IntSize bookSize = getBookSize(layersStream.get());
|
|
|
|
|
|
|
|
float bookScale = osgMyGUI::ScalingLayer::getScaleFactor(bookSize);
|
|
|
|
|
|
|
|
|
|
|
|
std::string oldDataPath = dataManager->getDataPath("");
|
|
|
|
std::string oldDataPath = dataManager->getDataPath("");
|
|
|
|
dataManager->setResourcePath("fonts");
|
|
|
|
dataManager->setResourcePath("fonts");
|
|
|
|
std::unique_ptr<MyGUI::IDataStream> dataStream(dataManager->getData(fileName));
|
|
|
|
std::unique_ptr<MyGUI::IDataStream> dataStream(dataManager->getData(fileName));
|
|
|
@ -226,15 +274,17 @@ namespace Gui
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// For TrueType fonts we should override Size and Resolution properties
|
|
|
|
int resolution = 70;
|
|
|
|
// to allow to configure font size via config file, without need to edit XML files.
|
|
|
|
MyGUI::xml::ElementPtr resolutionNode = getProperty(resourceNode.current(), "Resolution");
|
|
|
|
// Also we should take UI scaling factor in account.
|
|
|
|
if (resolutionNode == nullptr)
|
|
|
|
int resolution = Settings::Manager::getInt("ttf resolution", "GUI");
|
|
|
|
{
|
|
|
|
resolution = std::clamp(resolution, 50, 125) * mScalingFactor;
|
|
|
|
resolutionNode = resourceNode->createChild("Property");
|
|
|
|
|
|
|
|
|
|
|
|
MyGUI::xml::ElementPtr resolutionNode = resourceNode->createChild("Property");
|
|
|
|
|
|
|
|
resolutionNode->addAttribute("key", "Resolution");
|
|
|
|
resolutionNode->addAttribute("key", "Resolution");
|
|
|
|
resolutionNode->addAttribute("value", std::to_string(resolution));
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
resolution = MyGUI::utility::parseInt(resolutionNode->findAttribute("value"));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
resolutionNode->setAttribute("value", MyGUI::utility::toString(resolution * std::ceil(mScalingFactor)));
|
|
|
|
|
|
|
|
|
|
|
|
MyGUI::xml::ElementPtr sizeNode = resourceNode->createChild("Property");
|
|
|
|
MyGUI::xml::ElementPtr sizeNode = resourceNode->createChild("Property");
|
|
|
|
sizeNode->addAttribute("key", "Size");
|
|
|
|
sizeNode->addAttribute("key", "Size");
|
|
|
@ -246,16 +296,7 @@ namespace Gui
|
|
|
|
font->setResourceName(fontId);
|
|
|
|
font->setResourceName(fontId);
|
|
|
|
MyGUI::ResourceManager::getInstance().addResource(font);
|
|
|
|
MyGUI::ResourceManager::getInstance().addResource(font);
|
|
|
|
|
|
|
|
|
|
|
|
float currentX = Settings::Manager::getInt("resolution x", "Video");
|
|
|
|
resolutionNode->setAttribute("value", MyGUI::utility::toString(static_cast<int>(resolution * bookScale * mScalingFactor)));
|
|
|
|
float currentY = Settings::Manager::getInt("resolution y", "Video");
|
|
|
|
|
|
|
|
// TODO: read size from openmw_layout.xml somehow
|
|
|
|
|
|
|
|
// TODO: it may be worth to take in account resolution change, but it is not safe to replace used assets
|
|
|
|
|
|
|
|
float heightScale = (currentY / 520);
|
|
|
|
|
|
|
|
float widthScale = (currentX / 600);
|
|
|
|
|
|
|
|
float uiScale = std::min(widthScale, heightScale);
|
|
|
|
|
|
|
|
resolution = Settings::Manager::getInt("ttf resolution", "GUI");
|
|
|
|
|
|
|
|
resolution = std::clamp(resolution, 50, 125) * uiScale;
|
|
|
|
|
|
|
|
resolutionNode->setAttribute("value", std::to_string(resolution));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
MyGUI::ResourceTrueTypeFont* bookFont = static_cast<MyGUI::ResourceTrueTypeFont*>(
|
|
|
|
MyGUI::ResourceTrueTypeFont* bookFont = static_cast<MyGUI::ResourceTrueTypeFont*>(
|
|
|
|
MyGUI::FactoryManager::getInstance().createObject("Resource", "ResourceTrueTypeFont"));
|
|
|
|
MyGUI::FactoryManager::getInstance().createObject("Resource", "ResourceTrueTypeFont"));
|
|
|
|