Fixed alignment on UI Label
This commit is contained in:
		| @@ -9,7 +9,8 @@ | ||||
| using namespace Dawn; | ||||
|  | ||||
| UILabel::UILabel(SceneItem *item) : | ||||
|   UIComponentRenderable(item) | ||||
|   UIComponentRenderable(item), | ||||
|   lineHeight(1.0f) | ||||
| { | ||||
|  | ||||
| } | ||||
| @@ -22,6 +23,10 @@ void UILabel::onStart() { | ||||
|   useEvent([&]{ | ||||
|     this->rebufferQuads(this->texts); | ||||
|   }, eventAlignmentUpdated); | ||||
|  | ||||
|   useEffect([&]{ | ||||
|     this->rebufferQuads(this->texts); | ||||
|   }, lineHeight); | ||||
| } | ||||
|  | ||||
| std::vector<struct ShaderPassItem> UILabel::getUIRenderPasses() { | ||||
| @@ -94,10 +99,15 @@ float_t UILabel::getContentHeight() { | ||||
|     h += it->height; | ||||
|     ++it; | ||||
|   } | ||||
|   return 1; | ||||
|   return h; | ||||
| } | ||||
|  | ||||
| void UILabel::rebufferQuads(const std::vector<struct UILabelText> newTexts) { | ||||
|   if(this->ignoreAlignmentUpdate) { | ||||
|     this->ignoreAlignmentUpdate = false; | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   assertTrue(newTexts.size() <= FONT_SHADER_PARTS_MAX); | ||||
|  | ||||
|   int32_t nextTexture = 0; | ||||
| @@ -116,7 +126,7 @@ void UILabel::rebufferQuads(const std::vector<struct UILabelText> newTexts) { | ||||
|   // Determine font dimensions. | ||||
|   auto itText = newTexts.begin(); | ||||
|   while(itText != newTexts.end()) { | ||||
|     position.y = mathMax<float_t>(position.y, itText->style.size); | ||||
|     position.y = mathMax<float_t>(position.y, itText->style.size * this->lineHeight); | ||||
|     ++itText; | ||||
|   } | ||||
|  | ||||
| @@ -189,7 +199,7 @@ void UILabel::rebufferQuads(const std::vector<struct UILabelText> newTexts) { | ||||
|       // Move to next line | ||||
|       if(i != len) { | ||||
|         position.x = 0; | ||||
|         position.y += realText.style.size; | ||||
|         position.y += realText.style.size * this->lineHeight; | ||||
|         lines.push_back(currentLine); | ||||
|       } | ||||
|        | ||||
| @@ -203,11 +213,11 @@ void UILabel::rebufferQuads(const std::vector<struct UILabelText> newTexts) { | ||||
|         currentLine = UILabelLine(); | ||||
|         currentLine.quadStart = quadCountTotal; | ||||
|         currentLine.position = position; | ||||
|         currentLine.height = realText.style.size; | ||||
|         currentLine.height = realText.style.size * this->lineHeight; | ||||
|         // Here I subtract line height from the line position because we start | ||||
|         // by moving the text down by the initial line height, so we need to | ||||
|         // compensate for that. | ||||
|         currentLine.position.y -= realText.style.size; | ||||
|         currentLine.position.y -= realText.style.size * this->lineHeight; | ||||
|       } | ||||
|     }; | ||||
|  | ||||
| @@ -342,6 +352,9 @@ void UILabel::rebufferQuads(const std::vector<struct UILabelText> newTexts) { | ||||
|   textsBuffered = realNewTexts; | ||||
|   texts = newTexts; | ||||
|  | ||||
|   this->ignoreAlignmentUpdate = true; | ||||
|   this->alignmentNeedsUpdating = true; | ||||
|  | ||||
|   // Event | ||||
|   this->eventTextChanged.invoke(); | ||||
| } | ||||
| @@ -36,11 +36,18 @@ namespace Dawn { | ||||
|     int32_t quadCount = 0; | ||||
|   }; | ||||
|  | ||||
|   enum UILabelVerticalAlign { | ||||
|     UI_LABEL_VERTICAL_ALIGN_TOP, | ||||
|     UI_LABEL_VERTICAL_ALIGN_MIDDLE, | ||||
|     UI_LABEL_VERTICAL_ALIGN_BOTTOM | ||||
|   }; | ||||
|  | ||||
|   class UILabel : public UIComponentRenderable { | ||||
|     private: | ||||
|       Mesh mesh; | ||||
|       FontShaderBuffer shaderBuffer; | ||||
|       std::map<TrueTypeFaceTexture*, int32_t> textureMap; | ||||
|       bool_t ignoreAlignmentUpdate = false; | ||||
|  | ||||
|     public: | ||||
|       int32_t quadStart = 0; | ||||
| @@ -55,6 +62,9 @@ namespace Dawn { | ||||
|        | ||||
|       StateEvent<> eventTextChanged; | ||||
|  | ||||
|       // @optional | ||||
|       StateProperty<float_t> lineHeight; | ||||
|  | ||||
|       UILabel(SceneItem *item); | ||||
|  | ||||
|       void onStart() override; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user