Bonfire Best Practices
Last updated
Was this helpful?
Last updated
Was this helpful?
Behavior nodes have a 1:1 relationship with their associated inputs/outputs within the behavior tree. Cause nodes should adhere to the Single Responsibility Principle, a vital part of the SOLID object-oriented design practices. If done correctly, the Cause node will be individually responsible for solely evaluating specific conditions. Similarly, using this principle with effect nodes means each node executes a single action.
Coupling between nodes in code can lead to brittle behavior. Nodes should only communicate through input and output sockets; they should not depend on each other in code. This allows for easy modification and extension of the behavior tree without affecting other system parts, thereby conforming to the Open/Closed Principle.
Behavior nodes cannot be Unity MonoBehaviors. They are Plain Old C# Objects (POCO). This practice of using POCOs creates a more structured application architecture that makes nodes platform-agnostic, performant, reusable, easier to control, and easier to troubleshoot. While MonoBehaviors are tightly coupled with Unity's lifecycle and primarily used for GameObject components, behavior tree nodes operate independently of Unity's GameObject architecture. To leverage Unity's lifecycle events, the SparkSDK offers the Lifecycle class.
When adding an "Interacted" or "Grabbed" Behavior Node to a Spark, ensure that the "Is Interactable" trait is checked. It is common for new creators to overlook this step, leading to confusion about the inability to grab or interact with Sparks.
When configuring UI buttons, make sure the Sort Order of the button is set higher than other UI elements within the same container (such as a Billboard or Screen Space UI) if symbols or elements overlap the button, as shown in the image. This ensures the button stays on the top layer, making it clickable and fully functional.
If no other UI elements overlap the button (like in the image below), having the same Sort Order is fine and should work as expected.
If a downloaded asset doesnât appear immediately, try clicking the breadcrumb labeled "Spark" at the top of the interface to ensure the asset is properly loaded.
Always monitor the Utilization Bar in the Bonfire Builder and ensure it does not exceed 200%. Exceeding this limit can cause performance issues and lead to lag within your Book.
To quickly navigate back to the main folder while in a sub-folder within the Spark Browser, simply click the breadcrumb labeled "Spark" at the top of the interface. This will immediately take you back to the main Spark directory, saving time and making navigation smoother.
In the Behavior Window and Chapter Window, use the "Zoom to Fit Selected" button to fill the screen with the specific behavior nodes or chapters in view. This button automatically adjusts the view to right size and center on the selected item, making it easier to find and edit nodes or chapters in complex layouts.
You can customize your window layout in the Bonfire Builder to suit your workflow preferences. Adjusting the layout can help you manage your workspace more efficiently when creating or editing Books.
In the Settings window of Bonfire Builder, you can easily reset, save, and open your saved layout configurations. This feature allows you to customize your workspace and maintain your preferred setup across sessions.
In the Chapter Window, Behavior Window, Spark Browser, Map Browser, Config Window, Entities Window, and Symbols Window, you can use the search bar to quickly locate or modify specific Sparks.
If you find a bug or want to request a new feature in Bonfire Builder, click the "Report a Bug" button.
To make your report clear:
Be Specific: Describe exactly what happened or what you want.
Test Before Reporting: Make sure the bug happens more than once.
Provide Details:
Steps to Reproduce: List what you did before the bug appeared.
Screenshots or Videos: Include visuals if possible.
System Info: Add your device and Bonfire version.
This helps the team understand and fix issues faster!
In Bonfire Builder, users can remotely access books created by other authors and review their code, provided they have the bookâs share code. However, these remotely accessed books cannot be edited or republished under the same share code, ensuring the original authorâs work remains intact. Additionally, users cannot save remotely pulled books from other authors locally.
If a user wishes to build upon an existing book, they can do so by selecting the Change Share Code button. Once the share code is changed, the book can be edited, published as the userâs own work, and saved locally.
Note that enterprise users will get their own dedicated domain, ensuring their books are accessible only to accounts within that exclusive domain. This setup prevents public users from viewing or making changes to their books, keeping everything secure and private.
Books can be accessed and modified using a Share Code. To open a shared Book, navigate to the Remote Book window and enter the provided Share Code. Once accessed, the Book can be used and modified as needed.
Selecting the Refresh icon next to the Share Code in the Book title tab generates a new Share Code for the published Book. Updating the Share Code allows the Book to be downloaded along with its assets and saved as a new creation.
In Bonfire Builder, custom fonts can be used in the Text Symbol Spark by importing them through the Sparkifier.
The Sparkifier is required to use custom fonts in Bonfire Builder. To create a new Text Symbol Spark, select Advanced, choose Symbol, and set the Symbol Type to Text Viewer and press the Select This Type button.
Then, navigate to Additional Data to import custom fonts.
Assign a name to the custom fonts, then build the Text Symbol Spark.
In Bonfire Builder, custom fonts built in the Sparkifier can be used by importing them into the Builder. Click the import icon, then select the custom fonts generated by the Sparkifier. Imported custom font Sparks can be found in "My Sparks."
Drag the Custom Font Symbol Spark into the UI Editor, then update the Font Name. The Text Symbol Spark will reflect the imported custom fonts in the Builder.
The Remote Book feature provides access to Books that have been published or shared. Entering a valid Share Code makes the Book available for use and modification.
A Share Code is required to access a published Book. Once entered, the Book becomes available for editing and customization.
When a Share Code is changed, the Book can be saved as a Local Book. Opening the Local Book window and saving the Book locally assigns ownership. Once saved, the Book can be published with a newly generated Share Code.
In Supplemental Data, click the icon in the top right corner to import the custom font file, then select the Browse button and select the desired Font File Type (either TTF or OTF).