From c8e02daa6e347a3ff039a27ed5fa9117ef741726 Mon Sep 17 00:00:00 2001 From: Michiel van der Geest Date: Wed, 16 Oct 2024 13:12:48 +0200 Subject: [PATCH] Added docs on @loaded event for Text elements. --- docs/essentials/displaying_text.md | 34 ++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/docs/essentials/displaying_text.md b/docs/essentials/displaying_text.md index 77665edd..f956859a 100644 --- a/docs/essentials/displaying_text.md +++ b/docs/essentials/displaying_text.md @@ -32,6 +32,40 @@ The Text-tag accepts the following attributes: - `contain` - the strategy for containing text within the bounds, can be `none` (default), `width`, or `both`. In most cases, the value of this attribute will automatically be set by Blits, based on the other specified attributes - `textoverflow` - the suffix to be added when text is cropped due to bounds limits, defaults to `...` +## Text dimensions + +When you want to center your Text element, or properly position other Elements around your text, it is useful know the exact dimensions of your text. + +Similar to the Image element (i.e. an Element with a `src`), Text elements also accept the `@loaded` attribute. This event is called, as soon as the text is rendered, and passes in the dimensions of the generated text texture. + +The example below shows how to use the `@loaded`-attribute to position an Element as an underline, under a piece of text. + +```js +export default Blits.Component('MyComponent', { + template: ` + + + + + + `, + props: ['myText'], + state() { + return { + w: 0, + y: 0, + } + }, + methods: { + textLoaded(dimensions) { + console.log(`The text has a width of ${dimensions.w} and a height of ${dimensions.h}`) + // set the underline width to the exact width of the text + this.w = dimensions.w + // position the underline 8px below the text + this.y = dimensions.h + 8 + } + } +``` ## SDF and Canvas2d