Compare commits

..

20 Commits

Author SHA1 Message Date
ca2dac47b8 Port to Minecraft 1.21.9
Some checks failed
build / build (17, ubuntu-20.04) (push) Has been cancelled
build-release / build (release) Has been cancelled
2025-12-31 06:40:30 +00:00
ec9a0ff865 Port to Minecraft 1.21.9
Some checks failed
build / build (17, ubuntu-20.04) (push) Has been cancelled
2025-12-31 07:39:39 +01:00
959f435e8f Port to Minecraft 1.21.10
Some checks failed
build / build (17, ubuntu-20.04) (push) Has been cancelled
2025-12-31 07:32:59 +01:00
Rain Graham
e0eba682ed update to 1.21.8 2025-09-05 11:51:07 +01:00
Rain Graham
459e6de64a update to 1.20.5 2025-04-27 11:44:36 +01:00
Liz Graham
db9040acc5 update to 1.21.4 2025-01-20 06:48:43 +00:00
Rain Graham
be27cf0f30 Merge pull request #27 from mpustovoi/1.18.2
Create ru_ru.json
2024-11-17 09:21:20 +00:00
Rain Graham
734ea7a1a2 Merge pull request #35 from SnowCutieOwO/patch-1
Create zh_cn.json
2024-11-17 09:20:54 +00:00
Liz Graham
71832342af update to 1.21.3, fix bugs, close issue #31, #34, #37 and #39. 2024-11-17 09:18:01 +00:00
Rain Graham
4b4b2ad206 break config, but now works in 1.21.3 2024-11-05 15:31:44 +00:00
SnowCutieOwO
e795778ba8 Create zh_cn.json
Added Simplified Chinese translation <3
2024-08-04 13:04:38 +08:00
Liz Graham
99ffeb1f99 update to 1.21, update to Gradle 8.8, update to Loom 1.7 2024-06-27 15:09:42 +01:00
Liz Graham
4e1a122289 add cave dust particle
calculate position inside blocks
changed menu
changed modid to cavedust
change some default values
fix bug where user got softlocked in the particle cycle in multiplayer
2024-05-17 02:30:53 +01:00
Korben
2161bbd1ba Create ru_ru.json 2024-03-13 12:29:23 +03:00
Liz Graham
e35fdaa8ce Merge pull request #19 from Myuui/1.18.2
French Translation by @Myuui
2024-01-21 01:59:17 +00:00
Liz Graham
a0aef4a5ef Merge pull request #20 from arunsathiya/1.18.2
ci: Use GITHUB_OUTPUT envvar instead of set-output command
2024-01-21 01:57:17 +00:00
Liz Graham
39cf0a0703 update to 1.20.4
loader to 1.15.5
loom to 1.5
gradle to 8.5
2024-01-17 14:48:06 +00:00
Arun
22928e4885 ci: Use GITHUB_OUTPUT envvar instead of set-output command 2024-01-11 21:22:27 -08:00
Myuui
8cb6407f8b French Translation by Myuui 2023-12-17 23:58:18 +01:00
Liz Graham
1a097e6daf Update README.md 2023-05-21 07:43:40 +01:00
20 changed files with 295 additions and 220 deletions

View File

@@ -24,12 +24,12 @@ jobs:
- name: Extract current branch name - name: Extract current branch name
shell: bash shell: bash
# bash pattern expansion to grab branch name without slashes # bash pattern expansion to grab branch name without slashes
run: ref="${GITHUB_REF#refs/heads/}" && echo "::set-output name=branch::${ref////-}" run: ref="${GITHUB_REF#refs/heads/}" && echo "branch=${ref////-}" >> $GITHUB_OUTPUT
id: ref id: ref
- name: Set outputs - name: Set outputs
id: vars id: vars
run: echo "::set-output name=sha_short::$(git rev-parse --short HEAD)" run: echo "sha_short=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
- name: Check outputs - name: Check outputs
run: echo ${{ steps.vars.outputs.sha_short }} run: echo ${{ steps.vars.outputs.sha_short }}

View File

@@ -1,11 +1,8 @@
plugins { plugins {
id 'fabric-loom' version '1.6-SNAPSHOT' id 'fabric-loom' version '1.11-SNAPSHOT'
id 'maven-publish' id 'maven-publish'
} }
sourceCompatibility = JavaVersion.VERSION_17
targetCompatibility = JavaVersion.VERSION_17
archivesBaseName = project.archives_base_name archivesBaseName = project.archives_base_name
version = project.mod_version version = project.mod_version
group = project.maven_group group = project.maven_group
@@ -61,7 +58,7 @@ processResources {
tasks.withType(JavaCompile).configureEach { tasks.withType(JavaCompile).configureEach {
// Minecraft 1.18 (1.18-pre2) upwards uses Java 17. // Minecraft 1.18 (1.18-pre2) upwards uses Java 17.
it.options.release = 17 it.options.release = 21
} }
java { java {
@@ -69,6 +66,8 @@ java {
// if it is present. // if it is present.
// If you remove this line, sources will not be generated. // If you remove this line, sources will not be generated.
withSourcesJar() withSourcesJar()
sourceCompatibility = JavaVersion.VERSION_21
targetCompatibility = JavaVersion.VERSION_21
} }
jar { jar {

View File

@@ -3,17 +3,17 @@ org.gradle.jvmargs=-Xmx1G
# Fabric Properties # Fabric Properties
# check these on https://fabricmc.net/develop # check these on https://fabricmc.net/develop
minecraft_version=1.20.1 minecraft_version=1.21.9
yarn_mappings=1.20.1+build.10 yarn_mappings=1.21.9+build.1
loader_version=0.15.11 loader_version=0.18.4
loom_version=1.14-SNAPSHOT
# Mod Properties # Mod Properties
mod_version=3.0.1 mod_version=1.0.0
maven_group=com.lizistired maven_group=com.straice
archives_base_name=cave_dust archives_base_name=cave_dust_reforged
# Dependencies # Dependencies
fabric_version=0.92.2+1.20.1 fabric_version=0.134.1+1.21.9
clothconfig_version=11.1.118 modmenu_version=16.0.0-rc.2
modmenu_version=7.2.2 kirin_version=1.21.1+1.21.7
kirin_version=1.15.6+1.20.1

Binary file not shown.

View File

@@ -1,6 +1,7 @@
distributionBase=GRADLE_USER_HOME distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip distributionUrl=https\://services.gradle.org/distributions/gradle-8.14-bin.zip
networkTimeout=10000 networkTimeout=10000
validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists zipStorePath=wrapper/dists

27
gradlew vendored
View File

@@ -15,6 +15,8 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
# SPDX-License-Identifier: Apache-2.0
#
############################################################################## ##############################################################################
# #
@@ -55,7 +57,7 @@
# Darwin, MinGW, and NonStop. # Darwin, MinGW, and NonStop.
# #
# (3) This script is generated from the Groovy template # (3) This script is generated from the Groovy template
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt # https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
# within the Gradle project. # within the Gradle project.
# #
# You can find Gradle at https://github.com/gradle/gradle/. # You can find Gradle at https://github.com/gradle/gradle/.
@@ -83,7 +85,9 @@ done
# This is normally unused # This is normally unused
# shellcheck disable=SC2034 # shellcheck disable=SC2034
APP_BASE_NAME=${0##*/} APP_BASE_NAME=${0##*/}
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit # Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s
' "$PWD" ) || exit
# Use the maximum available, or set MAX_FD != -1 to use that value. # Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD=maximum MAX_FD=maximum
@@ -130,10 +134,13 @@ location of your Java installation."
fi fi
else else
JAVACMD=java JAVACMD=java
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. if ! command -v java >/dev/null 2>&1
then
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the Please set the JAVA_HOME variable in your environment to match the
location of your Java installation." location of your Java installation."
fi
fi fi
# Increase the maximum file descriptors if we can. # Increase the maximum file descriptors if we can.
@@ -141,7 +148,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
case $MAX_FD in #( case $MAX_FD in #(
max*) max*)
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
# shellcheck disable=SC3045 # shellcheck disable=SC2039,SC3045
MAX_FD=$( ulimit -H -n ) || MAX_FD=$( ulimit -H -n ) ||
warn "Could not query maximum file descriptor limit" warn "Could not query maximum file descriptor limit"
esac esac
@@ -149,7 +156,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
'' | soft) :;; #( '' | soft) :;; #(
*) *)
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
# shellcheck disable=SC3045 # shellcheck disable=SC2039,SC3045
ulimit -n "$MAX_FD" || ulimit -n "$MAX_FD" ||
warn "Could not set maximum file descriptor limit to $MAX_FD" warn "Could not set maximum file descriptor limit to $MAX_FD"
esac esac
@@ -198,11 +205,11 @@ fi
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
# Collect all arguments for the java command; # Collect all arguments for the java command:
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of # * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
# shell script including quotes and variable substitutions, so put them in # and any embedded shellness will be escaped.
# double quotes to make sure that they get re-expanded; and # * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
# * put everything else in single quotes, so that it's not re-expanded. # treated as '${Hostname}' itself on the command line.
set -- \ set -- \
"-Dorg.gradle.appname=$APP_BASE_NAME" \ "-Dorg.gradle.appname=$APP_BASE_NAME" \

22
gradlew.bat vendored
View File

@@ -13,6 +13,8 @@
@rem See the License for the specific language governing permissions and @rem See the License for the specific language governing permissions and
@rem limitations under the License. @rem limitations under the License.
@rem @rem
@rem SPDX-License-Identifier: Apache-2.0
@rem
@if "%DEBUG%"=="" @echo off @if "%DEBUG%"=="" @echo off
@rem ########################################################################## @rem ##########################################################################
@@ -43,11 +45,11 @@ set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1 %JAVA_EXE% -version >NUL 2>&1
if %ERRORLEVEL% equ 0 goto execute if %ERRORLEVEL% equ 0 goto execute
echo. echo. 1>&2
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
echo. echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. echo location of your Java installation. 1>&2
goto fail goto fail
@@ -57,11 +59,11 @@ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
if exist "%JAVA_EXE%" goto execute if exist "%JAVA_EXE%" goto execute
echo. echo. 1>&2
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
echo. echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. echo location of your Java installation. 1>&2
goto fail goto fail

View File

@@ -1,103 +1,129 @@
package net.lizistired.cavedust; package net.lizistired.cavedust;
//minecraft imports // minecraft imports
import net.fabricmc.api.ClientModInitializer;
import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents;
import net.fabricmc.fabric.api.client.particle.v1.ParticleFactoryRegistry; import net.fabricmc.fabric.api.client.particle.v1.ParticleFactoryRegistry;
import net.minecraft.block.Blocks;
import net.minecraft.client.MinecraftClient; import net.minecraft.client.MinecraftClient;
import net.minecraft.particle.ParticleEffect; import net.minecraft.particle.ParticleEffect;
import net.minecraft.particle.ParticleTypes;
import net.minecraft.registry.Registries; import net.minecraft.registry.Registries;
import net.minecraft.text.Text; import net.minecraft.text.Text;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World; import net.minecraft.world.World;
//other imports
// other imports
import com.minelittlepony.common.util.GamePaths; import com.minelittlepony.common.util.GamePaths;
import net.fabricmc.api.ClientModInitializer;
import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
//java imports
import java.nio.file.Path;
//static imports
import static net.lizistired.cavedust.utils.MathHelper.*;
import static net.lizistired.cavedust.utils.MathHelper.generateRandomDouble;
import static net.lizistired.cavedust.utils.ParticleSpawnUtil.shouldParticlesSpawn;
import static net.lizistired.cavedust.utils.KeybindingHelper.*;
// java imports
import java.nio.file.Path;
// static imports
import static net.lizistired.cavedust.utils.KeybindingHelper.*;
import static net.lizistired.cavedust.utils.MathHelper.generateRandomDouble;
import static net.lizistired.cavedust.utils.MathHelper.normalize;
import static net.lizistired.cavedust.utils.ParticleSpawnUtil.shouldParticlesSpawn;
public class CaveDust implements ClientModInitializer { public class CaveDust implements ClientModInitializer {
//logger // logger
public static final Logger LOGGER = LoggerFactory.getLogger("cavedust"); public static final Logger LOGGER = LoggerFactory.getLogger("cavedust");
//make class static
// make class static
private static CaveDust instance; private static CaveDust instance;
public static CaveDust getInstance() { public static CaveDust getInstance() {
return instance; return instance;
} }
public CaveDust() { public CaveDust() {
instance = this; instance = this;
} }
//config assignment
private static net.lizistired.cavedust.CaveDustConfig config; // config assignment
public net.lizistired.cavedust.CaveDustConfig getConfig() { private static CaveDustConfig config;
public CaveDustConfig getConfig() {
return config; return config;
} }
public static ParticleEffect WHITE_ASH_ID = (ParticleEffect) Registries.PARTICLE_TYPE.get(Identifier.of("cavedust", "cave_dust"));
public static int PARTICLE_AMOUNT = 0;
public static ParticleEffect WHITE_ASH_ID =
(ParticleEffect) Registries.PARTICLE_TYPE.get(Identifier.of("cavedust", "cave_dust"));
public static int PARTICLE_AMOUNT = 0;
@Override @Override
public void onInitializeClient() { public void onInitializeClient() {
//config path and loading // config path and loading
Path CaveDustFolder = GamePaths.getConfigDirectory().resolve("cavedust"); Path caveDustFolder = GamePaths.getConfigDirectory().resolve("cavedust");
config = new CaveDustConfig(CaveDustFolder.getParent().resolve("cavedust.json"), this); config = new CaveDustConfig(caveDustFolder.getParent().resolve("cavedust.json"), this);
config.load(); config.load();
registerKeyBindings(); registerKeyBindings();
ParticleFactoryRegistry.getInstance().register(CaveDustServer.CAVE_DUST, CaveDustParticleFactory.Factory::new); ParticleFactoryRegistry.getInstance().register(CaveDustServer.CAVE_DUST, CaveDustParticleFactory.Factory::new);
//register end client tick to create cave dust function, using end client tick for async
// register end client tick to create cave dust function, using end client tick for async
ClientTickEvents.END_CLIENT_TICK.register(this::createCaveDust); ClientTickEvents.END_CLIENT_TICK.register(this::createCaveDust);
} }
private void createCaveDust(MinecraftClient client) { private void createCaveDust(MinecraftClient client) {
if (keyBinding1.wasPressed()){ if (client.player == null) return;
if (keyBinding1.wasPressed()) {
getConfig().toggleCaveDust(); getConfig().toggleCaveDust();
LOGGER.info("Toggled dust"); LOGGER.info("Toggled dust");
client.player.sendMessage(Text.translatable("debug.cavedust.toggle." + config.getCaveDustEnabled()), false); client.player.sendMessage(
Text.translatable("debug.cavedust.toggle." + config.getCaveDustEnabled()),
false
);
} }
if (keyBinding2.wasPressed()){
if (keyBinding2.wasPressed()) {
getConfig().load(); getConfig().load();
LOGGER.info("Reloaded config"); LOGGER.info("Reloaded config");
client.player.sendMessage(Text.translatable("debug.cavedust.reload"), false); client.player.sendMessage(Text.translatable("debug.cavedust.reload"), false);
} }
//ensure world is not null // ensure world is not null
if (client.world == null) return; if (client.world == null) return;
World world = client.world; World world = client.world;
//LOGGER.info(String.valueOf(((ClientWorldAccessor) client.world.getLevelProperties()).getFlatWorld()));
// ) double probabilityNormalized =
double probabilityNormalized = normalize(config.getLowerLimit(), config.getUpperLimit(), client.player.getBlockY()); normalize(config.getLowerLimit(), config.getUpperLimit(), client.player.getBlockY());
PARTICLE_AMOUNT = (int) (probabilityNormalized * config.getParticleMultiplier() * config.getParticleMultiplierMultiplier());
PARTICLE_AMOUNT = (int) (probabilityNormalized
* config.getParticleMultiplier()
* config.getParticleMultiplierMultiplier());
for (int i = 0; i < PARTICLE_AMOUNT; i++) { for (int i = 0; i < PARTICLE_AMOUNT; i++) {
try { int x = (int) (client.player.getX()
int x = (int) (client.player.getPos().getX() + (int) generateRandomDouble(config.getDimensionWidth() *-1, config.getDimensionWidth())); + generateRandomDouble(-config.getDimensionWidth(), config.getDimensionWidth()));
int y = (int) (client.player.getEyePos().getY() + (int) generateRandomDouble(config.getDimensionHeight() *-1, config.getDimensionHeight()));
int z = (int) (client.player.getPos().getZ() + (int) generateRandomDouble(config.getDimensionWidth() *-1, config.getDimensionWidth())); int y = (int) (client.player.getEyeY()
double miniX = (x + Math.random()); + generateRandomDouble(-config.getDimensionHeight(), config.getDimensionHeight()));
double miniY = (y + Math.random());
double miniZ = (z + Math.random()); int z = (int) (client.player.getZ()
+ generateRandomDouble(-config.getDimensionWidth(), config.getDimensionWidth()));
double miniX = x + Math.random();
double miniY = y + Math.random();
double miniZ = z + Math.random();
BlockPos particlePos = new BlockPos(x, y, z); BlockPos particlePos = new BlockPos(x, y, z);
if (shouldParticlesSpawn(client, config, particlePos)) { if (shouldParticlesSpawn(client, config, particlePos)) {
if (client.world.getBlockState(particlePos).isAir()) { if (client.world.getBlockState(particlePos).isAir()) {
world.addParticle(config.getParticle(), miniX, miniY, miniZ, config.getVelocityRandomnessRandom() * 0.01, config.getVelocityRandomnessRandom() * 0.01, config.getVelocityRandomnessRandom() * 0.01); world.addParticleClient(
getConfig().getParticle(),
miniX, miniY, miniZ,
config.getVelocityRandomnessRandom() * 0.01,
config.getVelocityRandomnessRandom() * 0.01,
config.getVelocityRandomnessRandom() * 0.01
);
} }
} }
} }
catch (NullPointerException e) {
LOGGER.error(String.valueOf(e));
//getConfig().setParticleID(WHITE_ASH_ID);
}
}
} }
} }

View File

@@ -2,55 +2,81 @@ package net.lizistired.cavedust;
import net.fabricmc.api.EnvType; import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment; import net.fabricmc.api.Environment;
import net.lizistired.cavedust.utils.MathHelper; import net.minecraft.client.particle.BillboardParticle;
import net.minecraft.client.particle.*; import net.minecraft.client.particle.Particle;
import net.minecraft.client.particle.ParticleFactory;
import net.minecraft.client.particle.SpriteProvider;
import net.minecraft.client.world.ClientWorld; import net.minecraft.client.world.ClientWorld;
import net.minecraft.particle.DefaultParticleType; import net.minecraft.particle.SimpleParticleType;
import net.minecraft.particle.ParticleEffect; import net.minecraft.util.math.random.Random;
import org.jetbrains.annotations.Nullable;
public class CaveDustParticleFactory extends SpriteBillboardParticle { @Environment(EnvType.CLIENT)
public class CaveDustParticleFactory extends BillboardParticle {
private final SpriteProvider spriteProvider; private final SpriteProvider spriteProvider;
CaveDustParticleFactory(ClientWorld clientWorld, double x, double y, double z, double velocityX, double velocityY, double velocityZ, SpriteProvider spriteProvider) {
super(clientWorld, x, y, z); CaveDustParticleFactory(
this.spriteProvider = spriteProvider; //Sets the sprite provider from above to the sprite provider in the constructor method ClientWorld world,
this.maxAge = 200; //20 ticks = 1 second double x, double y, double z,
this.velocityX = velocityX; //The velX from the constructor parameters double velocityX, double velocityY, double velocityZ,
this.velocityY = -0.007f; //Allows the particle to slowly fall SpriteProvider spriteProvider
) {
// En 1.21.9+ BillboardParticle puede recibir sprite inicial
super(world, x, y, z, velocityX, velocityY, velocityZ, spriteProvider.getFirst());
this.spriteProvider = spriteProvider;
this.maxAge = 200; // 20 ticks = 1s
this.scale = 0.1f;
this.velocityX = velocityX;
this.velocityY = -0.007f;
this.velocityZ = velocityZ; this.velocityZ = velocityZ;
this.x = x; //The x from the constructor parameters
this.y = y;
this.z = z;
this.collidesWithWorld = true; this.collidesWithWorld = true;
this.alpha = 1.0f; //Setting the alpha to 1.0f means there will be no opacity change until the alpha value is changed this.alpha = 1.0f;
this.setSpriteForAge(spriteProvider); //Required
// Selecciona el sprite correcto según edad/maxAge (equivalente a setSpriteForAge)
this.updateSprite(spriteProvider);
}
@Override
protected BillboardParticle.RenderType getRenderType() {
return BillboardParticle.RenderType.PARTICLE_ATLAS_TRANSLUCENT;
} }
@Override @Override
public void tick() { public void tick() {
super.tick(); super.tick();
if(this.alpha < 0.0f){
this.markDead(); if (!this.isAlive()) {
} return;
this.alpha -= 0.005f;
} }
@Override this.alpha -= 0.005f;
public ParticleTextureSheet getType() { if (this.alpha <= 0.0f) {
return ParticleTextureSheet.PARTICLE_SHEET_TRANSLUCENT; this.markDead();
return;
}
this.updateSprite(this.spriteProvider);
} }
@Environment(EnvType.CLIENT) @Environment(EnvType.CLIENT)
public static class Factory implements ParticleFactory<DefaultParticleType> { public static class Factory implements ParticleFactory<SimpleParticleType> {
private final SpriteProvider spriteProvider; private final SpriteProvider spriteProvider;
public Factory(SpriteProvider spriteProvider) { public Factory(SpriteProvider spriteProvider) {
this.spriteProvider = spriteProvider; this.spriteProvider = spriteProvider;
} }
@Override @Override
public @Nullable Particle createParticle(DefaultParticleType parameters, ClientWorld world, double x, double y, double z, double velocityX, double velocityY, double velocityZ) { public Particle createParticle(
SimpleParticleType type,
ClientWorld world,
double x, double y, double z,
double velocityX, double velocityY, double velocityZ,
Random random
) {
return new CaveDustParticleFactory(world, x, y, z, velocityX, velocityY, velocityZ, this.spriteProvider); return new CaveDustParticleFactory(world, x, y, z, velocityX, velocityY, velocityZ, this.spriteProvider);
} }
} }

View File

@@ -2,19 +2,18 @@ package net.lizistired.cavedust;
import net.fabricmc.api.ModInitializer; import net.fabricmc.api.ModInitializer;
import net.fabricmc.fabric.api.particle.v1.FabricParticleTypes; import net.fabricmc.fabric.api.particle.v1.FabricParticleTypes;
import net.minecraft.particle.DefaultParticleType; import net.minecraft.particle.SimpleParticleType;
import net.minecraft.particle.ParticleEffect;
import net.minecraft.registry.Registries; import net.minecraft.registry.Registries;
import net.minecraft.registry.Registry; import net.minecraft.registry.Registry;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
public class CaveDustServer implements ModInitializer { public class CaveDustServer implements ModInitializer {
public static final DefaultParticleType CAVE_DUST = FabricParticleTypes.simple(); public static final SimpleParticleType CAVE_DUST = FabricParticleTypes.simple();
/** /**
* Runs the mod initializer. * Runs the mod initializer.
*/ */
@Override @Override
public void onInitialize() { public void onInitialize() {
Registry.register(Registries.PARTICLE_TYPE, new Identifier("cavedust", "cave_dust"), CAVE_DUST); Registry.register(Registries.PARTICLE_TYPE, Identifier.of("cavedust", "cave_dust"), CAVE_DUST);
} }
} }

View File

@@ -8,7 +8,6 @@ import net.minecraft.client.gui.screen.Screen;
import net.minecraft.particle.ParticleType; import net.minecraft.particle.ParticleType;
import net.minecraft.registry.Registries; import net.minecraft.registry.Registries;
import net.minecraft.text.Text; import net.minecraft.text.Text;
import net.minecraft.util.Identifier;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
@@ -77,13 +76,13 @@ public class ModMenuConfigScreen extends GameGui {
addButton(new Slider(left += 220, row -= 96, 1, 50, config.getDimensionWidth())) addButton(new Slider(left += 220, row -= 96, 1, 50, config.getDimensionWidth()))
.onChange(config::setDimensionWidth) .onChange(config::setDimensionWidth)
.setTextFormat(transText::formatMaxX) .setTextFormat(transText::formatMaxWidth)
.getStyle().setTooltip(Text.translatable("menu.cavedust.X.tooltip")); .getStyle().setTooltip(Text.translatable("menu.cavedust.width.tooltip"));
addButton(new Slider(left, row += 24, 1, 50, config.getDimensionHeight())) addButton(new Slider(left, row += 24, 1, 50, config.getDimensionHeight()))
.onChange(config::setDimensionHeight) .onChange(config::setDimensionHeight)
.setTextFormat(transText::formatMaxY) .setTextFormat(transText::formatMaxHeight)
.getStyle().setTooltip(Text.translatable("menu.cavedust.Y.tooltip")); .getStyle().setTooltip(Text.translatable("menu.cavedust.height.tooltip"));
addButton(new Slider(left, row += 24, 0, 10, config.getVelocityRandomness())) addButton(new Slider(left, row += 24, 0, 10, config.getVelocityRandomness()))
.onChange(config::setVelocityRandomness) .onChange(config::setVelocityRandomness)
@@ -106,18 +105,17 @@ public class ModMenuConfigScreen extends GameGui {
@Override @Override
public void render(DrawContext context, int mouseX, int mouseY, float partialTicks) { public void render(DrawContext context, int mouseX, int mouseY, float partialTicks) {
renderBackground(context);
super.render(context, mouseX, mouseY, partialTicks); super.render(context, mouseX, mouseY, partialTicks);
} }
private Identifier getNameOfParticle(){ private String getNameOfParticle(){
CaveDustConfig config = CaveDust.getInstance().getConfig(); CaveDustConfig config = CaveDust.getInstance().getConfig();
config.load(); config.load();
try { try {
return Registries.PARTICLE_TYPE.getId((ParticleType<?>) config.getParticleID()); return Registries.PARTICLE_TYPE.getEntry((ParticleType<?>) config.getParticleID()).getIdAsString();
} catch (NoSuchElementException e) { } catch (NoSuchElementException e){
CaveDust.LOGGER.error(String.valueOf(e)); CaveDust.LOGGER.error(String.valueOf(e));
return null; return "null";
} }
} }
} }

View File

@@ -6,19 +6,31 @@ import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject; import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import static net.lizistired.cavedust.CaveDust.PARTICLE_AMOUNT; import static net.lizistired.cavedust.CaveDust.PARTICLE_AMOUNT;
import static net.lizistired.cavedust.utils.ParticleSpawnUtil.shouldParticlesSpawn;
@Mixin(DebugHud.class) @Mixin(DebugHud.class)
public abstract class MixinDebugScreenOverlay { public abstract class MixinDebugScreenOverlay {
@Inject(method = "getRightText", at = @At("RETURN"))
@Inject(
method = "getRightText()Ljava/util/List;",
at = @At("RETURN"),
cancellable = true,
require = 0
)
private void appendDebugText(CallbackInfoReturnable<List<String>> cir) { private void appendDebugText(CallbackInfoReturnable<List<String>> cir) {
List<String> messages = cir.getReturnValue(); List<String> messages = cir.getReturnValue();
if (messages == null) return;
messages.add(""); // Evita modificar una lista inmutable/compartida
messages.add("Particle amount evaluated: " + PARTICLE_AMOUNT); List<String> out = new ArrayList<>(messages);
messages.add("");
out.add("");
out.add("Particle amount evaluated: " + PARTICLE_AMOUNT);
out.add("");
cir.setReturnValue(out);
} }
} }

View File

@@ -3,6 +3,7 @@ package net.lizistired.cavedust.utils;
import net.fabricmc.fabric.api.client.keybinding.v1.KeyBindingHelper; import net.fabricmc.fabric.api.client.keybinding.v1.KeyBindingHelper;
import net.minecraft.client.option.KeyBinding; import net.minecraft.client.option.KeyBinding;
import net.minecraft.client.util.InputUtil; import net.minecraft.client.util.InputUtil;
import net.minecraft.util.Identifier;
import org.lwjgl.glfw.GLFW; import org.lwjgl.glfw.GLFW;
public class KeybindingHelper { public class KeybindingHelper {
@@ -10,19 +11,23 @@ public class KeybindingHelper {
public static KeyBinding keyBinding1; public static KeyBinding keyBinding1;
public static KeyBinding keyBinding2; public static KeyBinding keyBinding2;
// 1.21.9+ requiere Category (no String)
private static final KeyBinding.Category CATEGORY =
KeyBinding.Category.create(Identifier.of("cavedust", "spook"));
public static void registerKeyBindings(){ public static void registerKeyBindings() {
keyBinding1 = KeyBindingHelper.registerKeyBinding(new KeyBinding( keyBinding1 = KeyBindingHelper.registerKeyBinding(new KeyBinding(
"key.cavedust.toggle", "key.cavedust.toggle",
InputUtil.Type.KEYSYM,// The translation key of the keybinding's name // The type of the keybinding, KEYSYM for keyboard, MOUSE for mouse. InputUtil.Type.KEYSYM,
GLFW.GLFW_KEY_KP_ADD, // The keycode of the key GLFW.GLFW_KEY_KP_ADD,
"category.cavedust.spook" // The translation key of the keybinding's category. CATEGORY
)); ));
keyBinding2 = KeyBindingHelper.registerKeyBinding(new KeyBinding( keyBinding2 = KeyBindingHelper.registerKeyBinding(new KeyBinding(
"key.cavedust.reload", // The translation key of the keybinding's name "key.cavedust.reload",
InputUtil.Type.KEYSYM, // The type of the keybinding, KEYSYM for keyboard, MOUSE for mouse. InputUtil.Type.KEYSYM,
GLFW.GLFW_KEY_KP_ENTER, // The keycode of the key GLFW.GLFW_KEY_KP_ENTER,
"category.cavedust.spook" // The translation key of the keybinding's category. CATEGORY
)); ));
} }
} }

View File

@@ -22,14 +22,21 @@ public class ParticleSpawnUtil {
*/ */
public static boolean shouldParticlesSpawn(MinecraftClient client, CaveDustConfig config) { public static boolean shouldParticlesSpawn(MinecraftClient client, CaveDustConfig config) {
//checks if the config is enabled, if the game isn't paused, if the world is valid, if the particle is valid and if the player isn't in a lush caves biome if (client.player == null) {
timer = 0;
shouldParticlesSpawn = false;
return false;
}
// checks if the config is enabled, if the game isn't paused, if the world is valid,
// if the dimension is valid and if the player isn't in a lush caves biome
if (!config.getCaveDustEnabled() if (!config.getCaveDustEnabled()
|| client.isPaused() || client.isPaused()
|| client.world == null || client.world == null
|| !client.world.getDimension().bedWorks() || !client.world.getDimension().bedWorks()
|| Objects.requireNonNull(client.player).isSubmergedInWater() || client.player.isSubmergedInWater()
|| client.world.getBiome(Objects.requireNonNull(client.player.getBlockPos())).matchesKey(LUSH_CAVES)) || client.world.getBiome(client.player.getBlockPos()).matchesKey(LUSH_CAVES)) {
{
timer = 0; timer = 0;
shouldParticlesSpawn = false; shouldParticlesSpawn = false;
return false; return false;
@@ -38,16 +45,18 @@ public class ParticleSpawnUtil {
World world = client.world; World world = client.world;
int seaLevel = world.getSeaLevel(); int seaLevel = world.getSeaLevel();
if (!client.player.clientWorld.isSkyVisible(client.player.getBlockPos())) { // 1.21.10: usar world directamente
if (client.player.getBlockPos().getY() + 2 < seaLevel){ if (!world.isSkyVisible(client.player.getBlockPos())) {
if (client.player.getBlockPos().getY() + 2 < seaLevel) {
timer = timer + 1; timer = timer + 1;
if (timer > 10){ if (timer > 10) {
timer = 10; timer = 10;
shouldParticlesSpawn = true; shouldParticlesSpawn = true;
return true; return true;
} }
} }
} }
shouldParticlesSpawn = false; shouldParticlesSpawn = false;
return false; return false;
} }
@@ -61,20 +70,27 @@ public class ParticleSpawnUtil {
*/ */
public static boolean shouldParticlesSpawn(MinecraftClient client, CaveDustConfig config, BlockPos pos) { public static boolean shouldParticlesSpawn(MinecraftClient client, CaveDustConfig config, BlockPos pos) {
//checks if the config is enabled, if the game isn't paused, if the world is valid, if the particle is valid and if the player isn't in a lush caves biome // checks if the config is enabled, if the game isn't paused, if the world is valid,
// if the dimension is valid and if the particle position isn't in lush caves
if (!config.getCaveDustEnabled() if (!config.getCaveDustEnabled()
|| client.isPaused() || client.isPaused()
|| client.world == null || client.world == null
|| !client.world.getDimension().bedWorks() || !client.world.getDimension().bedWorks()
|| (client.world.getBottomY() > pos.getY()) || (client.world.getBottomY() > pos.getY())
|| client.world.getBiome(Objects.requireNonNull(pos)).matchesKey(LUSH_CAVES)) || client.world.getBiome(Objects.requireNonNull(pos)).matchesKey(LUSH_CAVES)) {
{
timer = 0; timer = 0;
shouldParticlesSpawn = false; shouldParticlesSpawn = false;
return false; return false;
} }
if(!config.getSuperFlatStatus()) {
if (client.player == null) {
timer = 0;
shouldParticlesSpawn = false;
return false;
}
if (!config.getSuperFlatStatus()) {
if (((ClientWorldAccessor) client.world.getLevelProperties()).getFlatWorld()) { if (((ClientWorldAccessor) client.world.getLevelProperties()).getFlatWorld()) {
return false; return false;
} }
@@ -83,16 +99,18 @@ public class ParticleSpawnUtil {
World world = client.world; World world = client.world;
int seaLevel = world.getSeaLevel(); int seaLevel = world.getSeaLevel();
if (!client.player.clientWorld.isSkyVisible(pos)) { // 1.21.10: usar world directamente
if (pos.getY() + 2 < seaLevel){ if (!world.isSkyVisible(pos)) {
if (pos.getY() + 2 < seaLevel) {
timer = timer + 1; timer = timer + 1;
if (timer > 10){ if (timer > 10) {
timer = 10; timer = 10;
shouldParticlesSpawn = true; shouldParticlesSpawn = true;
return true; return true;
} }
} }
} }
shouldParticlesSpawn = false; shouldParticlesSpawn = false;
return false; return false;
} }

View File

@@ -3,13 +3,11 @@ package net.lizistired.cavedust.utils;
import com.minelittlepony.common.client.gui.element.AbstractSlider; import com.minelittlepony.common.client.gui.element.AbstractSlider;
import net.minecraft.text.Text; import net.minecraft.text.Text;
import javax.swing.*;
public class TranslatableTextHelper { public class TranslatableTextHelper {
public Text formatMaxX(AbstractSlider<Float> slider) { public Text formatMaxWidth(AbstractSlider<Float> slider) {
return Text.translatable("menu.cavedust.width", (int)Math.floor(slider.getValue())); return Text.translatable("menu.cavedust.width", (int)Math.floor(slider.getValue()));
} }
public Text formatMaxY(AbstractSlider<Float> slider) { public Text formatMaxHeight(AbstractSlider<Float> slider) {
return Text.translatable("menu.cavedust.height", (int)Math.floor(slider.getValue())); return Text.translatable("menu.cavedust.height", (int)Math.floor(slider.getValue()));
} }
public Text formatUpperLimit(AbstractSlider<Float> slider) { public Text formatUpperLimit(AbstractSlider<Float> slider) {
@@ -28,12 +26,4 @@ public class TranslatableTextHelper {
public Text formatVelocityRandomness(AbstractSlider<Float> slider) { public Text formatVelocityRandomness(AbstractSlider<Float> slider) {
return Text.translatable("menu.cavedust.velocityrandomness", (int) Math.floor(slider.getValue())); return Text.translatable("menu.cavedust.velocityrandomness", (int) Math.floor(slider.getValue()));
} }
public Text formatScaleLower(AbstractSlider<Float> slider) {
return Text.translatable("menu.cavedust.scalelower", (int) Math.floor(slider.getValue()));
}
public Text formatScaleHigher(AbstractSlider<Float> slider) {
return Text.translatable("menu.cavedust.scalehigher", (int) Math.floor(slider.getValue()));
}
} }

Binary file not shown.

Before

Width:  |  Height:  |  Size: 116 KiB

After

Width:  |  Height:  |  Size: 250 KiB

View File

@@ -28,10 +28,6 @@
"menu.cavedust.superflatstatus.tooltip": "Should particles spawn on superflat worlds?", "menu.cavedust.superflatstatus.tooltip": "Should particles spawn on superflat worlds?",
"menu.cavedust.particle": "Particle: ", "menu.cavedust.particle": "Particle: ",
"menu.cavedust.particle.tooltip": "Particle to spawn. Click to cycle.", "menu.cavedust.particle.tooltip": "Particle to spawn. Click to cycle.",
"menu.cavedust.scalelower": "Minimum scale: %s",
"menu.cavedust.scalelower.tooltip": "Minimum particle size to spawn.",
"menu.cavedust.scalehigher": "Maximum scale: %s",
"menu.cavedust.scalehigher.tooltip": "Maximum particle size to spawn.",
"key.cavedust.reload": "Reload Config", "key.cavedust.reload": "Reload Config",
"key.cavedust.toggle": "Toggle Particles", "key.cavedust.toggle": "Toggle Particles",

View File

@@ -1,15 +1,19 @@
{ {
"schemaVersion": 1, "schemaVersion": 1,
"id": "cavedust", "id": "cavedustreforged",
"version": "${version}", "version": "${version}",
"name": "Cave Dust", "name": "Cave Dust Reforged",
"description": "Makes dust underground that scales with depth!", "description": "Makes dust underground that scales with depth!",
"authors": [ "authors": [
"LizIsTired" "DekinDev"
],
"contributors": [
"LizIsTired (Original mod)"
], ],
"contact": { "contact": {
"issues": "https://github.com/LizIsTired/dust/issues", "issues": "https://git.straice.com/DekinDev/cave_dust_reforged/issues",
"sources": "https://github.com/LizIsTired/dust" "sources": "https://git.straice.com/DekinDev/cave_dust_reforged",
"homepage": "https://modrinth.com/project/cave-dust-reforged"
}, },
"license": "MPL-2.0", "license": "MPL-2.0",
"icon": "assets/cavedust/icon.png", "icon": "assets/cavedust/icon.png",
@@ -19,8 +23,7 @@
"net.lizistired.cavedust.CaveDust" "net.lizistired.cavedust.CaveDust"
], ],
"main": [ "main": [
"net.lizistired.cavedust.CaveDustServer" "net.lizistired.cavedust.CaveDustServer"],
],
"modmenu": [ "modmenu": [
"net.lizistired.cavedust.CaveDustModMenuFactory" "net.lizistired.cavedust.CaveDustModMenuFactory"
] ]
@@ -29,19 +32,12 @@
"cavedust.mixins.json" "cavedust.mixins.json"
], ],
"depends": { "depends": {
"fabricloader": ">=0.14.5", "fabricloader": ">=0.17.2",
"fabric": "*", "fabric": "*",
"minecraft": "1.20.1", "minecraft": "1.21.9",
"java": ">=17" "java": ">=17"
}, },
"suggests": { "suggests": {
"modmenu": ">=3.0.1" "modmenu": ">=3.0.1"
},
"custom": {
"modmenu": {
"links": {
"modmenu.discord": "https://discord.gg/4m6kQSX6bx"
}
}
} }
} }