1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
package gregtech.api.gui.widgets;
import static gregtech.api.gui.modularui.GTUITextures.OVERLAY_BUTTON_HOURGLASS;
import static gregtech.common.covers.CoverInfo.MAX_TICK_RATE_ADDITION;
import java.util.List;
import net.minecraft.util.StatCollector;
import org.jetbrains.annotations.NotNull;
import com.google.common.collect.ImmutableList;
import com.gtnewhorizons.modularui.api.drawable.UITexture;
import com.gtnewhorizons.modularui.api.widget.IWidgetBuilder;
import com.gtnewhorizons.modularui.api.widget.Widget;
import com.gtnewhorizons.modularui.common.widget.ButtonWidget;
import com.gtnewhorizons.modularui.common.widget.FakeSyncWidget;
import gregtech.api.gui.modularui.GTUITextures;
import gregtech.common.covers.CoverInfo;
public class CoverTickRateButton extends ButtonWidget {
private static final UITexture BACKGROUND = GTUITextures.BUTTON_COVER_NORMAL.getSubArea(0, 0, 1, 0.5f);
private final CoverInfo coverInfo;
private int clientTickRate;
private int tickRateAddition;
public CoverTickRateButton(@NotNull CoverInfo coverInfo, @NotNull IWidgetBuilder<?> builder) {
this.coverInfo = coverInfo;
this.clientTickRate = coverInfo.getTickRate();
this.tickRateAddition = coverInfo.getTickRateAddition();
super.setBackground(BACKGROUND, OVERLAY_BUTTON_HOURGLASS);
super.setOnClick(this::onClick);
super.dynamicTooltip(this::dynamicTooltip);
super.attachSyncer(
new FakeSyncWidget.IntegerSyncer(this.coverInfo::getTickRate, integer -> clientTickRate = integer),
builder,
(widget, aInt) -> notifyTooltipChange())
.attachSyncer(
new FakeSyncWidget.IntegerSyncer(
this.coverInfo::getTickRateAddition,
integer -> tickRateAddition = integer),
builder);
}
private void onClick(@NotNull ClickData clickData, @NotNull Widget widget) {
final int iterations = clickData.ctrl ? 5 : 1;
final boolean isDecreasing = clickData.mouseButton == 1;
// Do five operations at once if Ctrl is held down. Since the actual increase granted by each invocation can be
// different on each call, just call the method several times rather than trying to do a bunch of weird math.
for (int i = 0; i < iterations; i++) {
coverInfo.adjustTickRateMultiplier(isDecreasing);
}
}
private List<String> dynamicTooltip() {
final String boundsNotification;
if (tickRateAddition == 0) {
boundsNotification = StatCollector.translateToLocal("gt.cover.info.button.bounds_notification.minimum");
} else if (tickRateAddition >= MAX_TICK_RATE_ADDITION - 1) {
// Clamping can make tickRateAddition approach but never actually equal MAX_ADDITION, so we need this
// adjustment.
boundsNotification = StatCollector.translateToLocal("gt.cover.info.button.bounds_notification.maximum");
} else {
boundsNotification = "";
}
return ImmutableList.of(
StatCollector.translateToLocalFormatted(
"gt.cover.info.button.tick_rate.1",
new CoverInfo.ClientTickRateFormatter(clientTickRate),
boundsNotification),
StatCollector.translateToLocal("gt.cover.info.button.tick_rate.2"),
StatCollector.translateToLocal("gt.cover.info.button.tick_rate.3"));
}
}
|