Jump to content

[1.15.2] Smoothly interpolating Power Generation


Ahndrek Li'Cyri

Recommended Posts

Hello all!
So i have a bit of a odd question.
I have a Power generator that works all fine, but the power being all added in at the end of the burn time is not exactly what I want to do.
Let's say i want to add... 2500 power units over 1600 ticks. How would i go about doing that when the power system only accepts Integers to add?

 

I have tried

int power = 2500 / 1600;
addPower(power);

but obviously this won't work because it rounds the result to a Integer, only generating 1600 and not 2500 power units.

Any help on this would be great, thank you!

Link to comment
Share on other sites

if addPower() accepts floats, just use a float

I don't know how that power system works but

int power = 2500/1600;

float powerLeft = 2500;
for(int i=1600; i>0; i--){ //make this run once every tick instead of this for loop, but remember to make i work the same
power = powerLeft/i;
addPower(power);
powerLeft -= power;
}

Link to comment
Share on other sites

Disclaimer: I haven't used any energy system in my mods yet.

private int ratePerTick = 20; // adjust if needed
private int powerRemaining = 2500; // will be changed by other code

public void tick() {
    if (powerRemaining > ratePerTick) {
        addPower(ratePerTick);
        powerRemaining -= ratePerTick;
    } else {
        if (powerRemaining > 0) {
            addPower(powerRemaining);
        }
        powerRemaining = 0;
    }
}

 

Link to comment
Share on other sites

Howdy

The basic algorithm for doing things like this is to add a different amount each tick.

For example, if you wanted to add 30 power units over 20 ticks, you would add

2 units on the first tick

1 unit on the second tick

2 units on the third tick

1 unit on the fourth tick

(etc) for 20 ticks in total.

 

You need to track the fractional part yourself

eg from your example

 

INITIALISING:

float ratePerTick = 2500.0/1600.0;

float remainder = 0.0;

 

EVERY TICK:

remainder += ratePerTick;

int powerToAddThisTick = (int)remainder;

remainder -= powerToAddThisTick;

addPower(powerToAddThisTick)

 

-TGG

 

 

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Faced with this problem, I want to put the build on the server, but it as I realized a lot of client mods, most of them I removed, but still have a lot of errors. Help please, I sit a whole day to solve the problem, perhaps there are some other problems, crash log attached  https://pastebin.com/vh0647bG
    • Im trying to transfer mod from modpack to my server,i deleted some mod that only work in client,but i can't find zume. https://pastebin.com/CsnrMvup
    • What structures are you trying to make your custom item generate in?
    • Ok, I removed the littletiles mod and the server was opened, my problem was solved, thank you very much again.
    • The code is written by a neural network, but no matter how much I try to do damage or fire effect, either everything stops working, or the particles stop pointing at creatures. package net.tndax.thaumcraft.item.custom; import net.minecraft.core.Holder; import net.minecraft.core.particles.ParticleTypes; import net.minecraft.world.InteractionHand; import net.minecraft.world.InteractionResult; import net.minecraft.world.InteractionResultHolder; import net.minecraft.world.entity.Entity; import net.minecraft.world.entity.LivingEntity; import net.minecraft.world.entity.player.Player; import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.Level; import net.minecraft.world.damagesource.DamageSource; import java.util.List; import net.minecraft.world.damagesource.DamageType; public class ProtectiveItem extends Item { public ProtectiveItem(Properties pProperties) { super(pProperties); } @Override public InteractionResultHolder<ItemStack> use(Level level, Player player, InteractionHand hand) { if (level.isClientSide()) { new Thread(() -> { double radius = 2.0; // Радиус вращения double heightOffset = 1.5; // Высота вращения частиц относительно игрока int duration = 20000; // Продолжительность эффекта в миллисекундах int steps = 200; // Количество шагов в одном круге (увеличено для большей плотности частиц) long startTime = System.currentTimeMillis(); while (System.currentTimeMillis() - startTime < duration) { for (int step = 0; step < steps; step++) { try { Thread.sleep(5); // Время между шагами уменьшено для увеличения скорости } catch (InterruptedException e) { e.printStackTrace(); } double angle = 2 * Math.PI * step / steps; for (int i = 0; i < 5; i++) { // Добавляем несколько частиц с небольшими смещениями double offset = i * 0.1; double randomFactorX = Math.sin(Math.toRadians(step * 7 % 360 + offset)); double randomFactorY = Math.sin(Math.toRadians(step * 13 % 360 + offset)); double randomFactorZ = Math.sin(Math.toRadians(step * 17 % 360 + offset)); double x = player.getX() + radius * Math.cos(angle) * randomFactorX; double y = player.getY() + heightOffset + radius * Math.sin(angle) * randomFactorY; double z = player.getZ() + radius * Math.sin(angle) * randomFactorZ; level.addParticle(ParticleTypes.FLAME, x, y, z, 0, 0, 0); } // Проверяем наличие сущностей в радиусе 5 блоков List<Entity> nearbyEntities = level.getEntities(player, player.getBoundingBox().inflate(10), entity -> entity instanceof LivingEntity && entity != player); if (!nearbyEntities.isEmpty()) { Entity target = nearbyEntities.get(0); // Берём первую ближайшую сущность double targetX = target.getX(); double targetY = target.getY() + target.getEyeHeight(); double targetZ = target.getZ(); // Направляем частицы к цели for (int i = 0; i < 20; i++) { double t = i / 20.0; double particleX = player.getX() + t * (targetX - player.getX()); double particleY = player.getY() + heightOffset + t * (targetY - (player.getY() + heightOffset)); double particleZ = player.getZ() + t * (targetZ - player.getZ()); level.addParticle(ParticleTypes.FLAME, particleX, particleY, particleZ, 0, 0, 0); try { Thread.sleep(5); // Пауза между частицами } catch (InterruptedException e) { e.printStackTrace(); } } // Возвращаем частицы обратно к игроку for (int i = 0; i < 20; i++) { double t = i / 20.0; double particleX = targetX + t * (player.getX() - targetX); double particleY = targetY + t * (player.getY() + heightOffset - targetY); double particleZ = targetZ + t * (player.getZ() - targetZ); level.addParticle(ParticleTypes.FLAME, particleX, particleY, particleZ, 0, 0, 0); try { Thread.sleep(5); // Пауза между частицами } catch (InterruptedException e) { e.printStackTrace(); } } } } } }).start(); } return new InteractionResultHolder<>(InteractionResult.SUCCESS, player.getItemInHand(hand)); } }  
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.