forked from organicmaps/organicmaps
font parameters are taken out of all text functions into separate FontDesc structure.
This commit is contained in:
parent
a16922f909
commit
37ced5a920
14 changed files with 465 additions and 254 deletions
|
@ -234,37 +234,35 @@ void DrawerYG::drawText(m2::PointD const & pt, string const & name, rule_ptr_t p
|
|||
if (textColor == yg::Color(255, 255, 255, 255))
|
||||
textColor = yg::Color(0, 0, 0, 0);
|
||||
|
||||
// bool isMasked = pRule->GetColor() != -1;
|
||||
bool isMasked = true;
|
||||
yg::FontDesc fontDesc(false, get_text_font_size(pRule), textColor, isMasked, yg::Color(255, 255, 255, 255));
|
||||
|
||||
if (!filter_text_size(pRule))
|
||||
m_pScreen->drawText(
|
||||
pt,
|
||||
pos,
|
||||
0.0,
|
||||
get_text_font_size(pRule),
|
||||
textColor,
|
||||
name,
|
||||
pRule->GetColor() != -1,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
depth,
|
||||
false,
|
||||
true);
|
||||
fontDesc,
|
||||
pt,
|
||||
pos,
|
||||
0.0,
|
||||
name,
|
||||
depth,
|
||||
true);
|
||||
}
|
||||
|
||||
bool DrawerYG::drawPathText(di::PathInfo const & info, string const & name, uint8_t fontSize, int /*depth*/)
|
||||
{
|
||||
// bool const isMasked = (double(fontSize) / m_visualScale >= min_text_height);
|
||||
|
||||
return m_pScreen->drawPathText( &info.m_path[0],
|
||||
yg::FontDesc fontDesc(false, fontSize);
|
||||
|
||||
return m_pScreen->drawPathText( fontDesc,
|
||||
&info.m_path[0],
|
||||
info.m_path.size(),
|
||||
fontSize,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
name,
|
||||
info.GetLength(),
|
||||
info.GetOffset(),
|
||||
yg::gl::Screen::middle_line,
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
false);
|
||||
yg::maxDepth);
|
||||
}
|
||||
|
||||
shared_ptr<yg::gl::Screen> DrawerYG::screen() const
|
||||
|
@ -294,11 +292,11 @@ void DrawerYG::Draw(di::DrawInfo const * pInfo, di::DrawRule const * rules, size
|
|||
string symbol;
|
||||
pRule->GetSymbol(symbol);
|
||||
|
||||
bool const isSymbol = !symbol.empty();
|
||||
bool const hasSymbol = !symbol.empty();
|
||||
bool const isCaption = pRule->GetTextHeight() >= 0.0;
|
||||
bool const isPath = !pInfo->m_pathes.empty();
|
||||
|
||||
if (!isCaption && isPath && !isSymbol && (pRule->GetColor() != -1))
|
||||
if (!isCaption && isPath && !hasSymbol && (pRule->GetColor() != -1))
|
||||
pathRules.push_back(rules[i]);
|
||||
}
|
||||
|
||||
|
@ -317,11 +315,11 @@ void DrawerYG::Draw(di::DrawInfo const * pInfo, di::DrawRule const * rules, size
|
|||
|
||||
string symbol;
|
||||
pRule->GetSymbol(symbol);
|
||||
bool const isSymbol = !symbol.empty();
|
||||
bool const hasSymbol = !symbol.empty();
|
||||
|
||||
bool const isPath = !pInfo->m_pathes.empty();
|
||||
bool const isArea = !pInfo->m_areas.empty();
|
||||
bool const isName = !pInfo->m_name.empty();
|
||||
bool const hasName = !pInfo->m_name.empty();
|
||||
|
||||
bool const isCircle = (pRule->GetRadius() != -1);
|
||||
|
||||
|
@ -339,13 +337,13 @@ void DrawerYG::Draw(di::DrawInfo const * pInfo, di::DrawRule const * rules, size
|
|||
if (isArea)
|
||||
{
|
||||
bool const isFill = pRule->GetFillColor() != -1;
|
||||
bool const isSym = isSymbol && ((pRule->GetType() & drule::way) != 0);
|
||||
bool const hasSym = hasSymbol && ((pRule->GetType() & drule::way) != 0);
|
||||
|
||||
for (list<di::AreaInfo>::const_iterator i = pInfo->m_areas.begin(); i != pInfo->m_areas.end(); ++i)
|
||||
{
|
||||
if (isFill)
|
||||
drawArea(i->m_path, pRule, depth);
|
||||
else if (isSym)
|
||||
else if (hasSym)
|
||||
drawSymbol(i->GetCenter() + m2::PointD(0, 2 * m_visualScale), pRule, yg::EPosUnder, depth);
|
||||
}
|
||||
}
|
||||
|
@ -353,7 +351,7 @@ void DrawerYG::Draw(di::DrawInfo const * pInfo, di::DrawRule const * rules, size
|
|||
// draw point symbol
|
||||
if (!isPath && !isArea && ((pRule->GetType() & drule::node) != 0))
|
||||
{
|
||||
if (isSymbol)
|
||||
if (hasSymbol)
|
||||
drawSymbol(pInfo->m_point + m2::PointD(0, 2 * m_visualScale), pRule, yg::EPosUnder, depth);
|
||||
if (isCircle)
|
||||
drawCircle(pInfo->m_point + m2::PointD(0, 2 * m_visualScale), pRule, yg::EPosUnder, depth);
|
||||
|
@ -361,7 +359,7 @@ void DrawerYG::Draw(di::DrawInfo const * pInfo, di::DrawRule const * rules, size
|
|||
}
|
||||
else
|
||||
{
|
||||
if (isName)
|
||||
if (hasName)
|
||||
{
|
||||
bool isN = ((pRule->GetType() & drule::way) != 0);
|
||||
|
||||
|
|
|
@ -273,17 +273,15 @@ void InformationDisplay::drawRuler(DrawerYG * pDrawer)
|
|||
pDrawer->screen()->skin()->mapPenInfo(yg::PenInfo(yg::Color(0, 0, 0, 255), 2, 0, 0, 0)),
|
||||
yg::maxDepth);
|
||||
|
||||
m2::RectD textRect = pDrawer->screen()->textRect(scalerText.c_str(), 10, true, true, false);
|
||||
pDrawer->screen()->drawText(scalerPts[1] + m2::PointD(7, -7),
|
||||
yg::FontDesc fontDesc = yg::FontDesc::defaultFont;
|
||||
|
||||
m2::RectD textRect = pDrawer->screen()->textRect(fontDesc, scalerText.c_str(), false);
|
||||
pDrawer->screen()->drawText(fontDesc,
|
||||
scalerPts[1] + m2::PointD(7, -7),
|
||||
yg::EPosAboveRight,
|
||||
0,
|
||||
10,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
scalerText.c_str(),
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
|
||||
/* m2::PointD minPixPath[4];
|
||||
|
@ -322,10 +320,8 @@ void InformationDisplay::drawCenter(DrawerYG * drawer)
|
|||
<< fixed << setprecision(4) << setw(8) << m_centerPt.y << ")";
|
||||
|
||||
m2::RectD const & textRect = drawer->screen()->textRect(
|
||||
yg::FontDesc::defaultFont,
|
||||
out.str().c_str(),
|
||||
10,
|
||||
true,
|
||||
true,
|
||||
false);
|
||||
|
||||
m2::RectD bgRect = m2::Offset(m2::Inflate(textRect, 5.0, 5.0),
|
||||
|
@ -338,17 +334,14 @@ void InformationDisplay::drawCenter(DrawerYG * drawer)
|
|||
yg::maxDepth - 1);
|
||||
|
||||
drawer->screen()->drawText(
|
||||
m2::PointD(m_displayRect.maxX() - textRect.SizeX() - 10 * m_visualScale,
|
||||
m_displayRect.maxY() - (m_bottomShift + 10) * m_visualScale - 5),
|
||||
yg::EPosAboveRight,
|
||||
0, 10,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
out.str().c_str(),
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
yg::FontDesc::defaultFont,
|
||||
m2::PointD(m_displayRect.maxX() - textRect.SizeX() - 10 * m_visualScale,
|
||||
m_displayRect.maxY() - (m_bottomShift + 10) * m_visualScale - 5),
|
||||
yg::EPosAboveRight,
|
||||
0,
|
||||
out.str().c_str(),
|
||||
yg::maxDepth,
|
||||
false);
|
||||
}
|
||||
|
||||
void InformationDisplay::enableGlobalRect(bool doEnable)
|
||||
|
@ -367,16 +360,13 @@ void InformationDisplay::drawGlobalRect(DrawerYG *pDrawer)
|
|||
ostringstream out;
|
||||
out << "(" << m_globalRect.minX() << ", " << m_globalRect.minY() << ", " << m_globalRect.maxX() << ", " << m_globalRect.maxY() << ") Scale : " << m_currentScale;
|
||||
pDrawer->screen()->drawText(
|
||||
m2::PointD(m_displayRect.minX() + 10, m_displayRect.minY() + m_yOffset),
|
||||
yg::EPosAboveRight,
|
||||
0, 10,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
out.str().c_str(),
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
yg::FontDesc::defaultFont,
|
||||
m2::PointD(m_displayRect.minX() + 10, m_displayRect.minY() + m_yOffset),
|
||||
yg::EPosAboveRight,
|
||||
0,
|
||||
out.str().c_str(),
|
||||
yg::maxDepth,
|
||||
false);
|
||||
}
|
||||
|
||||
void InformationDisplay::enableDebugInfo(bool doEnable)
|
||||
|
@ -403,15 +393,12 @@ void InformationDisplay::drawDebugInfo(DrawerYG * drawer)
|
|||
|
||||
m2::PointD pos = m2::PointD(m_displayRect.minX() + 10, m_displayRect.minY() + m_yOffset);
|
||||
|
||||
drawer->screen()->drawText(pos,
|
||||
drawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
pos,
|
||||
yg::EPosAboveRight,
|
||||
0, 10,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
0,
|
||||
out.str().c_str(),
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
}
|
||||
|
||||
|
@ -434,15 +421,12 @@ void InformationDisplay::drawMemoryWarning(DrawerYG * drawer)
|
|||
ostringstream out;
|
||||
out << "MemoryWarning : " << m_lastMemoryWarning.ElapsedSeconds() << " sec. ago.";
|
||||
|
||||
drawer->screen()->drawText(pos,
|
||||
drawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
pos,
|
||||
yg::EPosAboveRight,
|
||||
0, 10,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
0,
|
||||
out.str().c_str(),
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
|
||||
if (m_lastMemoryWarning.ElapsedSeconds() > 5)
|
||||
|
@ -508,12 +492,10 @@ void InformationDisplay::drawLog(DrawerYG * pDrawer)
|
|||
m2::PointD startPt(m_displayRect.minX() + 10, m_displayRect.minY() + m_yOffset);
|
||||
|
||||
m2::RectD textRect = pDrawer->screen()->textRect(
|
||||
it->c_str(),
|
||||
10,
|
||||
true,
|
||||
true,
|
||||
false
|
||||
);
|
||||
yg::FontDesc::defaultFont,
|
||||
it->c_str(),
|
||||
false
|
||||
);
|
||||
|
||||
pDrawer->screen()->drawRectangle(
|
||||
m2::Inflate(m2::Offset(textRect, startPt), m2::PointD(2, 2)),
|
||||
|
@ -522,17 +504,14 @@ void InformationDisplay::drawLog(DrawerYG * pDrawer)
|
|||
);
|
||||
|
||||
pDrawer->screen()->drawText(
|
||||
startPt,
|
||||
yg::EPosAboveRight,
|
||||
0, 10,
|
||||
yg::Color(0, 0, 0, 255),
|
||||
it->c_str(),
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false
|
||||
);
|
||||
yg::FontDesc::defaultFont,
|
||||
startPt,
|
||||
yg::EPosAboveRight,
|
||||
0,
|
||||
it->c_str(),
|
||||
yg::maxDepth,
|
||||
false
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -551,37 +530,41 @@ void InformationDisplay::drawEmptyModelMessage(DrawerYG * pDrawer)
|
|||
char const s2 [] = "Just click the button at the bottom";
|
||||
char const s3 [] = "right corner to download the maps.";
|
||||
|
||||
m2::RectD tr0 = pDrawer->screen()->textRect(s0, 10, true, true, false);
|
||||
m2::RectD tr1 = pDrawer->screen()->textRect(s1, 10, true, true, false);
|
||||
m2::RectD tr2 = pDrawer->screen()->textRect(s2, 10, true, true, false);
|
||||
m2::RectD tr3 = pDrawer->screen()->textRect(s3, 10, true, true, false);
|
||||
m2::RectD tr0 = pDrawer->screen()->textRect(yg::FontDesc::defaultFont, s0, false);
|
||||
m2::RectD tr1 = pDrawer->screen()->textRect(yg::FontDesc::defaultFont, s1, false);
|
||||
m2::RectD tr2 = pDrawer->screen()->textRect(yg::FontDesc::defaultFont, s2, false);
|
||||
m2::RectD tr3 = pDrawer->screen()->textRect(yg::FontDesc::defaultFont, s3, false);
|
||||
|
||||
pDrawer->screen()->drawText(m2::PointD(0, -(tr1.SizeY() + 5)) + pt,
|
||||
pDrawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
m2::PointD(0, -(tr1.SizeY() + 5)) + pt,
|
||||
yg::EPosCenter,
|
||||
0, 10, yg::Color(255, 255, 255, 255), s0, true, yg::Color(255, 255, 255, 255),
|
||||
0,
|
||||
s0,
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
|
||||
pDrawer->screen()->drawText(m2::PointD(0, 0) + pt,
|
||||
pDrawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
m2::PointD(0, 0) + pt,
|
||||
yg::EPosCenter,
|
||||
0, 10, yg::Color(255, 255, 255, 255), s1, true, yg::Color(255, 255, 255, 255),
|
||||
0,
|
||||
s1,
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
|
||||
pDrawer->screen()->drawText(m2::PointD(0, tr2.SizeY() + 5) + pt,
|
||||
pDrawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
m2::PointD(0, tr2.SizeY() + 5) + pt,
|
||||
yg::EPosCenter,
|
||||
0, 10, yg::Color(255, 255, 255, 255), s2, true, yg::Color(255, 255, 255, 255),
|
||||
0,
|
||||
s2,
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
|
||||
pDrawer->screen()->drawText(m2::PointD(0, tr2.SizeY() + 5 + tr3.SizeY() + 5) + pt,
|
||||
pDrawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
m2::PointD(0, tr2.SizeY() + 5 + tr3.SizeY() + 5) + pt,
|
||||
yg::EPosCenter,
|
||||
0, 10, yg::Color(255, 255, 255, 255), s3, true, yg::Color(255, 255, 255, 255),
|
||||
0,
|
||||
s3,
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
}
|
||||
#endif
|
||||
|
@ -626,15 +609,12 @@ void InformationDisplay::drawBenchmarkInfo(DrawerYG * pDrawer)
|
|||
{
|
||||
m_yOffset += 20;
|
||||
m2::PointD pos(m_displayRect.minX() + 10, m_displayRect.minY() + m_yOffset);
|
||||
pDrawer->screen()->drawText(pos,
|
||||
pDrawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
pos,
|
||||
yg::EPosAboveRight,
|
||||
0, 10,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
0,
|
||||
"benchmark info :",
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false);
|
||||
|
||||
for (unsigned i = 0; i < m_benchmarkInfo.size(); ++i)
|
||||
|
@ -649,15 +629,12 @@ void InformationDisplay::drawBenchmarkInfo(DrawerYG * pDrawer)
|
|||
<< "), duration : " << m_benchmarkInfo[i].m_duration;
|
||||
m_yOffset += 20;
|
||||
pos.y += 20;
|
||||
pDrawer->screen()->drawText(pos,
|
||||
pDrawer->screen()->drawText(yg::FontDesc::defaultFont,
|
||||
pos,
|
||||
yg::EPosAboveRight,
|
||||
0, 10,
|
||||
yg::Color(0, 0, 0, 0),
|
||||
0,
|
||||
out.str().c_str(),
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
yg::maxDepth,
|
||||
true,
|
||||
false
|
||||
);
|
||||
}
|
||||
|
|
|
@ -68,6 +68,15 @@ namespace yg
|
|||
return false;
|
||||
}
|
||||
|
||||
bool operator > (Color const & l, Color const & r)
|
||||
{
|
||||
if (l.r != r.r) return l.r > r.r;
|
||||
if (l.g != r.g) return l.g > r.g;
|
||||
if (l.b != r.b) return l.b > r.b;
|
||||
if (l.a != r.a) return l.a > r.a;
|
||||
return false;
|
||||
}
|
||||
|
||||
bool operator != (Color const & l, Color const & r)
|
||||
{
|
||||
return (l.r != r.r) || (l.g != r.g) || (l.b != r.b) || (l.a != r.a);
|
||||
|
|
|
@ -23,6 +23,7 @@ namespace yg
|
|||
};
|
||||
|
||||
bool operator < (Color const & l, Color const & r);
|
||||
bool operator > (Color const & l, Color const & r);
|
||||
bool operator !=(Color const & l, Color const & r);
|
||||
bool operator ==(Color const & l, Color const & r);
|
||||
|
||||
|
|
|
@ -3,4 +3,17 @@
|
|||
namespace yg
|
||||
{
|
||||
static const int maxDepth = 12000;
|
||||
|
||||
enum EPosition
|
||||
{
|
||||
EPosCenter = 0x00,
|
||||
EPosAbove = 0x01,
|
||||
EPosUnder = 0x02,
|
||||
EPosLeft = 0x04,
|
||||
EPosRight = 0x10,
|
||||
EPosAboveLeft = EPosAbove | EPosLeft,
|
||||
EPosAboveRight = EPosAbove | EPosRight,
|
||||
EPosUnderLeft = EPosUnder | EPosLeft,
|
||||
EPosUnderRight = EPosUnder | EPosRight
|
||||
};
|
||||
}
|
||||
|
|
57
yg/font_desc.cpp
Normal file
57
yg/font_desc.cpp
Normal file
|
@ -0,0 +1,57 @@
|
|||
#include "../base/SRC_FIRST.hpp"
|
||||
#include "font_desc.hpp"
|
||||
|
||||
namespace yg
|
||||
{
|
||||
FontDesc const & FontDesc::defaultFont = FontDesc();
|
||||
|
||||
FontDesc::FontDesc(bool isStatic, int size, yg::Color const & color,
|
||||
bool isMasked, yg::Color const & maskColor)
|
||||
: m_isStatic(isStatic), m_size(size), m_color(color),
|
||||
m_isMasked(isMasked), m_maskColor(maskColor)
|
||||
{}
|
||||
|
||||
bool FontDesc::operator ==(FontDesc const & src) const
|
||||
{
|
||||
return (m_isStatic == src.m_isStatic)
|
||||
&& (m_size == src.m_size)
|
||||
&& (m_color == src.m_color)
|
||||
&& (m_isMasked == src.m_isMasked)
|
||||
&& (m_maskColor == src.m_maskColor);
|
||||
}
|
||||
|
||||
bool FontDesc::operator !=(FontDesc const & src) const
|
||||
{
|
||||
return !(*this == src);
|
||||
}
|
||||
|
||||
bool FontDesc::operator < (FontDesc const & src) const
|
||||
{
|
||||
if (m_isStatic != src.m_isStatic)
|
||||
return m_isStatic < src.m_isStatic;
|
||||
if (m_size != src.m_size)
|
||||
return m_size < src.m_size;
|
||||
if (m_color != src.m_color)
|
||||
return m_color < src.m_color;
|
||||
if (m_isMasked != src.m_isMasked)
|
||||
return m_isMasked < src.m_isMasked;
|
||||
if (m_maskColor != src.m_maskColor)
|
||||
return m_maskColor < src.m_maskColor;
|
||||
return false;
|
||||
}
|
||||
|
||||
bool FontDesc::operator > (FontDesc const & src) const
|
||||
{
|
||||
if (m_isStatic != src.m_isStatic)
|
||||
return m_isStatic > src.m_isStatic;
|
||||
if (m_size != src.m_size)
|
||||
return m_size > src.m_size;
|
||||
if (m_color != src.m_color)
|
||||
return m_color > src.m_color;
|
||||
if (m_isMasked != src.m_isMasked)
|
||||
return m_isMasked > src.m_isMasked;
|
||||
if (m_maskColor != src.m_maskColor)
|
||||
return m_maskColor > src.m_maskColor;
|
||||
return false;
|
||||
}
|
||||
}
|
25
yg/font_desc.hpp
Normal file
25
yg/font_desc.hpp
Normal file
|
@ -0,0 +1,25 @@
|
|||
#pragma once
|
||||
|
||||
#include "color.hpp"
|
||||
|
||||
namespace yg
|
||||
{
|
||||
struct FontDesc
|
||||
{
|
||||
bool m_isStatic;
|
||||
int m_size;
|
||||
yg::Color m_color;
|
||||
bool m_isMasked;
|
||||
yg::Color m_maskColor;
|
||||
|
||||
FontDesc(bool isStatic = true, int size = 10, yg::Color const & color = yg::Color(0, 0, 0, 255),
|
||||
bool isMasked = true, yg::Color const & maskColor = yg::Color(255, 255, 255, 255));
|
||||
|
||||
bool operator != (FontDesc const & src) const;
|
||||
bool operator == (FontDesc const & src) const;
|
||||
bool operator < (FontDesc const & src) const;
|
||||
bool operator > (FontDesc const & src) const;
|
||||
|
||||
static FontDesc const & defaultFont;
|
||||
};
|
||||
}
|
|
@ -27,19 +27,6 @@ namespace yg
|
|||
class Skin;
|
||||
struct CharStyle;
|
||||
|
||||
enum EPosition
|
||||
{
|
||||
EPosCenter = 0x00,
|
||||
EPosAbove = 0x01,
|
||||
EPosUnder = 0x02,
|
||||
EPosLeft = 0x04,
|
||||
EPosRight = 0x10,
|
||||
EPosAboveLeft = EPosAbove | EPosLeft,
|
||||
EPosAboveRight = EPosAbove | EPosRight,
|
||||
EPosUnderLeft = EPosUnder | EPosLeft,
|
||||
EPosUnderRight = EPosUnder | EPosRight
|
||||
};
|
||||
|
||||
namespace gl
|
||||
{
|
||||
class GeometryBatcher : public RenderStateUpdater
|
||||
|
|
56
yg/layout_element.cpp
Normal file
56
yg/layout_element.cpp
Normal file
|
@ -0,0 +1,56 @@
|
|||
#include "../base/SRC_FIRST.hpp"
|
||||
|
||||
#include "layout_element.hpp"
|
||||
#include "screen.hpp"
|
||||
|
||||
namespace yg
|
||||
{
|
||||
LayoutElement::LayoutElement(int groupID, m2::PointD const & pivot, EPosition pos)
|
||||
: m_groupID(groupID), m_pivot(pivot), m_pos(pos)
|
||||
{}
|
||||
|
||||
int LayoutElement::groupID() const
|
||||
{
|
||||
return m_groupID;
|
||||
}
|
||||
|
||||
m2::PointD const & LayoutElement::pivot() const
|
||||
{
|
||||
return m_pivot;
|
||||
}
|
||||
|
||||
EPosition LayoutElement::position() const
|
||||
{
|
||||
return m_pos;
|
||||
}
|
||||
|
||||
bool LayoutElement::isFreeElement() const
|
||||
{
|
||||
return m_isFreeElement;
|
||||
}
|
||||
|
||||
void LayoutElement::setIsFreeElement(bool flag) const
|
||||
{
|
||||
m_isFreeElement = flag;
|
||||
}
|
||||
|
||||
bool LayoutElement::isFrozen() const
|
||||
{
|
||||
return m_isFrozen;
|
||||
}
|
||||
|
||||
void LayoutElement::setIsFrozen(bool flag) const
|
||||
{
|
||||
m_isFrozen = flag;
|
||||
}
|
||||
|
||||
bool LayoutElement::doNeedRedraw() const
|
||||
{
|
||||
return m_doNeedRedraw;
|
||||
}
|
||||
|
||||
void LayoutElement::setNeedRedraw(bool flag) const
|
||||
{
|
||||
m_doNeedRedraw = flag;
|
||||
}
|
||||
}
|
69
yg/layout_element.hpp
Normal file
69
yg/layout_element.hpp
Normal file
|
@ -0,0 +1,69 @@
|
|||
#pragma once
|
||||
|
||||
#include "../geometry/point2d.hpp"
|
||||
#include "../geometry/rect2d.hpp"
|
||||
#include "defines.hpp"
|
||||
|
||||
namespace yg
|
||||
{
|
||||
class Screen;
|
||||
struct FontDesc;
|
||||
|
||||
class LayoutElement
|
||||
{
|
||||
private:
|
||||
|
||||
int m_groupID;
|
||||
m2::PointD m_pivot;
|
||||
EPosition m_pos;
|
||||
|
||||
mutable bool m_isFreeElement;
|
||||
mutable bool m_isFrozen;
|
||||
mutable bool m_doNeedRedraw;
|
||||
|
||||
public:
|
||||
LayoutElement(int groupID, m2::PointD const & pivot, EPosition pos);
|
||||
/// id of the group, composed of several layoutElements
|
||||
int groupID() const;
|
||||
/// pivot is expressed in group coordinates
|
||||
m2::PointD const & pivot() const;
|
||||
/// position of the element related to pivot point
|
||||
EPosition position() const;
|
||||
|
||||
bool isFreeElement() const;
|
||||
void setIsFreeElement(bool flag) const;
|
||||
|
||||
bool isFrozen() const;
|
||||
void setIsFrozen(bool flag) const;
|
||||
|
||||
bool doNeedRedraw() const;
|
||||
void setNeedRedraw(bool flag) const;
|
||||
|
||||
/// bounding rect in pivot-aligned coordinates
|
||||
virtual m2::RectD const boundRect() const = 0;
|
||||
/// draw layout element
|
||||
virtual void draw(Screen * screen) = 0;
|
||||
};
|
||||
|
||||
class TextLayoutElement : public LayoutElement
|
||||
{
|
||||
public:
|
||||
|
||||
TextLayoutElement(char const * text, double depth, FontDesc const & fontDesc);
|
||||
|
||||
m2::RectD const boundRect() const;
|
||||
|
||||
void draw(Screen * screen);
|
||||
};
|
||||
|
||||
class SymbolLayoutElement : public LayoutElement
|
||||
{
|
||||
public:
|
||||
|
||||
SymbolLayoutElement();
|
||||
|
||||
m2::RectD const boundRect() const;
|
||||
|
||||
void draw(Screen * screen);
|
||||
};
|
||||
}
|
|
@ -23,6 +23,7 @@ namespace yg
|
|||
{
|
||||
namespace gl
|
||||
{
|
||||
|
||||
TextRenderer::Params::Params()
|
||||
: m_textTreeAutoClean(true),
|
||||
m_useTextTree(false),
|
||||
|
@ -39,8 +40,8 @@ namespace yg
|
|||
m_doPeriodicalTextUpdate(params.m_doPeriodicalTextUpdate)
|
||||
{}
|
||||
|
||||
TextRenderer::TextObj::TextObj(m2::PointD const & pt, yg::EPosition pos, string const & txt, uint8_t sz, yg::Color const & c, bool isMasked, yg::Color const & maskColor, double d, bool isFixedFont, bool log2vis)
|
||||
: m_pt(pt), m_pos(pos), m_size(sz), m_utf8Text(txt), m_isMasked(isMasked), m_depth(d), m_needRedraw(true), m_frozen(false), m_isFixedFont(isFixedFont), m_log2vis(log2vis), m_color(c), m_maskColor(maskColor)
|
||||
TextRenderer::TextObj::TextObj(FontDesc const & fontDesc, m2::PointD const & pt, yg::EPosition pos, string const & txt, double d, bool log2vis)
|
||||
: m_fontDesc(fontDesc), m_pt(pt), m_pos(pos), m_utf8Text(txt), m_depth(d), m_needRedraw(true), m_frozen(false), m_log2vis(log2vis)
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -50,14 +51,14 @@ namespace yg
|
|||
/// lies inside the testing rect and therefore should be skipped.
|
||||
if (m_needRedraw)
|
||||
{
|
||||
pTextRenderer->drawTextImpl(m_pt, m_pos, 0.0, m_size, m_color, m_utf8Text, true, m_maskColor, yg::maxDepth, m_isFixedFont, m_log2vis);
|
||||
pTextRenderer->drawTextImpl(m_fontDesc, m_pt, m_pos, 0.0, m_utf8Text, yg::maxDepth, m_log2vis);
|
||||
m_frozen = true;
|
||||
}
|
||||
}
|
||||
|
||||
m2::RectD const TextRenderer::TextObj::GetLimitRect(TextRenderer* pTextRenderer) const
|
||||
{
|
||||
m2::RectD limitRect = pTextRenderer->textRect(m_utf8Text, m_size, m_isMasked, false, m_log2vis);
|
||||
m2::RectD limitRect = pTextRenderer->textRect(m_fontDesc, m_utf8Text, m_log2vis);
|
||||
|
||||
double dx = -limitRect.SizeX() / 2;
|
||||
double dy = limitRect.SizeY() / 2;
|
||||
|
@ -111,32 +112,28 @@ namespace yg
|
|||
// because frozen texts shouldn't be popped out by newly arrived texts.
|
||||
if (r2.m_frozen)
|
||||
return false;
|
||||
if (r1.m_size != r2.m_size)
|
||||
return r1.m_size > r2.m_size;
|
||||
if (r1.m_fontDesc != r2.m_fontDesc)
|
||||
return r1.m_fontDesc > r2.m_fontDesc;
|
||||
return (r1.m_depth > r2.m_depth);
|
||||
}
|
||||
|
||||
void TextRenderer::drawText(m2::PointD const & pt,
|
||||
void TextRenderer::drawText(FontDesc const & fontDesc,
|
||||
m2::PointD const & pt,
|
||||
yg::EPosition pos,
|
||||
float angle,
|
||||
uint8_t fontSize,
|
||||
yg::Color const & color,
|
||||
string const & utf8Text,
|
||||
bool isMasked,
|
||||
yg::Color const & maskColor,
|
||||
double depth,
|
||||
bool isFixedFont,
|
||||
bool log2vis)
|
||||
{
|
||||
if (!m_drawTexts)
|
||||
return;
|
||||
|
||||
if (!m_useTextTree || isFixedFont)
|
||||
drawTextImpl(pt, pos, angle, fontSize, color, utf8Text, true, maskColor, depth, isFixedFont, log2vis);
|
||||
if (!m_useTextTree || fontDesc.m_isStatic)
|
||||
drawTextImpl(fontDesc, pt, pos, angle, utf8Text, depth, log2vis);
|
||||
else
|
||||
{
|
||||
checkTextRedraw();
|
||||
TextObj obj(pt, pos, utf8Text, fontSize, color, isMasked, maskColor, depth, isFixedFont, log2vis);
|
||||
TextObj obj(fontDesc, pt, pos, utf8Text, depth, log2vis);
|
||||
m2::RectD r = obj.GetLimitRect(this);
|
||||
m_tree.ReplaceIf(obj, r, &TextObj::better_text);
|
||||
}
|
||||
|
@ -225,12 +222,12 @@ namespace yg
|
|||
}
|
||||
|
||||
template <class ToDo>
|
||||
void TextRenderer::ForEachGlyph(uint8_t fontSize, yg::Color const & color, wstring const & text, bool isMasked, bool isFixedFont, ToDo toDo)
|
||||
void TextRenderer::ForEachGlyph(FontDesc const & fontDesc, wstring const & text, ToDo toDo)
|
||||
{
|
||||
m2::PointD currPt(0, 0);
|
||||
for (size_t i = 0; i < text.size(); ++i)
|
||||
{
|
||||
uint32_t glyphID = skin()->mapGlyph(GlyphKey(text[i], fontSize, isMasked, color), isFixedFont);
|
||||
uint32_t glyphID = skin()->mapGlyph(GlyphKey(text[i], fontDesc.m_size, fontDesc.m_isMasked, fontDesc.m_isMasked ? fontDesc.m_maskColor : fontDesc.m_color), fontDesc.m_isStatic);
|
||||
CharStyle const * p = static_cast<CharStyle const *>(skin()->fromID(glyphID));
|
||||
if (p)
|
||||
{
|
||||
|
@ -250,14 +247,14 @@ namespace yg
|
|||
return res;
|
||||
}
|
||||
|
||||
void TextRenderer::drawTextImpl(m2::PointD const & pt, yg::EPosition pos, float angle, uint8_t fontSize, yg::Color const & color, string const & utf8Text, bool isMasked, yg::Color const & maskColor, double depth, bool isFixedFont, bool log2vis)
|
||||
void TextRenderer::drawTextImpl(FontDesc const & fontDesc, m2::PointD const & pt, yg::EPosition pos, float angle, string const & utf8Text, double depth, bool log2vis)
|
||||
{
|
||||
wstring text = FromUtf8(utf8Text);
|
||||
|
||||
if (log2vis)
|
||||
text = Log2Vis(text);
|
||||
|
||||
m2::RectD r = textRect(utf8Text, fontSize, isMasked, isFixedFont, log2vis);
|
||||
m2::RectD r = textRect(fontDesc, utf8Text, log2vis);
|
||||
|
||||
m2::PointD orgPt(pt.x - r.SizeX() / 2, pt.y + r.SizeY() / 2);
|
||||
|
||||
|
@ -276,12 +273,18 @@ namespace yg
|
|||
orgPt.x = ::floor(orgPt.x);
|
||||
orgPt.y = ::floor(orgPt.y);
|
||||
|
||||
if (isMasked)
|
||||
ForEachGlyph(fontSize, maskColor, text, true, isFixedFont, bind(&TextRenderer::drawGlyph, this, cref(orgPt), _1, angle, 0, _2, depth));
|
||||
ForEachGlyph(fontSize, color, text, false, isFixedFont, bind(&TextRenderer::drawGlyph, this, cref(orgPt), _1, angle, 0, _2, depth));
|
||||
yg::FontDesc desc = fontDesc;
|
||||
|
||||
if (desc.m_isMasked)
|
||||
{
|
||||
ForEachGlyph(desc, text, bind(&TextRenderer::drawGlyph, this, cref(orgPt), _1, angle, 0, _2, depth));
|
||||
desc.m_isMasked = false;
|
||||
}
|
||||
|
||||
ForEachGlyph(desc, text, bind(&TextRenderer::drawGlyph, this, cref(orgPt), _1, angle, 0, _2, depth));
|
||||
}
|
||||
|
||||
m2::RectD const TextRenderer::textRect(string const & utf8Text, uint8_t fontSize, bool isMasked, bool fixedFont, bool log2vis)
|
||||
m2::RectD const TextRenderer::textRect(FontDesc const & fontDesc, string const & utf8Text, bool log2vis)
|
||||
{
|
||||
if (m_useTextTree)
|
||||
checkTextRedraw();
|
||||
|
@ -295,9 +298,9 @@ namespace yg
|
|||
|
||||
for (size_t i = 0; i < text.size(); ++i)
|
||||
{
|
||||
if (fixedFont)
|
||||
if (fontDesc.m_isStatic)
|
||||
{
|
||||
uint32_t glyphID = skin()->mapGlyph(GlyphKey(text[i], fontSize, isMasked, yg::Color(0, 0, 0, 0)), fixedFont);
|
||||
uint32_t glyphID = skin()->mapGlyph(GlyphKey(text[i], fontDesc.m_size, fontDesc.m_isMasked, yg::Color(0, 0, 0, 0)), fontDesc.m_isStatic);
|
||||
CharStyle const * p = static_cast<CharStyle const *>(skin()->fromID(glyphID));
|
||||
if (p != 0)
|
||||
{
|
||||
|
@ -308,7 +311,7 @@ namespace yg
|
|||
}
|
||||
else
|
||||
{
|
||||
GlyphMetrics const m = resourceManager()->getGlyphMetrics(GlyphKey(text[i], fontSize, isMasked, yg::Color(0, 0, 0, 0)));
|
||||
GlyphMetrics const m = resourceManager()->getGlyphMetrics(GlyphKey(text[i], fontDesc.m_size, fontDesc.m_isMasked, yg::Color(0, 0, 0, 0)));
|
||||
|
||||
rect.Add(pt);
|
||||
rect.Add(pt + m2::PointD(m.m_xOffset + m.m_width, - m.m_yOffset - m.m_height));
|
||||
|
@ -393,23 +396,29 @@ namespace yg
|
|||
}
|
||||
|
||||
bool TextRenderer::drawPathText(
|
||||
m2::PointD const * path, size_t s, uint8_t fontSize, yg::Color const & color, string const & utf8Text,
|
||||
double fullLength, double pathOffset, TextPos pos, bool isMasked, yg::Color const & maskColor, double depth, bool isFixedFont)
|
||||
FontDesc const & fontDesc, m2::PointD const * path, size_t s, string const & utf8Text,
|
||||
double fullLength, double pathOffset, TextPos pos, double depth)
|
||||
{
|
||||
if (!m_drawTexts)
|
||||
return false;
|
||||
if (m_useTextTree)
|
||||
checkTextRedraw();
|
||||
|
||||
if (isMasked)
|
||||
if (!drawPathTextImpl(path, s, fontSize, maskColor, utf8Text, fullLength, pathOffset, pos, true, depth, isFixedFont))
|
||||
yg::FontDesc desc = fontDesc;
|
||||
|
||||
if (desc.m_isMasked)
|
||||
{
|
||||
if (!drawPathTextImpl(desc, path, s, utf8Text, fullLength, pathOffset, pos, depth))
|
||||
return false;
|
||||
return drawPathTextImpl(path, s, fontSize, color, utf8Text, fullLength, pathOffset, pos, false, depth, isFixedFont);
|
||||
else
|
||||
desc.m_isMasked = false;
|
||||
}
|
||||
return drawPathTextImpl(desc, path, s, utf8Text, fullLength, pathOffset, pos, depth);
|
||||
}
|
||||
|
||||
bool TextRenderer::drawPathTextImpl(
|
||||
m2::PointD const * path, size_t s, uint8_t fontSize, yg::Color const & color, string const & utf8Text,
|
||||
double fullLength, double pathOffset, TextPos pos, bool isMasked, double depth, bool isFixedFont)
|
||||
FontDesc const & fontDesc, m2::PointD const * path, size_t s, string const & utf8Text,
|
||||
double fullLength, double pathOffset, TextPos pos, double depth)
|
||||
{
|
||||
pts_array arrPath(path, s, fullLength, pathOffset);
|
||||
|
||||
|
@ -419,8 +428,8 @@ namespace yg
|
|||
float blOffset = 2;
|
||||
switch (pos)
|
||||
{
|
||||
case under_line: blOffset -= fontSize; break;
|
||||
case middle_line: blOffset -= fontSize / 2; break;
|
||||
case under_line: blOffset -= fontDesc.m_size; break;
|
||||
case middle_line: blOffset -= fontDesc.m_size / 2; break;
|
||||
case above_line: blOffset -= 0; break;
|
||||
}
|
||||
|
||||
|
@ -432,7 +441,7 @@ namespace yg
|
|||
double strLength = 0.0;
|
||||
for (size_t i = 0; i < count; ++i)
|
||||
{
|
||||
glyphs[i] = resourceManager()->getGlyphMetrics(GlyphKey(text[i], fontSize, isMasked, yg::Color(0, 0, 0, 0)));
|
||||
glyphs[i] = resourceManager()->getGlyphMetrics(GlyphKey(text[i], fontDesc.m_size, fontDesc.m_isMasked, yg::Color(0, 0, 0, 0)));
|
||||
strLength += glyphs[i].m_xAdvance;
|
||||
}
|
||||
|
||||
|
@ -457,7 +466,7 @@ namespace yg
|
|||
if (!CalcPointAndAngle(arrPath, offset, ind, ptOrg, angle))
|
||||
break;
|
||||
|
||||
uint32_t const glyphID = skin()->mapGlyph(GlyphKey(text[i], fontSize, isMasked, color), isFixedFont);
|
||||
uint32_t const glyphID = skin()->mapGlyph(GlyphKey(text[i], fontDesc.m_size, fontDesc.m_isMasked, fontDesc.m_isMasked ? fontDesc.m_maskColor : fontDesc.m_color), fontDesc.m_isStatic);
|
||||
CharStyle const * charStyle = static_cast<CharStyle const *>(skin()->fromID(glyphID));
|
||||
|
||||
drawGlyph(ptOrg, m2::PointD(0.0, 0.0), angle, blOffset, charStyle, depth);
|
||||
|
|
|
@ -1,11 +1,14 @@
|
|||
#pragma once
|
||||
|
||||
#include "path_renderer.hpp"
|
||||
#include "defines.hpp"
|
||||
#include "font_desc.hpp"
|
||||
|
||||
#include "../geometry/tree4d.hpp"
|
||||
|
||||
#include "../std/shared_ptr.hpp"
|
||||
|
||||
|
||||
namespace yg
|
||||
{
|
||||
class ResourceManager;
|
||||
|
@ -19,24 +22,26 @@ namespace yg
|
|||
|
||||
enum TextPos { under_line, middle_line, above_line };
|
||||
|
||||
|
||||
class TextObj
|
||||
{
|
||||
FontDesc m_fontDesc;
|
||||
m2::PointD m_pt;
|
||||
yg::EPosition m_pos;
|
||||
uint8_t m_size;
|
||||
string m_utf8Text;
|
||||
bool m_isMasked;
|
||||
double m_depth;
|
||||
mutable bool m_needRedraw;
|
||||
mutable bool m_frozen;
|
||||
bool m_isFixedFont;
|
||||
bool m_log2vis;
|
||||
yg::Color m_color;
|
||||
yg::Color m_maskColor;
|
||||
|
||||
public:
|
||||
|
||||
TextObj(m2::PointD const & pt, yg::EPosition pos, string const & txt, uint8_t sz, yg::Color const & c, bool isMasked, yg::Color const & maskColor, double d, bool isFixedFont, bool log2vis);
|
||||
TextObj(FontDesc const & fontDesc,
|
||||
m2::PointD const & pt,
|
||||
yg::EPosition pos,
|
||||
string const & txt,
|
||||
double depth,
|
||||
bool log2vis);
|
||||
void Draw(TextRenderer * pTextRenderer) const;
|
||||
m2::RectD const GetLimitRect(TextRenderer * pTextRenderer) const;
|
||||
void SetNeedRedraw(bool needRedraw) const;
|
||||
|
@ -58,7 +63,7 @@ namespace yg
|
|||
static wstring Log2Vis(wstring const & str);
|
||||
|
||||
template <class ToDo>
|
||||
void ForEachGlyph(uint8_t fontSize, yg::Color const & color, wstring const & text, bool isMask, bool isFixedFont, ToDo toDo);
|
||||
void ForEachGlyph(FontDesc const & fontDesc, wstring const & text, ToDo toDo);
|
||||
|
||||
void drawGlyph(m2::PointD const & ptOrg,
|
||||
m2::PointD const & ptGlyph,
|
||||
|
@ -68,29 +73,22 @@ namespace yg
|
|||
double depth);
|
||||
|
||||
|
||||
bool drawPathTextImpl(m2::PointD const * path,
|
||||
size_t s,
|
||||
uint8_t fontSize,
|
||||
yg::Color const & color,
|
||||
string const & utf8Text,
|
||||
double fullLength,
|
||||
double pathOffset,
|
||||
TextPos pos,
|
||||
bool isMasked,
|
||||
double depth,
|
||||
bool isFixedFont);
|
||||
bool drawPathTextImpl(FontDesc const & fontDesc,
|
||||
m2::PointD const * path,
|
||||
size_t s,
|
||||
string const & utf8Text,
|
||||
double fullLength,
|
||||
double pathOffset,
|
||||
TextPos pos,
|
||||
double depth);
|
||||
|
||||
/// Drawing text from point rotated by the angle.
|
||||
void drawTextImpl(m2::PointD const & pt,
|
||||
void drawTextImpl(FontDesc const & fontDesc,
|
||||
m2::PointD const & pt,
|
||||
yg::EPosition pos,
|
||||
float angle,
|
||||
uint8_t fontSize,
|
||||
yg::Color const & color,
|
||||
string const & utf8Text,
|
||||
bool isMasked,
|
||||
yg::Color const & maskColor,
|
||||
double depth,
|
||||
bool fixedFont,
|
||||
bool log2vis);
|
||||
|
||||
bool m_textTreeAutoClean;
|
||||
|
@ -114,37 +112,27 @@ namespace yg
|
|||
TextRenderer(Params const & params);
|
||||
|
||||
/// Drawing text from point rotated by the angle.
|
||||
void drawText(m2::PointD const & pt,
|
||||
void drawText(FontDesc const & fontDesc,
|
||||
m2::PointD const & pt,
|
||||
yg::EPosition pos,
|
||||
float angle,
|
||||
uint8_t fontSize,
|
||||
yg::Color const & color,
|
||||
string const & utf8Text,
|
||||
bool isMasked,
|
||||
yg::Color const & maskColor,
|
||||
double depth,
|
||||
bool fixedFont,
|
||||
bool log2vis);
|
||||
|
||||
m2::RectD const textRect(string const & utf8Text,
|
||||
uint8_t fontSize,
|
||||
bool isMasked,
|
||||
bool fixedFont,
|
||||
m2::RectD const textRect(FontDesc const & fontDesc,
|
||||
string const & utf8Text,
|
||||
bool log2vis);
|
||||
|
||||
/// Drawing text in the middle of the path.
|
||||
bool drawPathText(m2::PointD const * path,
|
||||
bool drawPathText(FontDesc const & fontDesc,
|
||||
m2::PointD const * path,
|
||||
size_t s,
|
||||
uint8_t fontSize,
|
||||
yg::Color const & color,
|
||||
string const & utf8Text,
|
||||
double fullLength,
|
||||
double pathOffset,
|
||||
TextPos pos,
|
||||
bool isMasked,
|
||||
yg::Color const & maskColor,
|
||||
double depth,
|
||||
bool isFixedFont = false);
|
||||
double depth);
|
||||
|
||||
|
||||
void setClipRect(m2::RectI const & rect);
|
||||
|
|
|
@ -55,7 +55,9 @@ SOURCES += \
|
|||
shape_renderer.cpp \
|
||||
symbol_renderer.cpp \
|
||||
circle_info.cpp \
|
||||
area_renderer.cpp
|
||||
area_renderer.cpp \
|
||||
layout_element.cpp \
|
||||
font_desc.cpp
|
||||
|
||||
HEADERS += \
|
||||
internal/opengl.hpp \
|
||||
|
@ -104,7 +106,9 @@ HEADERS += \
|
|||
shape_renderer.hpp \
|
||||
symbol_renderer.hpp \
|
||||
circle_info.hpp \
|
||||
area_renderer.hpp
|
||||
area_renderer.hpp \
|
||||
layout_element.hpp \
|
||||
font_desc.hpp
|
||||
|
||||
!iphone*:!bada-simulator {
|
||||
HEADERS += internal/opengl_win32.hpp
|
||||
|
|
|
@ -520,12 +520,14 @@ namespace
|
|||
double pat[2] = {2, 2};
|
||||
p->drawPath(path, sizeof(path) / sizeof(m2::PointD), p->skin()->mapPenInfo(yg::PenInfo(yg::Color(0, 0, 0, 0xFF), 2, pat, 2, 0)), 0);
|
||||
|
||||
p->drawText(m2::PointD(200, 200), yg::EPosAboveRight, 0 , 20, yg::Color(0, 0, 0, 0), "0", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
p->drawText(m2::PointD(240, 200), yg::EPosAboveRight, math::pi / 2 , 20, yg::Color(0, 0, 0, 0), "0", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
p->drawText(m2::PointD(280, 200), yg::EPosAboveRight, math::pi , 20, yg::Color(0, 0, 0, 0), "0", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
p->drawText(m2::PointD(320, 200), yg::EPosAboveRight, math::pi * 3 / 2 , 20, yg::Color(0, 0, 0, 0), "0", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
p->drawText(m2::PointD(360, 200), yg::EPosAboveRight, math::pi / 18, 20, yg::Color(0, 0, 0, 0), "0", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, math::pi / 18, 20, yg::Color(0, 0, 0, 0), "Simplicity is the ultimate sophistication", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
yg::FontDesc fontDesc(false, 20, yg::Color(0, 0, 0, 0), true, yg::Color(255, 255, 255, 255));
|
||||
|
||||
p->drawText(fontDesc, m2::PointD(200, 200), yg::EPosAboveRight, 0 , "0", 0, true);
|
||||
p->drawText(fontDesc, m2::PointD(240, 200), yg::EPosAboveRight, math::pi / 2 , "0", 0, true);
|
||||
p->drawText(fontDesc, m2::PointD(280, 200), yg::EPosAboveRight, math::pi , "0", 0, true);
|
||||
p->drawText(fontDesc, m2::PointD(320, 200), yg::EPosAboveRight, math::pi * 3 / 2 , "0", 0, true);
|
||||
p->drawText(fontDesc, m2::PointD(360, 200), yg::EPosAboveRight, math::pi / 18, "0", 0, true);
|
||||
p->drawText(fontDesc, m2::PointD(40, 50), yg::EPosAboveRight, math::pi / 18, "Simplicity is the ultimate sophistication", 0, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -533,7 +535,8 @@ namespace
|
|||
{
|
||||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, 0, 20, yg::Color(0, 0, 0, 0), "X", true, yg::Color(255, 255, 255, 255), 1, false, true);
|
||||
yg::FontDesc fontDesc(false, 20, yg::Color(0, 0, 0, 0), true, yg::Color(255, 255, 255, 255));
|
||||
p->drawText(fontDesc, m2::PointD(40, 50), yg::EPosAboveRight, 0, "X", 1, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -541,7 +544,8 @@ namespace
|
|||
{
|
||||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, 0, 20, yg::Color(0, 0, 0, 0), " ", true, yg::Color(255, 255, 255, 255), 1, false, true);
|
||||
yg::FontDesc fontDesc(false, 20, yg::Color(0, 0, 0, 0), true, yg::Color(255, 255, 255, 255));
|
||||
p->drawText(fontDesc, m2::PointD(40, 50), yg::EPosAboveRight, 0, " ", 1, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -552,9 +556,11 @@ namespace
|
|||
size_t const maxTimes = 10;
|
||||
size_t const yStep = 30;
|
||||
|
||||
yg::FontDesc fontDesc(false, 20, yg::Color(0, 0, 0, 0), true, yg::Color(255, 255, 255, 255));
|
||||
|
||||
for (size_t i = 0; i < maxTimes; ++i)
|
||||
for (size_t j = 1; j <= i+1; ++j)
|
||||
p->drawText(m2::PointD(40, 10 + yStep * i), yg::EPosAboveRight, math::pi / 6, 20, yg::Color(0, 0, 0, 0), "Simplicity is the ultimate sophistication", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
p->drawText(fontDesc, m2::PointD(40, 10 + yStep * i), yg::EPosAboveRight, math::pi / 6, "Simplicity is the ultimate sophistication", 0, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -570,7 +576,9 @@ namespace
|
|||
yg::PenInfo penInfo = yg::PenInfo(yg::Color(0, 0, 0, 0xFF), 2, &pat[0], ARRAY_SIZE(pat), 0);
|
||||
yg::PenInfo solidPenInfo = yg::PenInfo(yg::Color(0xFF, 0, 0, 0xFF), 4, 0, 0, 0);
|
||||
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, 0, 20, yg::Color(0, 0, 0, 0), "S", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
yg::FontDesc fontDesc(false, 20, yg::Color(0, 0, 0, 0), true, yg::Color(255, 255, 255, 255));
|
||||
|
||||
p->drawText(fontDesc, m2::PointD(40, 50), yg::EPosAboveRight, 0, "S", 0, true);
|
||||
p->drawPath(&path[0], path.size(), p->skin()->mapPenInfo(solidPenInfo), 0);
|
||||
|
||||
}
|
||||
|
@ -580,7 +588,8 @@ namespace
|
|||
{
|
||||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, 0/*, math::pi / 18*/, 20, yg::Color(0, 0, 0, 0), "Simplicity is the ultimate sophistication", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
yg::FontDesc fontDesc(false, 20, yg::Color(0, 0, 0, 0), true, yg::Color(255, 255, 255, 255));
|
||||
p->drawText(fontDesc, m2::PointD(40, 50), yg::EPosAboveRight, 0/*, math::pi / 18*/, "Simplicity is the ultimate sophistication", 0, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -588,7 +597,7 @@ namespace
|
|||
{
|
||||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, 0/*, math::pi / 18*/, 12, yg::Color(0, 0, 0, 0), "Simplicity is the ultimate sophistication", true, yg::Color(255, 255, 255, 255), 0, true, true);
|
||||
p->drawText(yg::FontDesc::defaultFont, m2::PointD(40, 50), yg::EPosAboveRight, 0/*, math::pi / 18*/, "Simplicity is the ultimate sophistication", 0, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -596,7 +605,8 @@ namespace
|
|||
{
|
||||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, 0/*, math::pi / 18*/, 25, yg::Color(0, 0, 255, 255), "Simplicity is the ultimate sophistication", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
yg::FontDesc fontDesc(false, 25, yg::Color(0, 0, 255, 255), true, yg::Color(255, 255, 255, 255));
|
||||
p->drawText(fontDesc, m2::PointD(40, 50), yg::EPosAboveRight, 0/*, math::pi / 18*/, "Simplicity is the ultimate sophistication", 0, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -605,8 +615,9 @@ namespace
|
|||
{
|
||||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
p->drawText(m2::PointD(40, 50), yg::EPosAboveRight, 0, 12, yg::Color(0, 0, 0, 0), "Latin Symbol : A", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
p->drawText(m2::PointD(40, 80), yg::EPosAboveRight, 0, 12, yg::Color(0, 0, 0, 0), "Cyrillic Symbol : Ы", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
yg::FontDesc fontDesc(false, 12);
|
||||
p->drawText(fontDesc, m2::PointD(40, 50), yg::EPosAboveRight, 0, "Latin Symbol : A", 0, true);
|
||||
p->drawText(fontDesc, m2::PointD(40, 80), yg::EPosAboveRight, 0, "Cyrillic Symbol : Ы", 0, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -615,7 +626,7 @@ namespace
|
|||
typedef TestDrawStringWithFixedFont base_t;
|
||||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
m2::RectD r = p->textRect("Simplicity is the ultimate sophistication", 12, true, true, false);
|
||||
m2::RectD r = p->textRect(yg::FontDesc::defaultFont, "Simplicity is the ultimate sophistication", false);
|
||||
|
||||
m2::PointD startPt(40, 50);
|
||||
|
||||
|
@ -664,7 +675,8 @@ namespace
|
|||
void DoDraw(shared_ptr<yg::gl::Screen> p)
|
||||
{
|
||||
p->drawPath(&m_path[0], m_path.size(), p->skin()->mapPenInfo(m_penInfo), 0);
|
||||
p->drawPathText(&m_path[0], m_path.size(), 10, yg::Color(0, 0, 0, 0), m_text, calc_length(m_path), 0.0, yg::gl::Screen::middle_line, true, yg::Color(255, 255, 255, 255), 0, false);
|
||||
yg::FontDesc fontDesc(false, 10);
|
||||
p->drawPathText(fontDesc, &m_path[0], m_path.size(), m_text, calc_length(m_path), 0.0, yg::gl::Screen::middle_line, 0);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -675,8 +687,10 @@ namespace
|
|||
p->drawPath(&m_path[0], m_path.size(), p->skin()->mapPenInfo(m_penInfo), 0);
|
||||
|
||||
double const len = calc_length(m_path);
|
||||
p->drawPathText(&m_path[0], m_path.size(), 10, yg::Color(0, 0, 0, 0), m_text, len, 0.0, yg::gl::Screen::above_line, true, yg::Color(255, 255, 255, 255), 0, false);
|
||||
p->drawPathText(&m_path[0], m_path.size(), 10, yg::Color(0, 0, 0, 0), m_text, len, 0.0, yg::gl::Screen::under_line, true, yg::Color(255, 255, 255, 255), 0, false);
|
||||
yg::FontDesc fontDesc(false, 10);
|
||||
|
||||
p->drawPathText(fontDesc, &m_path[0], m_path.size(), m_text, len, 0.0, yg::gl::Screen::above_line, 0);
|
||||
p->drawPathText(fontDesc, &m_path[0], m_path.size(), m_text, len, 0.0, yg::gl::Screen::under_line, 0);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -690,8 +704,9 @@ namespace
|
|||
int startY = 30;
|
||||
for (size_t i = 0; i < sizesCount; ++i)
|
||||
{
|
||||
p->drawText(m2::PointD(10, startY), yg::EPosAboveRight, 0, startSize + i, yg::Color(0, 0, 0, 0), "Simplicity is the ultimate sophistication. Leonardo Da Vinci", true, yg::Color(255, 255, 255, 255), 0, false, true);
|
||||
startY += startSize + i;
|
||||
yg::FontDesc fontDesc(false, startSize + i);
|
||||
p->drawText(fontDesc, m2::PointD(10, startY), yg::EPosAboveRight, 0, "Simplicity is the ultimate sophistication. Leonardo Da Vinci", 0, true);
|
||||
startY += fontDesc.m_size;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -706,8 +721,9 @@ namespace
|
|||
int startY = 30;
|
||||
for (size_t i = 0; i < sizesCount; ++i)
|
||||
{
|
||||
p->drawText(m2::PointD(10, startY), yg::EPosAboveRight, 0, startSize/* + i*/, yg::Color(0, 0, 0, 0), "Simplicity is the ultimate sophistication. Leonardo Da Vinci", true, yg::Color(255, 255, 255, 255), 100, false, true);
|
||||
p->drawText(m2::PointD(5, startY + (startSize + i) / 2), yg::EPosAboveRight, 0, startSize/* + i*/, yg::Color(0, 0, 0, 0), "This text should be filtered", true, yg::Color(255, 255, 255, 255), 100, false, true);
|
||||
yg::FontDesc fontDesc(false, startSize);
|
||||
p->drawText(fontDesc, m2::PointD(10, startY), yg::EPosAboveRight, 0, "Simplicity is the ultimate sophistication. Leonardo Da Vinci", 100, true);
|
||||
p->drawText(fontDesc, m2::PointD(5, startY + (startSize + i) / 2), yg::EPosAboveRight, 0, "This text should be filtered", 100, true);
|
||||
startY += startSize + i;
|
||||
}
|
||||
}
|
||||
|
@ -725,18 +741,20 @@ namespace
|
|||
int textsCount = 200;
|
||||
|
||||
for (int i = 0; i < textsCount; ++i)
|
||||
{
|
||||
yg::FontDesc fontDesc(false,
|
||||
rand() % (endSize - startSize) + startSize,
|
||||
yg::Color(rand() % 255, rand() % 255, rand() % 255, 255)
|
||||
);
|
||||
p->drawText(
|
||||
m2::PointD(rand() % 500, rand() % 500),
|
||||
yg::EPosAboveRight,
|
||||
0,
|
||||
rand() % (endSize - startSize) + startSize,
|
||||
yg::Color(rand() % 255, rand() % 255, rand() % 255, 255),
|
||||
texts[rand() % (sizeof(texts) / sizeof(char*))],
|
||||
true,
|
||||
yg::Color(255, 255, 255, 255),
|
||||
rand() % 10,
|
||||
false,
|
||||
true);
|
||||
fontDesc,
|
||||
m2::PointD(rand() % 500, rand() % 500),
|
||||
yg::EPosAboveRight,
|
||||
0,
|
||||
texts[rand() % (sizeof(texts) / sizeof(char*))],
|
||||
rand() % 10,
|
||||
true);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -937,21 +955,21 @@ namespace
|
|||
};
|
||||
|
||||
// UNIT_TEST_GL(TestDrawPolyOverflow);
|
||||
// UNIT_TEST_GL(TestDrawText);
|
||||
UNIT_TEST_GL(TestDrawText);
|
||||
// UNIT_TEST_GL(TestDrawSingleSymbol);
|
||||
// UNIT_TEST_GL(TestDrawEmptySymbol);
|
||||
// UNIT_TEST_GL(TestDrawSingleSymbolAndSolidPath);
|
||||
// UNIT_TEST_GL(TestDrawString);
|
||||
// UNIT_TEST_GL(TestDrawStringWithFixedFont);
|
||||
// UNIT_TEST_GL(TestDrawStringWithColor);
|
||||
// UNIT_TEST_GL(TestDrawUnicodeSymbols);
|
||||
// UNIT_TEST_GL(TestDrawTextRectWithFixedFont);
|
||||
// UNIT_TEST_GL(TestDrawStringOnString);
|
||||
// UNIT_TEST_GL(TestDrawTextOnPath);
|
||||
// UNIT_TEST_GL(TestDrawTextOnPathWithOffset);
|
||||
// UNIT_TEST_GL(TestDrawTextOverflow);
|
||||
// UNIT_TEST_GL(TestDrawTextFiltering);
|
||||
// UNIT_TEST_GL(TestDrawRandomTextFiltering);
|
||||
UNIT_TEST_GL(TestDrawString);
|
||||
UNIT_TEST_GL(TestDrawStringWithFixedFont);
|
||||
UNIT_TEST_GL(TestDrawStringWithColor);
|
||||
UNIT_TEST_GL(TestDrawUnicodeSymbols);
|
||||
UNIT_TEST_GL(TestDrawTextRectWithFixedFont);
|
||||
UNIT_TEST_GL(TestDrawStringOnString);
|
||||
UNIT_TEST_GL(TestDrawTextOnPath);
|
||||
UNIT_TEST_GL(TestDrawTextOnPathWithOffset);
|
||||
UNIT_TEST_GL(TestDrawTextOverflow);
|
||||
UNIT_TEST_GL(TestDrawTextFiltering);
|
||||
UNIT_TEST_GL(TestDrawRandomTextFiltering);
|
||||
// UNIT_TEST_GL(TestDrawSGIConvex);
|
||||
// UNIT_TEST_GL(TestDrawPoly);
|
||||
// UNIT_TEST_GL(TestDrawSolidRect);
|
||||
|
@ -962,7 +980,7 @@ namespace
|
|||
// UNIT_TEST_GL(TestDrawPathSolid2PX);
|
||||
// UNIT_TEST_GL(TestDrawPathSolid);
|
||||
// UNIT_TEST_GL(TestDrawSector);
|
||||
UNIT_TEST_GL(TestDrawPathSolidDiffWidth);
|
||||
// UNIT_TEST_GL(TestDrawPathSolidDiffWidth);
|
||||
// UNIT_TEST_GL(TestDrawPathSolidWithZ);
|
||||
// UNIT_TEST_GL(TestDrawPathSolidWithClipRect);
|
||||
// UNIT_TEST_GL(TestDrawUtilsRect);
|
||||
|
|
Loading…
Add table
Reference in a new issue