diff options
author | nea <nea@nea.moe> | 2023-07-31 21:27:07 +0200 |
---|---|---|
committer | nea <nea@nea.moe> | 2023-07-31 21:27:07 +0200 |
commit | c3e1bab941f47dfd5ef5c55805015ee5d47da802 (patch) | |
tree | b4db354834ad01260b2c544ae6bfe7e73de00a07 /src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt | |
parent | d8ee0c458a31352eefdb2100a53c3af268b2bb53 (diff) | |
download | Firmament-c3e1bab941f47dfd5ef5c55805015ee5d47da802.tar.gz Firmament-c3e1bab941f47dfd5ef5c55805015ee5d47da802.tar.bz2 Firmament-c3e1bab941f47dfd5ef5c55805015ee5d47da802.zip |
Improve config gui handling
Diffstat (limited to 'src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt')
-rw-r--r-- | src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt | 22 |
1 files changed, 8 insertions, 14 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt b/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt index c705f7f..c7a9a55 100644 --- a/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt +++ b/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt @@ -1,5 +1,6 @@ package moe.nea.firmament.gui.config +import io.github.cottonmc.cotton.gui.widget.WBox import io.github.cottonmc.cotton.gui.widget.WLabel import io.github.cottonmc.cotton.gui.widget.WSlider import io.github.cottonmc.cotton.gui.widget.data.Axis @@ -9,7 +10,9 @@ import kotlinx.serialization.json.JsonElement import kotlinx.serialization.json.JsonPrimitive import kotlinx.serialization.json.int import kotlinx.serialization.json.jsonPrimitive +import kotlin.time.Duration.Companion.milliseconds import net.minecraft.text.Text +import moe.nea.firmament.util.FirmFormatters class IntegerHandler(val config: ManagedConfig, val min: Int, val max: Int) : ManagedConfig.OptionHandler<Int> { override fun toJson(element: Int): JsonElement? { @@ -21,20 +24,11 @@ class IntegerHandler(val config: ManagedConfig, val min: Int, val max: Int) : Ma } override fun emitGuiElements(opt: ManagedConfig.Option<Int>, guiAppender: GuiAppender) { - val lw = guiAppender.width / 2 - guiAppender.set( - 0, 0, lw, 1, - WLabel(opt.labelText).setVerticalAlignment(VerticalAlignment.CENTER) - ) val label = WLabel(Text.literal(opt.value.toString())).setVerticalAlignment(VerticalAlignment.CENTER) - guiAppender.set(lw, 0, 2, 1, label) - guiAppender.set( - lw + 2, - 0, - lw - 2, - 1, - WSlider(min, max, Axis.HORIZONTAL).apply { + guiAppender.appendLabeledRow(opt.labelText, WBox(Axis.HORIZONTAL).also { + it.add(label, 40, 18) + it.add(WSlider(min, max, Axis.HORIZONTAL).apply { valueChangeListener = IntConsumer { opt.value = it label.text = Text.literal(opt.value.toString()) @@ -44,8 +38,8 @@ class IntegerHandler(val config: ManagedConfig, val min: Int, val max: Int) : Ma value = opt.value label.text = Text.literal(opt.value.toString()) } - }) - guiAppender.skipRows(1) + }, 130, 18) + }) } } |