> For the complete documentation index, see [llms.txt](https://docs.febucci.com/text-animator-unreal/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://docs.febucci.com/text-animator-unreal/other/best-practices.md).

# Best Practices

{% hint style="info" %}
Every project is different, but in this page you can find some common best practices that can help you set up everything better and avoid most common issues!
{% endhint %}

***

### Set the entire text/dialogue only once

Please try to set text just once, and use the typewriter / visibility methods to control how it appears.

{% hint style="info" %}
If you really need to append text later in time, you can use the "AppendText" function found in the core UMG widget UAnimTextBlock.
{% endhint %}

<details>

<summary>Example</summary>

If you have a character that says "Helloooo how are you doing?", and you want to display it letter by letter, simply do: `Typewriter->ShowText(FText::FromString("Helloooo how are you doing?"));` and that's it! [Show and hide letters dynamically](/text-animator-unreal/typewriter/show-and-hide-letters-dynamically.md)

***

If you're building a dynamic string, you can still do that before setting its value to the typewriter/animator.

```cpp
int Apples = 5;
FString PlayerName = TEXT("Bob");

// Build the dialogue string first
FString Dialogue = FString::Printf(TEXT("Hello %s, you've got %d apples"), *PlayerName, Apples);

// Then pass it to ShowText, which expects an FText
Typewriter->ShowText(FText::FromString(Dialogue));
```

(If you're using a Dialogue System, they'll do this for you - no worries ! [Integrations](/text-animator-unreal/integrations/integrated-plugins-and-dialogues-systems.md))

</details>

<details>

<summary>Why should I set the entire text once, instead of character by character?</summary>

Performance! (Even if you didn't have Text Animator.)

Every time you set the text, calculations have to performed for its mesh, positioning etc., and Text Animator has then to re-calculate character durations and more. This means that if you change it multiple times per second (e.g. adding more letters), you're doing these calculations every time.

To display characters one by one, you can simply set the full text once, and then start the typewriter: [Show and hide letters dynamically](/text-animator-unreal/typewriter/show-and-hide-letters-dynamically.md)&#x20;

</details>

***

*If you're changing something in the text editor but it's not getting updated, please let us know!*


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter, and the optional `goal` query parameter:

```
GET https://docs.febucci.com/text-animator-unreal/other/best-practices.md?ask=<question>&goal=<endgoal>
```

`ask` is the immediate question: it should be specific, self-contained, and written in natural language.
`goal` is optional and describes the broader end goal you are ultimately trying to accomplish on behalf of the user. GitBook uses it to tailor the answer towards what is most useful for that goal.

The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
