Working on removing ui label
This commit is contained in:
@ -15,86 +15,90 @@ VNTextboxScroller::VNTextboxScroller(SceneItem *item) :
|
|||||||
}
|
}
|
||||||
|
|
||||||
void VNTextboxScroller::onStart() {
|
void VNTextboxScroller::onStart() {
|
||||||
assertNotNull(label);
|
// assertNotNull(label);
|
||||||
|
|
||||||
std::function<void()> x = [&]{
|
// std::function<void()> x = [&]{
|
||||||
this->lineCurrent = 0;
|
// this->lineCurrent = 0;
|
||||||
this->timeCharacter = 0;
|
// this->timeCharacter = 0;
|
||||||
this->label->startQuad = 0;
|
// this->label->startQuad = 0;
|
||||||
this->label->quadCount = 0;
|
// this->label->quadCount = 0;
|
||||||
this->readyToClose = false;
|
// this->readyToClose = false;
|
||||||
};
|
// };
|
||||||
x();
|
// x();
|
||||||
|
|
||||||
useEvent(x, this->label->eventTextChanged);
|
// useEvent(x, this->label->eventTextChanged);
|
||||||
|
|
||||||
useEvent([&](float_t delta){
|
// useEvent([&](float_t delta){
|
||||||
auto game = this->getGame();
|
// auto game = this->getGame();
|
||||||
|
|
||||||
this->timeCharacter += delta;
|
// this->timeCharacter += delta;
|
||||||
if(this->hasRevealedAllCurrentCharacters()) {
|
// if(this->hasRevealedAllCurrentCharacters()) {
|
||||||
if(this->hasRevealedAllCharacters()) {
|
// if(this->hasRevealedAllCharacters()) {
|
||||||
if(!this->readyToClose) {
|
// if(!this->readyToClose) {
|
||||||
this->readyToClose = true;
|
// this->readyToClose = true;
|
||||||
this->eventReadyToClose.invoke();
|
// this->eventReadyToClose.invoke();
|
||||||
}
|
// }
|
||||||
} else {
|
// } else {
|
||||||
if(game->inputManager.isPressed(INPUT_BIND_ACCEPT)) {
|
// if(game->inputManager.isPressed(INPUT_BIND_ACCEPT)) {
|
||||||
this->lineCurrent += this->getCountOfVisibleLines();
|
// this->lineCurrent += this->getCountOfVisibleLines();
|
||||||
this->label->startQuad = 0;
|
// this->label->startQuad = 0;
|
||||||
for(int32_t i = 0; i < this->lineCurrent; i++) {
|
// for(int32_t i = 0; i < this->lineCurrent; i++) {
|
||||||
this->label->startQuad += this->label->measure.getQuadsOnLine(i);
|
// this->label->startQuad += this->label->measure.getQuadsOnLine(i);
|
||||||
}
|
// }
|
||||||
this->label->quadCount = 0;
|
// this->label->quadCount = 0;
|
||||||
this->timeCharacter = 0.0f;
|
// this->timeCharacter = 0.0f;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
return;
|
// return;
|
||||||
}
|
// }
|
||||||
|
|
||||||
auto lastTimeCharacter = mathFloor<int32_t>(this->timeCharacter);
|
// auto lastTimeCharacter = mathFloor<int32_t>(this->timeCharacter);
|
||||||
if(game->inputManager.isDown(INPUT_BIND_ACCEPT)) {
|
// if(game->inputManager.isDown(INPUT_BIND_ACCEPT)) {
|
||||||
this->timeCharacter += game->timeManager.delta * VN_TEXTBOX_SPEED_FASTER;
|
// this->timeCharacter += game->timeManager.delta * VN_TEXTBOX_SPEED_FASTER;
|
||||||
} else {
|
// } else {
|
||||||
this->timeCharacter += game->timeManager.delta * VN_TEXTBOX_SPEED;
|
// this->timeCharacter += game->timeManager.delta * VN_TEXTBOX_SPEED;
|
||||||
}
|
// }
|
||||||
|
|
||||||
auto newCount = mathFloor<int32_t>(this->timeCharacter);
|
// auto newCount = mathFloor<int32_t>(this->timeCharacter);
|
||||||
if(newCount == this->label->quadCount) return;
|
// if(newCount == this->label->quadCount) return;
|
||||||
this->label->quadCount = mathFloor<int32_t>(this->timeCharacter);
|
// this->label->quadCount = mathFloor<int32_t>(this->timeCharacter);
|
||||||
this->eventCharacterRevealed.invoke();
|
// this->eventCharacterRevealed.invoke();
|
||||||
}, getScene()->eventSceneUpdate);
|
// }, getScene()->eventSceneUpdate);
|
||||||
|
assertUnreachable();
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t VNTextboxScroller::getCountOfVisibleLines() {
|
size_t VNTextboxScroller::getCountOfVisibleLines() {
|
||||||
float_t y = this->label->getHeight();
|
// float_t y = this->label->getHeight();
|
||||||
size_t i = 1;
|
// size_t i = 1;
|
||||||
for(i = this->label->measure.getLineCount(); i > 0; --i) {
|
// for(i = this->label->measure.getLineCount(); i > 0; --i) {
|
||||||
if(y >= this->label->measure.getHeightOfLineCount(i)) {
|
// if(y >= this->label->measure.getHeightOfLineCount(i)) {
|
||||||
return i;
|
// return i;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
return this->label->measure.getLineCount();
|
// return this->label->measure.getLineCount();
|
||||||
|
assertUnreachable();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool_t VNTextboxScroller::hasRevealedAllCurrentCharacters() {
|
bool_t VNTextboxScroller::hasRevealedAllCurrentCharacters() {
|
||||||
int32_t quadsTotal = 0;
|
// int32_t quadsTotal = 0;
|
||||||
for(
|
// for(
|
||||||
size_t i = this->lineCurrent;
|
// size_t i = this->lineCurrent;
|
||||||
i < mathMin<size_t>(
|
// i < mathMin<size_t>(
|
||||||
this->label->measure.getLineCount(),
|
// this->label->measure.getLineCount(),
|
||||||
this->lineCurrent + this->getCountOfVisibleLines()
|
// this->lineCurrent + this->getCountOfVisibleLines()
|
||||||
);
|
// );
|
||||||
i++
|
// i++
|
||||||
) {
|
// ) {
|
||||||
quadsTotal += this->label->measure.getQuadsOnLine(i);
|
// quadsTotal += this->label->measure.getQuadsOnLine(i);
|
||||||
}
|
// }
|
||||||
return mathFloor<int32_t>(this->timeCharacter) >= quadsTotal;
|
// return mathFloor<int32_t>(this->timeCharacter) >= quadsTotal;
|
||||||
|
assertUnreachable();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool_t VNTextboxScroller::hasRevealedAllCharacters() {
|
bool_t VNTextboxScroller::hasRevealedAllCharacters() {
|
||||||
return (
|
// return (
|
||||||
this->lineCurrent + this->getCountOfVisibleLines() >=
|
// this->lineCurrent + this->getCountOfVisibleLines() >=
|
||||||
this->label->measure.getLineCount()
|
// this->label->measure.getLineCount()
|
||||||
);
|
// );
|
||||||
|
assertUnreachable();
|
||||||
}
|
}
|
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "scene/SceneItemComponent.hpp"
|
#include "scene/SceneItemComponent.hpp"
|
||||||
#include "scene/components/ui/UILabel.hpp"
|
#include "scene/components/ui/text/UILabelNew.hpp"
|
||||||
#include "input/InputManager.hpp"
|
#include "input/InputManager.hpp"
|
||||||
|
|
||||||
#define VN_TEXTBOX_SPEED 25.0f
|
#define VN_TEXTBOX_SPEED 25.0f
|
||||||
@ -15,7 +15,7 @@ namespace Dawn {
|
|||||||
class VNTextboxScroller : public SceneItemComponent {
|
class VNTextboxScroller : public SceneItemComponent {
|
||||||
public:
|
public:
|
||||||
// @optional
|
// @optional
|
||||||
StateProperty<UILabel*> label;
|
StateProperty<UILabelNew*> label;
|
||||||
|
|
||||||
StateEvent<> eventReadyToClose;
|
StateEvent<> eventReadyToClose;
|
||||||
StateEvent<> eventCharacterRevealed;
|
StateEvent<> eventCharacterRevealed;
|
||||||
|
@ -20,7 +20,8 @@ namespace Dawn {
|
|||||||
scroller = this->getScene()->findComponent<VNTextboxScroller>();
|
scroller = this->getScene()->findComponent<VNTextboxScroller>();
|
||||||
assertNotNull(scroller);
|
assertNotNull(scroller);
|
||||||
|
|
||||||
scroller->label->text = text;
|
assertUnreachable();
|
||||||
|
// scroller->label->text = text;
|
||||||
|
|
||||||
useEvent([&](inputbind_t bind){
|
useEvent([&](inputbind_t bind){
|
||||||
if(bind != INPUT_BIND_ACCEPT) return;
|
if(bind != INPUT_BIND_ACCEPT) return;
|
||||||
|
@ -18,6 +18,7 @@ void FPSLabelComponent::onStart() {
|
|||||||
if(this->label == nullptr) return;
|
if(this->label == nullptr) return;
|
||||||
std::string strFps = std::to_string((int32_t)(1.0f / delta));
|
std::string strFps = std::to_string((int32_t)(1.0f / delta));
|
||||||
std::string strTick = std::to_string((int32_t)(delta * 1000.0f));
|
std::string strTick = std::to_string((int32_t)(delta * 1000.0f));
|
||||||
label->text = strFps + "FPS (" + strTick + "ms)";
|
assertUnreachable();// Needs updating to new UI Label
|
||||||
|
// label->text = strFps + "FPS (" + strTick + "ms)";
|
||||||
}, this->item->scene->eventSceneUnpausedUpdate);
|
}, this->item->scene->eventSceneUnpausedUpdate);
|
||||||
}
|
}
|
@ -4,13 +4,13 @@
|
|||||||
// https://opensource.org/licenses/MIT
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "scene/components/ui/UILabel.hpp"
|
#include "scene/components/ui/text/UILabelNew.hpp"
|
||||||
|
|
||||||
namespace Dawn {
|
namespace Dawn {
|
||||||
class FPSLabelComponent : public SceneItemComponent {
|
class FPSLabelComponent : public SceneItemComponent {
|
||||||
public:
|
public:
|
||||||
/* @optional */
|
/* @optional */
|
||||||
UILabel *label = nullptr;
|
UILabelNew *label = nullptr;
|
||||||
|
|
||||||
FPSLabelComponent(SceneItem *item);
|
FPSLabelComponent(SceneItem *item);
|
||||||
void onStart() override;
|
void onStart() override;
|
||||||
|
@ -9,10 +9,9 @@ target_sources(${DAWN_TARGET_NAME}
|
|||||||
UICanvas.cpp
|
UICanvas.cpp
|
||||||
UIComponent.cpp
|
UIComponent.cpp
|
||||||
UIComponentRenderable.cpp
|
UIComponentRenderable.cpp
|
||||||
UILabel.cpp
|
|
||||||
UIImage.cpp
|
UIImage.cpp
|
||||||
UIBorder.cpp
|
UIBorder.cpp
|
||||||
UILabelNew.cpp
|
|
||||||
)
|
)
|
||||||
|
|
||||||
add_subdirectory(menu)
|
add_subdirectory(menu)
|
||||||
|
add_subdirectory(text)
|
@ -1,121 +0,0 @@
|
|||||||
// Copyright (c) 2023 Dominic Masters
|
|
||||||
//
|
|
||||||
// This software is released under the MIT License.
|
|
||||||
// https://opensource.org/licenses/MIT
|
|
||||||
|
|
||||||
#include "UILabel.hpp"
|
|
||||||
#include "game/DawnGame.hpp"
|
|
||||||
|
|
||||||
using namespace Dawn;
|
|
||||||
|
|
||||||
UILabel::UILabel(SceneItem *item) :
|
|
||||||
UIComponentRenderable(item),
|
|
||||||
text(""),
|
|
||||||
fontSize(10.0f),
|
|
||||||
font(&item->scene->game->renderManager.defaultFont),
|
|
||||||
maxWidth(UI_LABEL_MAX_WIDTH_ALIGN),
|
|
||||||
startQuad(0),
|
|
||||||
quadCount(-1)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
bool_t UILabel::hasText() {
|
|
||||||
return (
|
|
||||||
this->font != nullptr &&
|
|
||||||
this->font->isReady() &&
|
|
||||||
((std::string)this->text).size() > 0
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
void UILabel::updateMesh() {
|
|
||||||
if(!this->needsRebuffering) return;
|
|
||||||
if(!this->hasText()) return;
|
|
||||||
|
|
||||||
float_t width = this->maxWidth;
|
|
||||||
assertTrue(
|
|
||||||
width == UI_LABEL_MAX_WIDTH_NONE ||
|
|
||||||
width == UI_LABEL_MAX_WIDTH_ALIGN ||
|
|
||||||
width > 0
|
|
||||||
);
|
|
||||||
|
|
||||||
if(width == UI_LABEL_MAX_WIDTH_ALIGN) {
|
|
||||||
auto dimensional = this->getParentDimensional();
|
|
||||||
auto align = (glm::vec4)this->alignment;
|
|
||||||
float_t x;
|
|
||||||
UIComponent::calculateDimensions(
|
|
||||||
this->alignX,
|
|
||||||
this->alignUnitLeft,
|
|
||||||
this->alignUnitRight,
|
|
||||||
&x,
|
|
||||||
&width,
|
|
||||||
dimensional->getWidth(),
|
|
||||||
0,
|
|
||||||
glm::vec2(align[0], align[2])
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
this->font->buffer(
|
|
||||||
text,
|
|
||||||
fontSize,
|
|
||||||
width,
|
|
||||||
&this->mesh,
|
|
||||||
&this->measure
|
|
||||||
);
|
|
||||||
|
|
||||||
this->needsRebuffering = false;
|
|
||||||
|
|
||||||
this->eventFontRebuffered.invoke();
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<struct ShaderPassItem> UILabel::getUIRenderPasses() {
|
|
||||||
if(!this->hasText()) return {};
|
|
||||||
this->updateMesh();
|
|
||||||
|
|
||||||
struct ShaderPassItem item;
|
|
||||||
auto shader = getGame()->renderManager.uiShader;
|
|
||||||
item.shader = shader;
|
|
||||||
item.colorValues[shader->paramColor] = textColor;
|
|
||||||
item.parameterBuffers[shader->bufferUiCanvas] = &getCanvas()->shaderBuffer;
|
|
||||||
item.matrixValues[shader->paramModel] = this->transform->getWorldTransform();
|
|
||||||
item.textureSlots[0] = this->font->getTexture();
|
|
||||||
item.textureValues[shader->paramTexture] = 0;
|
|
||||||
item.start = this->startQuad * QUAD_INDICE_COUNT;
|
|
||||||
item.count = this->quadCount == -1 ? -1 : this->quadCount * QUAD_INDICE_COUNT;
|
|
||||||
item.w = this->transform->getWorldPosition().z;
|
|
||||||
item.renderFlags = RENDER_MANAGER_RENDER_FLAG_BLEND;
|
|
||||||
item.mesh = &mesh;
|
|
||||||
|
|
||||||
return { item };
|
|
||||||
}
|
|
||||||
|
|
||||||
float_t UILabel::getContentWidth() {
|
|
||||||
if(!this->hasText()) return 0;
|
|
||||||
this->updateMesh();
|
|
||||||
return this->measure.getWidth();
|
|
||||||
}
|
|
||||||
|
|
||||||
float_t UILabel::getContentHeight() {
|
|
||||||
if(!this->hasText()) return 0;
|
|
||||||
this->updateMesh();
|
|
||||||
return this->measure.getHeight();
|
|
||||||
}
|
|
||||||
|
|
||||||
void UILabel::onStart() {
|
|
||||||
UIComponent::onStart();
|
|
||||||
|
|
||||||
useEffect([&]{
|
|
||||||
alignmentNeedsUpdating = true;
|
|
||||||
}, { &fontSize, &font, &text, &maxWidth, &startQuad, &quadCount });
|
|
||||||
|
|
||||||
useEffect([&]{
|
|
||||||
eventTextChanged.invoke();
|
|
||||||
}, text);
|
|
||||||
|
|
||||||
useEffect([&]{
|
|
||||||
needsRebuffering = true;
|
|
||||||
}, alignmentNeedsUpdating);
|
|
||||||
|
|
||||||
useEvent([&]{
|
|
||||||
needsRebuffering = true;
|
|
||||||
}, eventAlignmentUpdated);
|
|
||||||
}
|
|
@ -1,59 +0,0 @@
|
|||||||
// Copyright (c) 2023 Dominic Masters
|
|
||||||
//
|
|
||||||
// This software is released under the MIT License.
|
|
||||||
// https://opensource.org/licenses/MIT
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
#include "UIComponentRenderable.hpp"
|
|
||||||
#include "display/font/Font.hpp"
|
|
||||||
|
|
||||||
#define UI_LABEL_MAX_WIDTH_NONE -1
|
|
||||||
#define UI_LABEL_MAX_WIDTH_ALIGN 0
|
|
||||||
|
|
||||||
namespace Dawn {
|
|
||||||
class UILabel : public UIComponentRenderable {
|
|
||||||
private:
|
|
||||||
bool_t needsRebuffering = true;
|
|
||||||
Mesh mesh;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true if the label contains renderable text.
|
|
||||||
*
|
|
||||||
* @return True if the label has text, otherwise false.
|
|
||||||
*/
|
|
||||||
bool_t hasText();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Internally performs the mesh update.
|
|
||||||
*/
|
|
||||||
void updateMesh();
|
|
||||||
|
|
||||||
public:
|
|
||||||
//@optional
|
|
||||||
StateProperty<std::string> text;
|
|
||||||
// @optional
|
|
||||||
StateProperty<float_t> fontSize;
|
|
||||||
/* @optional */
|
|
||||||
StateProperty<Font*> font;
|
|
||||||
/* @optional */
|
|
||||||
StateProperty<float_t> maxWidth;
|
|
||||||
/* @optional */
|
|
||||||
struct Color textColor = COLOR_WHITE;
|
|
||||||
// @optional
|
|
||||||
StateProperty<int32_t> startQuad;
|
|
||||||
// @optional
|
|
||||||
StateProperty<int32_t> quadCount;
|
|
||||||
|
|
||||||
StateEvent<> eventFontRebuffered;
|
|
||||||
StateEvent<> eventTextChanged;
|
|
||||||
|
|
||||||
struct FontMeasure measure;
|
|
||||||
|
|
||||||
UILabel(SceneItem *item);
|
|
||||||
|
|
||||||
float_t getContentWidth() override;
|
|
||||||
float_t getContentHeight() override;
|
|
||||||
std::vector<struct ShaderPassItem> getUIRenderPasses() override;
|
|
||||||
void onStart() override;
|
|
||||||
};
|
|
||||||
}
|
|
10
src/dawn/scene/components/ui/text/CMakeLists.txt
Normal file
10
src/dawn/scene/components/ui/text/CMakeLists.txt
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
# Copyright (c) 2022 Dominic Masters
|
||||||
|
#
|
||||||
|
# This software is released under the MIT License.
|
||||||
|
# https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
# Sources
|
||||||
|
target_sources(${DAWN_TARGET_NAME}
|
||||||
|
PRIVATE
|
||||||
|
UILabelNew.cpp
|
||||||
|
)
|
@ -21,10 +21,11 @@ namespace Dawn {
|
|||||||
std::string text;
|
std::string text;
|
||||||
struct UILabelStyle style;
|
struct UILabelStyle style;
|
||||||
|
|
||||||
// Part index
|
// Part index?
|
||||||
// Quad start
|
// Quad start?
|
||||||
// position
|
// quad count?
|
||||||
// size
|
// position?
|
||||||
|
// size?
|
||||||
// some kind of custom data e.g. wobble or shake?
|
// some kind of custom data e.g. wobble or shake?
|
||||||
|
|
||||||
usagelockid_t lockId = -1;
|
usagelockid_t lockId = -1;
|
@ -7,7 +7,7 @@
|
|||||||
#include "scene/Scene.hpp"
|
#include "scene/Scene.hpp"
|
||||||
#include "prefabs/SimpleSpinningCubePrefab.hpp"
|
#include "prefabs/SimpleSpinningCubePrefab.hpp"
|
||||||
#include "scene/components/display/Camera.hpp"
|
#include "scene/components/display/Camera.hpp"
|
||||||
#include "scene/components/ui/UILabelNew.hpp"
|
#include "scene/components/ui/text/UILabelNew.hpp"
|
||||||
|
|
||||||
namespace Dawn {
|
namespace Dawn {
|
||||||
class HelloWorldScene : public Scene {
|
class HelloWorldScene : public Scene {
|
||||||
|
Reference in New Issue
Block a user