#bevy-ui #xml #html #bevy #ui #dsl

bevy_hui_widgets

A collection of bevy components and systems to build widgets with bevy_hui

1 unstable release

0.1.0 Dec 3, 2024

#2376 in Game dev

Download history 28/week @ 2024-11-27 120/week @ 2024-12-04 7/week @ 2024-12-11

155 downloads per month

MIT/Apache

160KB
4K SLoC

Bevy Hui Widgets

A collection of bevy components & systems to build widgets with bevy_hui.

It is highly suggest to checkout the widget example in the example-crate.

Slider

A slider is a node with an absolute button as child. The button can be dragged on a fixed axis. The slider state/value is stored on the root node.

The important part:

on_spawn="init_slider" tag:axis="x"

A minimal template you have to implement:

<template>
    <node
        on_spawn="init_slider"
        tag:axis="x"
        width="255px"
        height="20px"
        background="#000"
    >
        <button
            background="#FFF"
            position="absolute"
            width="20px"
            height="20px"
        ></button>
    </node>
</template>

Input

A input node is just a button with a text node somewhere in it's hierarchy.

<template>
    <button
        on_spawn="init_input"
        target="text_value"
        tag:filter="text"
        active:border_color="#FFF"
    >
        <text id="text_value">Placeholder</text>
    </button>
</template>

Select [WIP]

A select is a button with a text child and a hidden container node with options. The current selected value is represented by the entity of the value node. It's up to the user to add any Component/value to that node.

Minimal template:

Select Template:

<template>
    <button
        on_spawn="init_select"
        target="options"
    >
        <text font_size="20">None</text>
        <node
            display="none"
            top="30px"
            id="options"
            position="absolute"
        >
            <slot />
        </node>
    </button>
</template>

Option Template:

<template>
    <property name="value"></property>
    <button tag:value="{value}">
        <text font_size="20">{value}</text>
    </button>
</template>

Usage:

<select>
    <option value="option 1" />
    <option value="option 2" />
    <option value="option 3" />
</select>

Dependencies

~53–86MB
~1.5M SLoC