Updated some docs
This commit is contained in:
@ -11,9 +11,32 @@
|
||||
namespace Dawn {
|
||||
class UIComponentDimensional {
|
||||
public:
|
||||
/**
|
||||
* Returns the width of this dimensional UI item.
|
||||
*
|
||||
* @return Width of this item.
|
||||
*/
|
||||
virtual float_t getWidth() = 0;
|
||||
|
||||
/**
|
||||
* Returns the height of this dimensional UI item.
|
||||
*
|
||||
* @return Height of this item.
|
||||
*/
|
||||
virtual float_t getHeight() = 0;
|
||||
|
||||
/**
|
||||
* Returns the content width of this dimensional UI item.
|
||||
*
|
||||
* @return Content width of this item.
|
||||
*/
|
||||
virtual float_t getContentWidth() = 0;
|
||||
|
||||
/**
|
||||
* Returns the content height of this dimensional UI item.
|
||||
*
|
||||
* @return Content height of this item.
|
||||
*/
|
||||
virtual float_t getContentHeight() = 0;
|
||||
};
|
||||
|
||||
@ -54,7 +77,6 @@ namespace Dawn {
|
||||
float_t getHeight() override;
|
||||
float_t getContentWidth() override;
|
||||
float_t getContentHeight() override;
|
||||
|
||||
void onStart() override;
|
||||
void onDispose() override;
|
||||
};
|
||||
|
@ -19,6 +19,15 @@ namespace Dawn {
|
||||
|
||||
class UIComponentRenderable {
|
||||
public:
|
||||
/**
|
||||
* Implemented UI Components that have rendering should implement this and
|
||||
* return their rendering items. Items are passed back to the render
|
||||
* pipeline.
|
||||
*
|
||||
* @param projection Camera projection, obtained from the canvas.
|
||||
* @param view Camera view, obtained from the canvas.
|
||||
* @return A list of renderable shader pass items for this renderable.
|
||||
*/
|
||||
virtual std::vector<struct ShaderPassItem> getPassItems(
|
||||
glm::mat4 projection,
|
||||
glm::mat4 view
|
||||
@ -27,13 +36,22 @@ namespace Dawn {
|
||||
|
||||
class UIComponent : public SceneItemComponent, public UIComponentDimensional {
|
||||
protected:
|
||||
// Calculated (and cached) values
|
||||
float_t width = 1;
|
||||
float_t height = 1;
|
||||
|
||||
StateEvent<> eventAlignmentUpdated;
|
||||
|
||||
/**
|
||||
* Simply returns this UI Components' dimensional parent, used for the
|
||||
* alignment of this item.
|
||||
*
|
||||
* @return Pointer to the parent dimensional.
|
||||
*/
|
||||
UIComponentDimensional * getParentDimensional();
|
||||
|
||||
/**
|
||||
* Internal method to update the alignment of this item.
|
||||
*/
|
||||
void updateAlignment();
|
||||
|
||||
public:
|
||||
@ -58,8 +76,6 @@ namespace Dawn {
|
||||
glm::vec2 alignment
|
||||
);
|
||||
|
||||
//
|
||||
|
||||
StateProperty<UIComponentAlign> alignX;
|
||||
StateProperty<UIComponentAlign> alignY;
|
||||
StateProperty<glm::vec4> alignment;
|
||||
@ -68,7 +84,6 @@ namespace Dawn {
|
||||
|
||||
float_t getWidth() override;
|
||||
float_t getHeight() override;
|
||||
|
||||
void onStart() override;
|
||||
|
||||
friend class UICanvas;
|
||||
|
@ -30,8 +30,8 @@ void UILabel::updateMesh() {
|
||||
if(!this->hasText()) return;
|
||||
|
||||
float_t width = this->maxWidth;
|
||||
assertTrue(width == 0 || width == -1 || width > 0);
|
||||
if(width == 0) {
|
||||
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;
|
||||
|
@ -16,7 +16,16 @@ namespace Dawn {
|
||||
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:
|
||||
|
Reference in New Issue
Block a user