aboutsummaryrefslogtreecommitdiff
path: root/common/src/main/java/dev/isxander/yacl/impl
diff options
context:
space:
mode:
authorisXander <xandersmith2008@gmail.com>2023-05-21 14:36:37 +0100
committerisXander <xandersmith2008@gmail.com>2023-05-21 14:36:37 +0100
commitc84415116455d108ad07fc8dd6232c9acc94c40f (patch)
tree9c6a20b611e45eedeb512b8294f7147575d56af9 /common/src/main/java/dev/isxander/yacl/impl
parent21afea0da3956f2d8cca81a54fa9820152e0c077 (diff)
downloadYetAnotherConfigLib-c84415116455d108ad07fc8dd6232c9acc94c40f.tar.gz
YetAnotherConfigLib-c84415116455d108ad07fc8dd6232c9acc94c40f.tar.bz2
YetAnotherConfigLib-c84415116455d108ad07fc8dd6232c9acc94c40f.zip
Automatic WebP frame duration detection
Diffstat (limited to 'common/src/main/java/dev/isxander/yacl/impl')
-rw-r--r--common/src/main/java/dev/isxander/yacl/impl/OptionDescriptionImpl.java20
1 files changed, 10 insertions, 10 deletions
diff --git a/common/src/main/java/dev/isxander/yacl/impl/OptionDescriptionImpl.java b/common/src/main/java/dev/isxander/yacl/impl/OptionDescriptionImpl.java
index f57a410..c866b43 100644
--- a/common/src/main/java/dev/isxander/yacl/impl/OptionDescriptionImpl.java
+++ b/common/src/main/java/dev/isxander/yacl/impl/OptionDescriptionImpl.java
@@ -38,7 +38,7 @@ public record OptionDescriptionImpl(Component descriptiveName, Component descrip
Validate.isTrue(width > 0, "Width must be greater than 0!");
Validate.isTrue(height > 0, "Height must be greater than 0!");
- this.image = CompletableFuture.completedFuture(Optional.of(new ImageRenderer.TextureBacked(image, width, height)));
+ this.image = ImageRenderer.getOrMakeSync(image, () -> Optional.of(new ImageRenderer.TextureBacked(image, width, height)));
imageUnset = false;
return this;
}
@@ -46,7 +46,7 @@ public record OptionDescriptionImpl(Component descriptiveName, Component descrip
@Override
public Builder image(Path path, ResourceLocation uniqueLocation) {
Validate.isTrue(imageUnset, "Image already set!");
- this.image = CompletableFuture.supplyAsync(() -> ImageRenderer.NativeImageBacked.createFromPath(path, uniqueLocation));
+ this.image = ImageRenderer.getOrMakeAsync(uniqueLocation, () -> ImageRenderer.NativeImageBacked.createFromPath(path, uniqueLocation));
imageUnset = false;
return this;
}
@@ -54,7 +54,7 @@ public record OptionDescriptionImpl(Component descriptiveName, Component descrip
@Override
public Builder gifImage(ResourceLocation image) {
Validate.isTrue(imageUnset, "Image already set!");
- this.image = CompletableFuture.supplyAsync(() -> {
+ this.image = ImageRenderer.getOrMakeAsync(image, () -> {
try {
return Optional.of(ImageRenderer.AnimatedNativeImageBacked.createGIFFromTexture(image));
} catch (IOException e) {
@@ -69,7 +69,7 @@ public record OptionDescriptionImpl(Component descriptiveName, Component descrip
@Override
public Builder gifImage(Path path, ResourceLocation uniqueLocation) {
Validate.isTrue(imageUnset, "Image already set!");
- this.image = CompletableFuture.supplyAsync(() -> {
+ this.image = ImageRenderer.getOrMakeAsync(uniqueLocation, () -> {
try {
return Optional.of(ImageRenderer.AnimatedNativeImageBacked.createGIF(new FileInputStream(path.toFile()), uniqueLocation));
} catch (IOException e) {
@@ -82,11 +82,11 @@ public record OptionDescriptionImpl(Component descriptiveName, Component descrip
}
@Override
- public Builder webpImage(ResourceLocation image, int frameDelayMS) {
+ public Builder webpImage(ResourceLocation image) {
Validate.isTrue(imageUnset, "Image already set!");
- this.image = CompletableFuture.supplyAsync(() -> {
+ this.image = ImageRenderer.getOrMakeAsync(image, () -> {
try {
- return Optional.of(ImageRenderer.AnimatedNativeImageBacked.createWEBPFromTexture(image, frameDelayMS));
+ return Optional.of(ImageRenderer.AnimatedNativeImageBacked.createWEBPFromTexture(image));
} catch (IOException e) {
e.printStackTrace();
return Optional.empty();
@@ -97,11 +97,11 @@ public record OptionDescriptionImpl(Component descriptiveName, Component descrip
}
@Override
- public Builder webpImage(Path path, ResourceLocation uniqueLocation, int frameDelayMS) {
+ public Builder webpImage(Path path, ResourceLocation uniqueLocation) {
Validate.isTrue(imageUnset, "Image already set!");
- this.image = CompletableFuture.supplyAsync(() -> {
+ this.image = ImageRenderer.getOrMakeAsync(uniqueLocation, () -> {
try {
- return Optional.of(ImageRenderer.AnimatedNativeImageBacked.createWEBP(new FileInputStream(path.toFile()), uniqueLocation, frameDelayMS));
+ return Optional.of(ImageRenderer.AnimatedNativeImageBacked.createWEBP(new FileInputStream(path.toFile()), uniqueLocation));
} catch (IOException e) {
e.printStackTrace();
return Optional.empty();