mirror of
https://github.com/overte-org/overte.git
synced 2025-04-06 10:12:56 +02:00
Merge pull request #1247 from Armored-Dragon/fix/system_display_name
Fix ShowRecieveStats in the Developer > Avatar menu
This commit is contained in:
commit
965ee1537b
4 changed files with 20 additions and 21 deletions
|
@ -994,9 +994,9 @@ void Avatar::renderDisplayName(gpu::Batch& batch, const ViewFrustum& view, const
|
||||||
|
|
||||||
QString statsFormat = QString("(%1 Kbps, %2 Hz)");
|
QString statsFormat = QString("(%1 Kbps, %2 Hz)");
|
||||||
if (!renderedDisplayName.isEmpty()) {
|
if (!renderedDisplayName.isEmpty()) {
|
||||||
statsFormat.prepend(" - ");
|
statsFormat.append("\n");
|
||||||
}
|
}
|
||||||
renderedDisplayName += statsFormat.arg(QString::number(kilobitsPerSecond, 'f', 2)).arg(getReceiveRate());
|
renderedDisplayName = statsFormat.arg(QString::number(kilobitsPerSecond, 'f', 2)).arg(getReceiveRate()) + renderedDisplayName;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Compute display name extent/position offset
|
// Compute display name extent/position offset
|
||||||
|
@ -1010,18 +1010,18 @@ void Avatar::renderDisplayName(gpu::Batch& batch, const ViewFrustum& view, const
|
||||||
// Compute background position/size
|
// Compute background position/size
|
||||||
static const float SLIGHTLY_IN_FRONT = 0.1f;
|
static const float SLIGHTLY_IN_FRONT = 0.1f;
|
||||||
static const float BORDER_RELATIVE_SIZE = 0.1f;
|
static const float BORDER_RELATIVE_SIZE = 0.1f;
|
||||||
static const float BEVEL_FACTOR = 0.1f;
|
// static const float BEVEL_FACTOR = 0.1f;
|
||||||
const int border = BORDER_RELATIVE_SIZE * nameDynamicRect.height();
|
const int border = BORDER_RELATIVE_SIZE * nameDynamicRect.height();
|
||||||
const int left = text_x - border;
|
// FIXME: Beveled box is broken
|
||||||
const int bottom = text_y - border;
|
// const int left = text_x - border;
|
||||||
const int width = nameDynamicRect.width() + 2.0f * border;
|
// const int bottom = text_y - border;
|
||||||
|
// const int width = nameDynamicRect.width() + 2.0f * border;
|
||||||
const int height = nameDynamicRect.height() + 2.0f * border;
|
const int height = nameDynamicRect.height() + 2.0f * border;
|
||||||
const int bevelDistance = BEVEL_FACTOR * height;
|
// const int bevelDistance = BEVEL_FACTOR * height;
|
||||||
|
|
||||||
// Display name and background colors
|
// Display name and background colors
|
||||||
glm::vec4 textColor(0.93f, 0.93f, 0.93f, _displayNameAlpha);
|
glm::vec4 textColor(0.93f, 0.93f, 0.93f, _displayNameAlpha);
|
||||||
glm::vec4 backgroundColor(0.2f, 0.2f, 0.2f,
|
glm::vec4 backgroundColor(0.2f, 0.2f, 0.2f,(_displayNameAlpha / DISPLAYNAME_ALPHA) * DISPLAYNAME_BACKGROUND_ALPHA);
|
||||||
(_displayNameAlpha / DISPLAYNAME_ALPHA) * DISPLAYNAME_BACKGROUND_ALPHA);
|
|
||||||
|
|
||||||
// Compute display name transform
|
// Compute display name transform
|
||||||
auto textTransform = calculateDisplayNameTransform(view, textPosition);
|
auto textTransform = calculateDisplayNameTransform(view, textPosition);
|
||||||
|
@ -1029,12 +1029,11 @@ void Avatar::renderDisplayName(gpu::Batch& batch, const ViewFrustum& view, const
|
||||||
textTransform.postScale(1.0f / height);
|
textTransform.postScale(1.0f / height);
|
||||||
batch.setModelTransform(textTransform);
|
batch.setModelTransform(textTransform);
|
||||||
|
|
||||||
{
|
// {
|
||||||
PROFILE_RANGE_BATCH(batch, __FUNCTION__":renderBevelCornersRect");
|
// PROFILE_RANGE_BATCH(batch, __FUNCTION__":renderBevelCornersRect");
|
||||||
DependencyManager::get<GeometryCache>()->bindSimpleProgram(batch, false, false, true, true, true, forward);
|
// DependencyManager::get<GeometryCache>()->bindSimpleProgram(batch, false, false, true, true, true, forward);
|
||||||
DependencyManager::get<GeometryCache>()->renderBevelCornersRect(batch, left, bottom, width, height,
|
// DependencyManager::get<GeometryCache>()->renderBevelCornersRect(batch, left, bottom, width, height, bevelDistance, backgroundColor, _nameRectGeometryID);
|
||||||
bevelDistance, backgroundColor, _nameRectGeometryID);
|
// }
|
||||||
}
|
|
||||||
|
|
||||||
// Render actual name
|
// Render actual name
|
||||||
QByteArray nameUTF8 = renderedDisplayName.toLocal8Bit();
|
QByteArray nameUTF8 = renderedDisplayName.toLocal8Bit();
|
||||||
|
@ -1044,7 +1043,7 @@ void Avatar::renderDisplayName(gpu::Batch& batch, const ViewFrustum& view, const
|
||||||
batch.setModelTransform(textTransform);
|
batch.setModelTransform(textTransform);
|
||||||
{
|
{
|
||||||
PROFILE_RANGE_BATCH(batch, __FUNCTION__":renderText");
|
PROFILE_RANGE_BATCH(batch, __FUNCTION__":renderText");
|
||||||
displayNameRenderer->draw(batch, { nameUTF8.data(), textColor, { text_x, -text_y }, glm::vec2(-1.0f), forward });
|
displayNameRenderer->draw(batch, { nameUTF8.data(), textColor, { text_x, -text_y }, glm::vec2(-1.0f), TextAlignment::LEFT, forward });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -95,8 +95,8 @@ vec4 evalSDFColor(vec2 texCoord, vec4 glyphBounds) {
|
||||||
|
|
||||||
vec4 evalSDFSuperSampled(vec2 texCoord, vec2 positionMS, vec4 glyphBounds) {
|
vec4 evalSDFSuperSampled(vec2 texCoord, vec2 positionMS, vec4 glyphBounds) {
|
||||||
// Clip to edges. Note: We don't need to check the top edge.
|
// Clip to edges. Note: We don't need to check the top edge.
|
||||||
if (positionMS.x < params.bounds.x || positionMS.x > (params.bounds.x + params.bounds.z) ||
|
if ((params.bounds.z > 0.0 && (positionMS.x < params.bounds.x || positionMS.x > (params.bounds.x + params.bounds.z))) ||
|
||||||
positionMS.y < params.bounds.y - params.bounds.w) {
|
(params.bounds.w > 0.0 && (positionMS.y < params.bounds.y - params.bounds.w))) {
|
||||||
return vec4(0.0);
|
return vec4(0.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -438,7 +438,7 @@ void Font::buildVertices(Font::DrawInfo& drawInfo, const QString& str, const glm
|
||||||
|
|
||||||
// Draw the token
|
// Draw the token
|
||||||
for (const QChar& c : token) {
|
for (const QChar& c : token) {
|
||||||
if (advance.x > rightEdge) {
|
if (bounds.x != -1 && advance.x > rightEdge) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
const Glyph& glyph = _glyphs[c];
|
const Glyph& glyph = _glyphs[c];
|
||||||
|
|
|
@ -71,8 +71,8 @@ public:
|
||||||
bool forward, bool mirror) :
|
bool forward, bool mirror) :
|
||||||
str(str), color(color), effectColor(effectColor), origin(origin), bounds(bounds), scale(scale), effectThickness(effectThickness),
|
str(str), color(color), effectColor(effectColor), origin(origin), bounds(bounds), scale(scale), effectThickness(effectThickness),
|
||||||
effect(effect), alignment(alignment), verticalAlignment(verticalAlignment), unlit(unlit), forward(forward), mirror(mirror) {}
|
effect(effect), alignment(alignment), verticalAlignment(verticalAlignment), unlit(unlit), forward(forward), mirror(mirror) {}
|
||||||
DrawProps(const QString& str, const glm::vec4& color, const glm::vec2& origin, const glm::vec2& bounds, bool forward) :
|
DrawProps(const QString& str, const glm::vec4& color, const glm::vec2& origin, const glm::vec2& bounds, TextAlignment alignment, bool forward) :
|
||||||
str(str), color(color), origin(origin), bounds(bounds), forward(forward) {}
|
str(str), color(color), origin(origin), bounds(bounds), alignment(alignment), forward(forward) {}
|
||||||
|
|
||||||
const QString& str;
|
const QString& str;
|
||||||
const glm::vec4& color;
|
const glm::vec4& color;
|
||||||
|
|
Loading…
Reference in a new issue