diff options
author | nea <romangraef@gmail.com> | 2022-08-07 23:51:45 +0200 |
---|---|---|
committer | nea <romangraef@gmail.com> | 2022-08-07 23:51:45 +0200 |
commit | 9713b856f8abdb003824fd3d0ef4bc8a8bfc5b06 (patch) | |
tree | 72f24e1f42e8449c8fb993aca33d752008a13f7b /src/main/kotlin/moe/nea/notenoughupdates/hud | |
parent | dc4755eb79ab78f87b0e1e4ad6dac81912af0ee0 (diff) | |
download | firmament-9713b856f8abdb003824fd3d0ef4bc8a8bfc5b06.tar.gz firmament-9713b856f8abdb003824fd3d0ef4bc8a8bfc5b06.tar.bz2 firmament-9713b856f8abdb003824fd3d0ef4bc8a8bfc5b06.zip |
progress bar
Diffstat (limited to 'src/main/kotlin/moe/nea/notenoughupdates/hud')
-rw-r--r-- | src/main/kotlin/moe/nea/notenoughupdates/hud/RepoDownloadProgress.kt | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/src/main/kotlin/moe/nea/notenoughupdates/hud/RepoDownloadProgress.kt b/src/main/kotlin/moe/nea/notenoughupdates/hud/RepoDownloadProgress.kt new file mode 100644 index 0000000..462f0bc --- /dev/null +++ b/src/main/kotlin/moe/nea/notenoughupdates/hud/RepoDownloadProgress.kt @@ -0,0 +1,63 @@ +package moe.nea.notenoughupdates.hud + +import com.mojang.blaze3d.vertex.PoseStack +import io.github.cottonmc.cotton.gui.client.ScreenDrawing +import io.github.cottonmc.cotton.gui.widget.WWidget +import io.github.cottonmc.cotton.gui.widget.data.HorizontalAlignment +import io.github.cottonmc.cotton.gui.widget.data.Insets +import kotlin.math.roundToInt +import kotlin.math.sin + + +val Insets.vertical get() = bottom + top +val Insets.horizontal get() = left + right + +class ProgressBar( + var label: String, + var total: Int?, // If total is null, then make it a bouncy rectangle + var progress: Int = 0, +) : WWidget() { + + var insets: Insets = Insets(7) + override fun canResize(): Boolean = true + + + fun reportProgress(label: String, progress: Int, total: Int?) { + synchronized(this) { + this.label = label + this.progress = progress + this.total = total + } + + } + + override fun paint(matrices: PoseStack, x: Int, y: Int, mouseX: Int, mouseY: Int) { + ScreenDrawing.coloredRect(matrices, x, y, width, height, 0xFF808080.toInt()) + val (l, prog) = synchronized(this) { + label to (progress to total) + } + val (p, t) = prog + + if (t == null) { + ScreenDrawing.coloredRect( + matrices, + (x + (1 + sin(System.currentTimeMillis().toDouble() / 1000)) * width * 3 / 4 / 2).roundToInt(), + y, + width / 4, + height, + 0xFF00FF00.toInt() + ) + } else { + ScreenDrawing.coloredRect(matrices, x, y, width * p / t, height, 0xFF00FF00.toInt()) + } + ScreenDrawing.drawString( + matrices, + if (t != null) "$l ($p/$t)" else l, + HorizontalAlignment.CENTER, + x + insets.left, + y + insets.top, + width - insets.horizontal, + height - insets.vertical, + ) + } +} |