Compare commits

..

No commits in common. "main" and "0.1.0-alpha" have entirely different histories.

41 changed files with 106 additions and 133 deletions

2
.gitignore vendored
View File

@ -1,6 +1,4 @@
*
!gifs
!gifs/**
!src
!src/**
!.gitignore

View File

@ -1,52 +0,0 @@
<div align="center">
<img src="src/main/resources/assets/smooth-chunks/icon.png" width="100">
# Smooth Chunks
[![Mod Loader](https://img.shields.io/badge/Mod%20Loader-Fabric-lightyellow?logo=)](https://fabricmc.net)
![Enviroment](https://img.shields.io/badge/Enviroment-Client-purple)
An enhanecd fork of [cadenkriese's mod](https://github.com/cadenkriese/smooth-chunks) for the latest versions of the game, with a completely different code base.
</div>
## What is this?
Smooth Chunks is a Fabric mod that adds animations of currently loading chunks. This makes chunk loading generally seem much more pleasant than them appearing out of thin air. There are multiple built-in animations and ease types, and if this isnt't enough, there's an API which will allow you to add your own animations and eases (with ease :trollface:)
Generally, this is what you'd call an "eye-candy" mod.
### Currently supported animations:
- Rise
<img src="gifs/rise.gif" width="300">
- Fall
<img src="gifs/fall.gif" width="300">
- Scale
<img src="gifs/scale.gif" width="300">
- Fly in
<img src="gifs/fly-in.gif" width="300">
### Currently supported interpolation types:
- Linear
- Sine
- Quadratic
- Elastic
## Future plans
In the future, I plan to extend the scope of this mod to not only smoothen the chunk loading, but entity spawning/despawning/dying, liquid flowing, crops growing etc.
## License
This mod is under the [MIT License](LICENSE).

View File

@ -96,5 +96,5 @@ publishing {
}
}
loom {
accessWidenerPath = file("src/main/resources/animated-chunks.accesswidener")
accessWidenerPath = file("src/main/resources/smooth-chunks.accesswidener")
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 441 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 370 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 283 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 272 KiB

View File

@ -10,7 +10,7 @@ loader_version=0.13.3
# Mod Properties
mod_version=0.2.0
maven_group=me.topchetoeu
archives_base_name=animated-chunks
archives_base_name=smooth-chunks
# Dependencies
fabric_version=0.47.8+1.18.2

27
readme.md Normal file
View File

@ -0,0 +1,27 @@
# Smooth chunks
This is a fork of [flogic](https://github.com/cadenkriese/smooth-chunks)'s mod (although code bases have nothing in common)
## What is this?
This is a mod that adds animations of currently loading chunks. This makes chunk loading generally seem much more pleasant than them appearing out of thin air. There are multiple built-in animations and ease types, and if this isnt't enough, there's an API which will allow you to add your own animations and eases (with ease)
Generally, this is what you'd call an "eye-candy" mod.
## Currently supported animations:
- Rise
- Fall
- Scale
## Currently supported interpolation types:
- Linear
- Sine
- Quadratic
- Elastic
## Future plans:
In the future, I plan to extend the scope of this mod to not only smoothen the chunk loading, but entity spawning / despawning / dying, liquid flowing, crops growing, etc.

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks;
package me.topchetoeu.smoothchunks;
import java.io.File;
import java.io.FileNotFoundException;
@ -8,8 +8,8 @@ import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import me.topchetoeu.animatedchunks.animation.Animation;
import me.topchetoeu.animatedchunks.easing.Ease;
import me.topchetoeu.smoothchunks.animation.Animation;
import me.topchetoeu.smoothchunks.easing.Ease;
public class ConfigManager {
public final File configFile;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks;
package me.topchetoeu.smoothchunks;
import org.apache.commons.lang3.Validate;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks;
package me.topchetoeu.smoothchunks;
import java.util.Collection;
import java.util.Collections;

View File

@ -1,32 +1,32 @@
package me.topchetoeu.animatedchunks;
package me.topchetoeu.smoothchunks;
import java.io.File;
import com.terraformersmc.modmenu.api.ConfigScreenFactory;
import com.terraformersmc.modmenu.api.ModMenuApi;
import me.topchetoeu.animatedchunks.Manager.RegisterEvent;
import me.topchetoeu.animatedchunks.animation.Animation;
import me.topchetoeu.animatedchunks.animation.FallAnimation;
import me.topchetoeu.animatedchunks.animation.FlyInAnimation;
import me.topchetoeu.animatedchunks.animation.ProgressManager;
import me.topchetoeu.animatedchunks.animation.RiseAnimation;
import me.topchetoeu.animatedchunks.animation.ScaleAnimation;
import me.topchetoeu.animatedchunks.easing.Ease;
import me.topchetoeu.animatedchunks.easing.ElasticEase;
import me.topchetoeu.animatedchunks.easing.LinearEase;
import me.topchetoeu.animatedchunks.easing.QuadraticEase;
import me.topchetoeu.animatedchunks.easing.SineEase;
import me.topchetoeu.animatedchunks.gui.AnimatedChunksScreen;
import me.topchetoeu.smoothchunks.Manager.RegisterEvent;
import me.topchetoeu.smoothchunks.animation.Animation;
import me.topchetoeu.smoothchunks.animation.FallAnimation;
import me.topchetoeu.smoothchunks.animation.FlyInAnimation;
import me.topchetoeu.smoothchunks.animation.ProgressManager;
import me.topchetoeu.smoothchunks.animation.RiseAnimation;
import me.topchetoeu.smoothchunks.animation.ScaleAnimation;
import me.topchetoeu.smoothchunks.easing.Ease;
import me.topchetoeu.smoothchunks.easing.ElasticEase;
import me.topchetoeu.smoothchunks.easing.LinearEase;
import me.topchetoeu.smoothchunks.easing.SineEase;
import me.topchetoeu.smoothchunks.gui.SmoothChunksScreen;
import me.topchetoeu.smoothchunks.easing.QuadraticEase;
import net.fabricmc.api.ClientModInitializer;
import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientChunkEvents;
import net.fabricmc.fabric.api.event.Event;
import net.minecraft.client.gui.screen.Screen;
import net.minecraft.util.math.BlockPos;
public final class AnimatedChunks implements ClientModInitializer, ModMenuApi {
private static AnimatedChunks instance;
public static AnimatedChunks getInstance() {
public final class SmoothChunks implements ClientModInitializer, ModMenuApi {
private static SmoothChunks instance;
public static SmoothChunks getInstance() {
return instance;
}
@ -134,7 +134,7 @@ public final class AnimatedChunks implements ClientModInitializer, ModMenuApi {
registerEases(ease);
registerAnimations(animation);
config = new ConfigManager(new File("config/animated-chunks.dat"), animation, ease);
config = new ConfigManager(new File("config/smooth-chunks.dat"), animation, ease);
EASES_REGISTERING.invoker().register(ease);
ANIMATIONS_REGISTERING.invoker().register(animation);
@ -148,7 +148,7 @@ public final class AnimatedChunks implements ClientModInitializer, ModMenuApi {
public ConfigScreenFactory<?> getModConfigScreenFactory() {
return (Screen parent) -> {
var _this = getInstance();
return new AnimatedChunksScreen(parent, _this.animation, _this.ease, _this.config);
return new SmoothChunksScreen(parent, _this.animation, _this.ease, _this.config);
};
}
}

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.animation;
package me.topchetoeu.smoothchunks.animation;
import net.minecraft.client.util.math.MatrixStack;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.animation;
package me.topchetoeu.smoothchunks.animation;
import net.minecraft.client.util.math.MatrixStack;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.animation;
package me.topchetoeu.smoothchunks.animation;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.util.math.Vec2f;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.animation;
package me.topchetoeu.smoothchunks.animation;
import java.util.ArrayList;
import java.util.HashSet;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.animation;
package me.topchetoeu.smoothchunks.animation;
import net.minecraft.client.util.math.MatrixStack;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.animation;
package me.topchetoeu.smoothchunks.animation;
import net.minecraft.client.util.math.MatrixStack;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.easing;
package me.topchetoeu.smoothchunks.easing;
public interface Ease {
/**

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.easing;
package me.topchetoeu.smoothchunks.easing;
public class ElasticEase implements Ease {
private float steepness = 1;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.easing;
package me.topchetoeu.smoothchunks.easing;
public class LinearEase implements Ease {
public float ease(float x) {

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.easing;
package me.topchetoeu.smoothchunks.easing;
public class QuadraticEase implements Ease {
@Override

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.easing;
package me.topchetoeu.smoothchunks.easing;
public class SineEase implements Ease {
@Override

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
public class Boundbox implements BoundboxProvider {
public float x, y, width, height;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
public interface BoundboxProvider {
float getX();

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import org.apache.commons.lang3.Validate;
import org.lwjgl.glfw.GLFW;

View File

@ -1,11 +1,11 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import org.lwjgl.glfw.GLFW;
import org.lwjgl.opengl.GL11;
import com.mojang.blaze3d.systems.RenderSystem;
import me.topchetoeu.animatedchunks.AnimatedChunks;
import me.topchetoeu.smoothchunks.SmoothChunks;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.gui.Drawable;
import net.minecraft.client.gui.DrawableHelper;
@ -170,8 +170,8 @@ public class ChunkPreview extends DrawableHelper implements Drawable, Element, S
if (progress < 0) progress = 0;
if (progress > 1) progress = 1;
if (progress < 0.999) {
float _progress = AnimatedChunks.getInstance().getEaseManager().getValue().ease(progress);
AnimatedChunks.getInstance().getAnimationManager().getValue().animate(
float _progress = SmoothChunks.getInstance().getEaseManager().getValue().ease(progress);
SmoothChunks.getInstance().getAnimationManager().getValue().animate(
_progress, matrices,
x * 16, 0, y * 16, 0, 0, 0
);
@ -187,7 +187,7 @@ public class ChunkPreview extends DrawableHelper implements Drawable, Element, S
matrices.pop();
}
private void renderChunks(MatrixStack matrices, float delta, int n) {
duration = AnimatedChunks.getInstance().getProgressManager().getDuration();
duration = SmoothChunks.getInstance().getProgressManager().getDuration();
// globalProgress += (lastTime - (lastTime = System.nanoTime())) / -1000000000f;
globalProgress += delta * 0.05f;
matrices.push();

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import java.util.ArrayList;
import java.util.Hashtable;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import org.apache.commons.lang3.Validate;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import java.util.ArrayList;
import java.util.Collections;

View File

@ -1,10 +1,10 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import java.util.LinkedHashMap;
import java.util.Map;
import me.topchetoeu.animatedchunks.Descriptor;
import me.topchetoeu.animatedchunks.Manager;
import me.topchetoeu.smoothchunks.Descriptor;
import me.topchetoeu.smoothchunks.Manager;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.font.TextRenderer;
import net.minecraft.client.gui.screen.Screen;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import net.minecraft.client.gui.screen.Screen;
import net.minecraft.client.sound.PositionedSoundInstance;
@ -8,14 +8,14 @@ import net.minecraft.text.LiteralText;
import net.minecraft.text.Text;
import net.minecraft.util.Formatting;
import net.minecraft.util.math.ColorHelper.Argb;
import me.topchetoeu.animatedchunks.ConfigManager;
import me.topchetoeu.animatedchunks.Manager;
import me.topchetoeu.animatedchunks.animation.Animation;
import me.topchetoeu.animatedchunks.easing.Ease;
import me.topchetoeu.animatedchunks.gui.Section.OrderType;
import me.topchetoeu.smoothchunks.ConfigManager;
import me.topchetoeu.smoothchunks.Manager;
import me.topchetoeu.smoothchunks.animation.Animation;
import me.topchetoeu.smoothchunks.easing.Ease;
import me.topchetoeu.smoothchunks.gui.Section.OrderType;
import net.minecraft.client.MinecraftClient;
public class AnimatedChunksScreen extends Screen {
public class SmoothChunksScreen extends Screen {
public final Screen parent;
private final HorizontalSection mainSection = new HorizontalSection();
private final Manager<Animation> animation;
@ -105,8 +105,8 @@ public class AnimatedChunksScreen extends Screen {
res.children.addSelectableChild(selectionSection(ease, "Ease"));
return res;
}
public AnimatedChunksScreen(Screen parent, Manager<Animation> animation, Manager<Ease> ease, ConfigManager config) {
super(Text.of("Animated Chunks Config"));
public SmoothChunksScreen(Screen parent, Manager<Animation> animation, Manager<Ease> ease, ConfigManager config) {
super(Text.of("Smooth Chunks Config"));
config.reload();
this.animation = animation;
this.ease = ease;

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.gui;
package me.topchetoeu.smoothchunks.gui;
import java.util.ArrayList;
import java.util.Hashtable;

View File

@ -1,11 +1,11 @@
package me.topchetoeu.animatedchunks.mixin;
package me.topchetoeu.smoothchunks.mixin;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
import me.topchetoeu.animatedchunks.AnimatedChunks;
import me.topchetoeu.smoothchunks.SmoothChunks;
import net.minecraft.client.render.chunk.ChunkBuilder;
import net.minecraft.util.math.BlockPos;
@ -17,6 +17,6 @@ abstract class BuiltChunkMixin {
// ci.cancel();
// return;
BlockPos origin = ((ChunkBuilder.BuiltChunk)(Object)this).getOrigin();
AnimatedChunks.getInstance().getProgressManager().unload(origin.getX(), 0, origin.getZ());
SmoothChunks.getInstance().getProgressManager().unload(origin.getX(), 0, origin.getZ());
}
}

View File

@ -1,4 +1,4 @@
package me.topchetoeu.animatedchunks.mixin;
package me.topchetoeu.smoothchunks.mixin;
import net.minecraft.client.gl.GlUniform;
import net.minecraft.client.render.BuiltChunkStorage;
@ -21,8 +21,8 @@ import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
import org.spongepowered.asm.mixin.injection.callback.LocalCapture;
import it.unimi.dsi.fastutil.objects.ObjectListIterator;
import me.topchetoeu.animatedchunks.AnimatedChunks;
import me.topchetoeu.animatedchunks.animation.ProgressManager;
import me.topchetoeu.smoothchunks.SmoothChunks;
import me.topchetoeu.smoothchunks.animation.ProgressManager;
@Mixin(WorldRenderer.class)
abstract class WorldRendererMixin {
@ -31,7 +31,7 @@ abstract class WorldRendererMixin {
@Accessor abstract BuiltChunkStorage getChunks();
private ProgressManager getProgressManager() {
return AnimatedChunks.getInstance().getProgressManager();
return SmoothChunks.getInstance().getProgressManager();
}
@Inject(method = "render", at = @At(value = "HEAD"))
@ -69,14 +69,14 @@ abstract class WorldRendererMixin {
float progress = getProgressManager().getChunkProgress(x, 0, z);
if (progress < 0.999) {
progress = AnimatedChunks.getInstance().getEaseManager().getValue().ease(progress);
progress = SmoothChunks.getInstance().getEaseManager().getValue().ease(progress);
float centerX = (float)playerX - x;
float centerY = (float)playerY - y;
float centerZ = (float)playerZ - z;
matrices.translate(-centerX, -centerY, -centerZ);
AnimatedChunks.getInstance().getAnimationManager().getValue().animate(progress, matrices, x, y, z, (float)playerX, (float)playerY, (float)playerZ);
SmoothChunks.getInstance().getAnimationManager().getValue().animate(progress, matrices, x, y, z, (float)playerX, (float)playerY, (float)playerZ);
matrices.translate(centerX, centerY, centerZ);
}
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

View File

@ -1,24 +1,24 @@
{
"schemaVersion": 1,
"id": "animated-chunks",
"id": "smooth-chunks",
"version": "0.2.0",
"name": "Animated Chunks",
"description": "animated chunk load animations.",
"name": "Smooth Chunks",
"description": "Smooth chunk load animations.",
"authors": [ "TopchetoEU" ],
"license": "MIT",
"icon": "assets/animated-chunks/icon.png",
"icon": "assets/smooth-chunks/icon.png",
"environment": "client",
"accessWidener": "animated-chunks.accesswidener",
"accessWidener": "smooth-chunks.accesswidener",
"entrypoints": {
"client": [
"me.topchetoeu.animatedchunks.AnimatedChunks"
"me.topchetoeu.smoothchunks.SmoothChunks"
],
"modmenu": [
"me.topchetoeu.animatedchunks.AnimatedChunks"
"me.topchetoeu.smoothchunks.SmoothChunks"
]
},
"mixins": [
"animated-chunks.mixins.json"
"smooth-chunks.mixins.json"
],
"depends": {
"fabricloader": ">=0.9.3+build.207",

View File

@ -1,7 +1,7 @@
{
"required": true,
"minVersion": "0.8",
"package": "me.topchetoeu.animatedchunks.mixin",
"package": "me.topchetoeu.smoothchunks.mixin",
"compatibilityLevel": "JAVA_17",
"mixins": [],
"client": [