本文整理汇总了C++中FontFace::HasMutableGlyphs方法的典型用法代码示例。如果您正苦于以下问题:C++ FontFace::HasMutableGlyphs方法的具体用法?C++ FontFace::HasMutableGlyphs怎么用?C++ FontFace::HasMutableGlyphs使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类FontFace
的用法示例。
在下文中一共展示了FontFace::HasMutableGlyphs方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: GetBatches
void Text::GetBatches(ea::vector<UIBatch>& batches, ea::vector<float>& vertexData, const IntRect& currentScissor)
{
FontFace* face = font_ ? font_->GetFace(fontSize_) : nullptr;
if (!face)
{
hovering_ = false;
return;
}
// If face has changed or char locations are not valid anymore, update before rendering
if (charLocationsDirty_ || !fontFace_ || face != fontFace_)
UpdateCharLocations();
// If face uses mutable glyphs mechanism, reacquire glyphs before rendering to make sure they are in the texture
else if (face->HasMutableGlyphs())
{
for (unsigned i = 0; i < printText_.size(); ++i)
face->GetGlyph(printText_[i]);
}
// Hovering and/or whole selection batch
UISelectable::GetBatches(batches, vertexData, currentScissor);
// Partial selection batch
if (!selected_ && selectionLength_ && charLocations_.size() >= selectionStart_ + selectionLength_ && selectionColor_.a_ > 0.0f)
{
UIBatch batch(this, BLEND_ALPHA, currentScissor, nullptr, &vertexData);
batch.SetColor(selectionColor_);
Vector2 currentStart = charLocations_[selectionStart_].position_;
Vector2 currentEnd = currentStart;
for (unsigned i = selectionStart_; i < selectionStart_ + selectionLength_; ++i)
{
// Check if row changes, and start a new quad in that case
if (charLocations_[i].size_ != Vector2::ZERO)
{
if (charLocations_[i].position_.y_ != currentStart.y_)
{
batch.AddQuad(currentStart.x_, currentStart.y_, currentEnd.x_ - currentStart.x_,
currentEnd.y_ - currentStart.y_, 0, 0);
currentStart = charLocations_[i].position_;
currentEnd = currentStart + charLocations_[i].size_;
}
else
{
currentEnd.x_ += charLocations_[i].size_.x_;
currentEnd.y_ = Max(currentStart.y_ + charLocations_[i].size_.y_, currentEnd.y_);
}
}
}
if (currentEnd != currentStart)
{
batch.AddQuad(currentStart.x_, currentStart.y_, currentEnd.x_ - currentStart.x_, currentEnd.y_ - currentStart.y_, 0, 0);
}
UIBatch::AddOrMerge(batch, batches);
}
// Text batch
TextEffect textEffect = font_->IsSDFFont() ? TE_NONE : textEffect_;
const ea::vector<ea::shared_ptr<Texture2D> >& textures = face->GetTextures();
for (unsigned n = 0; n < textures.size() && n < pageGlyphLocations_.size(); ++n)
{
// One batch per texture/page
UIBatch pageBatch(this, BLEND_ALPHA, currentScissor, textures[n], &vertexData);
const ea::vector<GlyphLocation>& pageGlyphLocation = pageGlyphLocations_[n];
switch (textEffect)
{
case TE_NONE:
ConstructBatch(pageBatch, pageGlyphLocation, 0, 0);
break;
case TE_SHADOW:
ConstructBatch(pageBatch, pageGlyphLocation, shadowOffset_.x_, shadowOffset_.y_, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 0, 0);
break;
case TE_STROKE:
if (roundStroke_)
{
// Samples should be even or glyph may be redrawn in wrong x y pos making stroke corners rough
// Adding to thickness helps with thickness of 1 not having enought samples for this formula
// or certain fonts with reflex corners requiring more glyph samples for a smooth stroke when large
int thickness = Min(strokeThickness_, fontSize_);
int samples = thickness * thickness + (thickness % 2 == 0 ? 4 : 3);
float angle = 360.f / samples;
auto floatThickness = (float)thickness;
for (int i = 0; i < samples; ++i)
{
float x = Cos(angle * i) * floatThickness;
float y = Sin(angle * i) * floatThickness;
ConstructBatch(pageBatch, pageGlyphLocation, x, y, &effectColor_, effectDepthBias_);
}
}
else
{
int thickness = Min(strokeThickness_, fontSize_);
int x, y;
for (x = -thickness; x <= thickness; ++x)
//.........这里部分代码省略.........
示例2: GetBatches
void Text::GetBatches(PODVector<UIBatch>& batches, PODVector<float>& vertexData, const IntRect& currentScissor)
{
FontFace* face = font_ ? font_->GetFace(fontSize_) : (FontFace*)0;
if (!face)
{
hovering_ = false;
return;
}
// If face has changed or char locations are not valid anymore, update before rendering
if (charLocationsDirty_ || !fontFace_ || face != fontFace_)
UpdateCharLocations();
// If face uses mutable glyphs mechanism, reacquire glyphs before rendering to make sure they are in the texture
else if (face->HasMutableGlyphs())
{
for (unsigned i = 0; i < printText_.Size(); ++i)
face->GetGlyph(printText_[i]);
}
// Hovering and/or whole selection batch
if ((hovering_ && hoverColor_.a_ > 0.0) || (selected_ && selectionColor_.a_ > 0.0f))
{
bool both = hovering_ && selected_ && hoverColor_.a_ > 0.0 && selectionColor_.a_ > 0.0f;
UIBatch batch(this, BLEND_ALPHA, currentScissor, 0, &vertexData);
batch.SetColor(both ? selectionColor_.Lerp(hoverColor_, 0.5f) :
(selected_ && selectionColor_.a_ > 0.0f ? selectionColor_ : hoverColor_));
batch.AddQuad(0, 0, GetWidth(), GetHeight(), 0, 0);
UIBatch::AddOrMerge(batch, batches);
}
// Partial selection batch
if (!selected_ && selectionLength_ && charLocations_.Size() >= selectionStart_ + selectionLength_ && selectionColor_.a_ > 0.0f)
{
UIBatch batch(this, BLEND_ALPHA, currentScissor, 0, &vertexData);
batch.SetColor(selectionColor_);
IntVector2 currentStart = charLocations_[selectionStart_].position_;
IntVector2 currentEnd = currentStart;
for (unsigned i = selectionStart_; i < selectionStart_ + selectionLength_; ++i)
{
// Check if row changes, and start a new quad in that case
if (charLocations_[i].size_ != IntVector2::ZERO)
{
if (charLocations_[i].position_.y_ != currentStart.y_)
{
batch.AddQuad(currentStart.x_, currentStart.y_, currentEnd.x_ - currentStart.x_,
currentEnd.y_ - currentStart.y_, 0, 0);
currentStart = charLocations_[i].position_;
currentEnd = currentStart + charLocations_[i].size_;
}
else
{
currentEnd.x_ += charLocations_[i].size_.x_;
currentEnd.y_ = Max(currentStart.y_ + charLocations_[i].size_.y_, currentEnd.y_);
}
}
}
if (currentEnd != currentStart)
{
batch.AddQuad(currentStart.x_, currentStart.y_, currentEnd.x_ - currentStart.x_, currentEnd.y_ - currentStart.y_, 0, 0);
}
UIBatch::AddOrMerge(batch, batches);
}
// Text batch
TextEffect textEffect = font_->IsSDFFont() ? TE_NONE : textEffect_;
const Vector<SharedPtr<Texture2D> >& textures = face->GetTextures();
for (unsigned n = 0; n < textures.Size() && n < pageGlyphLocations_.Size(); ++n)
{
// One batch per texture/page
UIBatch pageBatch(this, BLEND_ALPHA, currentScissor, textures[n], &vertexData);
const PODVector<GlyphLocation>& pageGlyphLocation = pageGlyphLocations_[n];
switch (textEffect)
{
case TE_NONE:
ConstructBatch(pageBatch, pageGlyphLocation, 0, 0);
break;
case TE_SHADOW:
ConstructBatch(pageBatch, pageGlyphLocation, 1, 1, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 0, 0);
break;
case TE_STROKE:
ConstructBatch(pageBatch, pageGlyphLocation, -1, -1, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 0, -1, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 1, -1, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, -1, 0, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 1, 0, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, -1, 1, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 0, 1, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 1, 1, &effectColor_, effectDepthBias_);
ConstructBatch(pageBatch, pageGlyphLocation, 0, 0);
break;
}
UIBatch::AddOrMerge(pageBatch, batches);
//.........这里部分代码省略.........