parent
3928a49d5e
commit
2e89eeed1a
@ -33,7 +33,7 @@ private:
|
|||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
virtual unsigned int getGlyphPageSize() const OVERRIDE { return 256; }
|
virtual unsigned int getGlyphPageSize() const OVERRIDE { return 256; }
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
virtual float getScalingFactorOne() const OVERRIDE { return 0.7f; }
|
virtual float getScalingFactorOne() const OVERRIDE { return 1.4f; }
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
virtual unsigned int getScalingFactorTwo() const OVERRIDE { return 40; }
|
virtual unsigned int getScalingFactorTwo() const OVERRIDE { return 40; }
|
||||||
|
|
||||||
@ -47,6 +47,8 @@ public:
|
|||||||
virtual void reset() OVERRIDE;
|
virtual void reset() OVERRIDE;
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
virtual bool disableTextShaping() const OVERRIDE { return true; }
|
virtual bool disableTextShaping() const OVERRIDE { return true; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
virtual float getNativeScalingFactor() const OVERRIDE { return 0.5f; }
|
||||||
}; // DigitFace
|
}; // DigitFace
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -498,11 +498,12 @@ core::dimension2d<u32> FontWithFace::getDimension(const core::stringw& text,
|
|||||||
if (GUIEngine::isNoGraphics())
|
if (GUIEngine::isNoGraphics())
|
||||||
return core::dimension2d<u32>(1, 1);
|
return core::dimension2d<u32>(1, 1);
|
||||||
|
|
||||||
const float scale = font_settings ? font_settings->getScale() : 1.0f;
|
const float scale = (font_settings ? font_settings->getScale() : 1.0f)
|
||||||
|
* getNativeScalingFactor();
|
||||||
if (disableTextShaping())
|
if (disableTextShaping())
|
||||||
{
|
{
|
||||||
return gui::getGlyphLayoutsDimension(text2GlyphsWithoutShaping(text),
|
return gui::getGlyphLayoutsDimension(text2GlyphsWithoutShaping(text),
|
||||||
m_font_max_height, 1.0f/*inverse shaping*/, scale);
|
m_font_max_height * scale, 1.0f/*inverse shaping*/, scale);
|
||||||
}
|
}
|
||||||
|
|
||||||
auto& gls = font_manager->getCachedLayouts(text);
|
auto& gls = font_manager->getCachedLayouts(text);
|
||||||
@ -525,7 +526,8 @@ int FontWithFace::getCharacterFromPos(const wchar_t* text, int pixel_x,
|
|||||||
FontSettings* font_settings) const
|
FontSettings* font_settings) const
|
||||||
{
|
{
|
||||||
#ifndef SERVER_ONLY
|
#ifndef SERVER_ONLY
|
||||||
const float scale = font_settings ? font_settings->getScale() : 1.0f;
|
const float scale = (font_settings ? font_settings->getScale() : 1.0f)
|
||||||
|
* getNativeScalingFactor();
|
||||||
float x = 0;
|
float x = 0;
|
||||||
int idx = 0;
|
int idx = 0;
|
||||||
|
|
||||||
@ -574,7 +576,8 @@ void FontWithFace::render(const std::vector<gui::GlyphLayout>& gl,
|
|||||||
font_settings->useBlackBorder() : false;
|
font_settings->useBlackBorder() : false;
|
||||||
const bool colored_border = font_settings ?
|
const bool colored_border = font_settings ?
|
||||||
font_settings->useColoredBorder() : false;
|
font_settings->useColoredBorder() : false;
|
||||||
const float scale = font_settings ? font_settings->getScale() : 1.0f;
|
const float scale = (font_settings ? font_settings->getScale() : 1.0f)
|
||||||
|
* getNativeScalingFactor();
|
||||||
const float shadow = font_settings ? font_settings->useShadow() : false;
|
const float shadow = font_settings ? font_settings->useShadow() : false;
|
||||||
|
|
||||||
if (shadow)
|
if (shadow)
|
||||||
|
@ -324,6 +324,10 @@ public:
|
|||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
virtual bool useColorGlyphPage() const { return false; }
|
virtual bool useColorGlyphPage() const { return false; }
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
|
/** Defined by sub-class about the native scaling factor, to provide */
|
||||||
|
/** a texture with higher resolution when the scale is > 1.0f */
|
||||||
|
virtual float getNativeScalingFactor() const { return 1.0f; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
void setDPI();
|
void setDPI();
|
||||||
}; // FontWithFace
|
}; // FontWithFace
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ STKTextBillboard::STKTextBillboard(const video::SColor& color_top,
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
float STKTextBillboard::getDefaultScale(FontWithFace* face)
|
float STKTextBillboard::getDefaultScale(FontWithFace* face)
|
||||||
{
|
{
|
||||||
return 1.0f / (float)face->getDPI();
|
return 1.0f / (float)face->getDPI() / face->getNativeScalingFactor();
|
||||||
} // getDefaultScale
|
} // getDefaultScale
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@ -150,7 +150,9 @@ IGUISpriteBank* ScalableFont::getSpriteBank() const
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
s32 ScalableFont::getHeightPerLine() const
|
s32 ScalableFont::getHeightPerLine() const
|
||||||
{
|
{
|
||||||
return m_face->getFontMaxHeight() * m_font_settings->getScale();
|
return m_face->getFontMaxHeight()
|
||||||
|
* m_face->getNativeScalingFactor()
|
||||||
|
* m_font_settings->getScale();
|
||||||
} // getHeightPerLine
|
} // getHeightPerLine
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
Loading…
Reference in New Issue
Block a user