Jump to content

Burst fire gun / creating delay between shots


DerpenWolf

Recommended Posts

    I am currently trying to add a gun to my upcoming mod which fires in 3 round bursts (about 1 round every 1/2 second), however I do not know how to implement a firing delay between each shot. Can I use a tick handler to create a delay, and if so how? What other methods can you suggest?

 

 

Here is my current code:

 

 

 

package assets.derpmod.common;

 

import cpw.mods.fml.relauncher.Side;

import cpw.mods.fml.relauncher.SideOnly;

import net.minecraft.client.renderer.texture.IconRegister;

import net.minecraft.creativetab.CreativeTabs;

import net.minecraft.entity.player.EntityPlayer;

import net.minecraft.item.EnumAction;

import net.minecraft.item.Item;

import net.minecraft.item.ItemStack;

import net.minecraft.world.World;

 

 

 

public class ItemBurstGun extends Item {

int x;

 

  public ItemBurstGun(int par1) {

super(par1);

this.setMaxDamage(250);

setUnlocalizedName("BurstGun");

setMaxStackSize(1);

}

  @Override

  public ItemStack onItemRightClick(ItemStack par1ItemStack, World par2World,EntityPlayer par3EntityPlayer)

  {

  x = 0;

 

  while(x < 3){

{

 

  if (par3EntityPlayer.inventory.hasItem(derpmod.CoilgunSlug.itemID))

  {

  par2World.playSoundAtEntity(par3EntityPlayer, "random.bow", 0.5F, 0.4F / (itemRand.nextFloat() * 0.4F + 0.8F));

  if (!par2World.isRemote)

  {

  par2World.spawnEntityInWorld(new EntityCoilgunRound(par2World, par3EntityPlayer));

 

  }

  }

     

par3EntityPlayer.inventory.consumeInventoryItem(derpmod.CoilgunSlug.itemID);

par1ItemStack.damageItem(1, par3EntityPlayer); 

x++;

  } 

x = 0;

    }

 

    return par1ItemStack;

    }

 

  public boolean isFull3D()

    {

        return true;

    }

   

  public void registerIcons(IconRegister iconRegister)

{

itemIcon = iconRegister.registerIcon("Derpmod:BurstGun");

}

}

 

 

 

 

 

 

Link to comment
Share on other sites

The way I made a delay: Item has a method onUpdate() which is called while the item is in da hotbar. I declared a global integer "timeElapsed". Then I wrote timeElapsed++ in the onUpdate() so it increases until a certain value reaches. Once the value is reached, the gun can shoot again, then timeElapsed is reset.

Link to comment
Share on other sites

I tried this but I didn't notice any difference, I still cant get a firing delay between each shot in the burst.

 

 

package assets.derpmod.common;

 

import cpw.mods.fml.relauncher.Side;

import cpw.mods.fml.relauncher.SideOnly;

import net.minecraft.client.renderer.texture.IconRegister;

import net.minecraft.creativetab.CreativeTabs;

import net.minecraft.entity.player.EntityPlayer;

import net.minecraft.item.EnumAction;

import net.minecraft.item.Item;

import net.minecraft.item.ItemStack;

import net.minecraft.world.World;

 

 

 

public class ItemBurstGun extends Item {

 

public static int timeElapsed;

  public ItemBurstGun(int par1) {

super(par1);

this.setMaxDamage(250);

setUnlocalizedName("BurstGun");

setMaxStackSize(1);

}

  @Override

  public ItemStack onItemRightClick(ItemStack par1ItemStack, World par2World,EntityPlayer par3EntityPlayer)

  {

 

if (par3EntityPlayer.inventory.hasItem(derpmod.CoilgunSlug.itemID))

{

par2World.playSoundAtEntity(par3EntityPlayer, "random.bow", 0.5F, 0.4F / (itemRand.nextFloat() * 0.4F + 0.8F));

if (!par2World.isRemote)

  {

  par2World.spawnEntityInWorld(new EntityCoilgunRound(par2World, par3EntityPlayer));

  }

 

par3EntityPlayer.inventory.consumeInventoryItem(derpmod.CoilgunSlug.itemID);

par1ItemStack.damageItem(1, par3EntityPlayer); 

}

timeElapsed = 0;

if(timeElapsed == 1000);

  {

onUpdate(par1ItemStack, par2World, par3EntityPlayer, timeElapsed, bFull3D);

timeElapsed++;

}

 

  if (par3EntityPlayer.inventory.hasItem(derpmod.CoilgunSlug.itemID))

{

par2World.playSoundAtEntity(par3EntityPlayer, "random.bow", 0.5F, 0.4F / (itemRand.nextFloat() * 0.4F + 0.8F));

if (!par2World.isRemote)

  {

  par2World.spawnEntityInWorld(new EntityCoilgunRound(par2World, par3EntityPlayer));

  }

 

par3EntityPlayer.inventory.consumeInventoryItem(derpmod.CoilgunSlug.itemID);

par1ItemStack.damageItem(1, par3EntityPlayer); 

}

  timeElapsed = 0;

 

    return par1ItemStack;

    }

 

  public boolean isFull3D()

    {

        return true;

    }

   

  public void registerIcons(IconRegister iconRegister)

{

itemIcon = iconRegister.registerIcon("Derpmod:BurstGun");

}

}

 

 

(not entirely confident that I know what to do)

Link to comment
Share on other sites

 

timeElapsed = 0;

if(timeElapsed == 1000);

      {

onUpdate(par1ItemStack, par2World, par3EntityPlayer, timeElapsed, bFull3D);

timeElapsed++;

}

}

 

Well i am not sure if that is what you want there, but i guess that you would want it to (lets say you fire 3 times and after that you want it to be delayed untill you can fire again, atleast thats how i read your intention) I would make it so that you have an int that counts up to lets say 5 and for the first 3 it would fire a shot and the last 2 wouldn't do anything.

Link to comment
Share on other sites

ah, sorry if I was unclear. what I want is there to be a delay between each shot in the burst so that when I click the trigger once I get the following:

 

 

 

tap right mouse button once

 

Fire round 1

 

wait 1/2 a second

 

Fire round 2

 

wait 1/2 a second

 

Fire round 3

 

stop/ reset until right mouse is clicked again

 

 

 

I am not looking for a delay between each time I press the trigger but instead looking for a way to implement a way to get the 1/2 second wait time between each shot in the burst itself.

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.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Compare this list (client-side-only mods) with your mods: https://www.dropbox.com/scl/fi/yeldxfv8ed60e4uflc2fi/Client-Side-Only-Modlist.xlsx?rlkey=8376c5bk7b33je2tad4p3ybrg&st=qf6osvit&dl=0  
    • Crashlog: https://paste.ee/p/WrGYD I'm thinking the problem might be a client side mod but ive already checked the mod list like 5 times and still cant find the problem
    • I'm unable to join my local forge servers. When running my forge servers of seemingly any version (tested 1.18 to 1.21.1) I get an error message [Forge Version Check/WARN] [ne.mi.fm.VersionChecker/]: Failed to process update information The server continues to start up and run, however I'm unable to join. Looking for solutions? Full error message: (note last "thead warning" error seems to be unrelated and only happened once for 1.20.1) Forge version check warning has happened for every version. [09:52:31] [Forge Version Check/WARN] [ne.mi.fm.VersionChecker/]: Failed to process update information java.net.http.HttpConnectTimeoutException: HTTP connect timed out         at jdk.internal.net.http.HttpClientImpl.send(HttpClientImpl.java:950) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientFacade.send(HttpClientFacade.java:133) ~[java.net.http:?] {}         at net.minecraftforge.fml.VersionChecker$1.openUrlString(VersionChecker.java:142) ~[fmlcore-1.20.1-47.3.10.jar%23102!/:?] {}         at net.minecraftforge.fml.VersionChecker$1.process(VersionChecker.java:180) ~[fmlcore-1.20.1-47.3.10.jar%23102!/:?] {}         at java.lang.Iterable.forEach(Iterable.java:75) ~[?:?] {}         at net.minecraftforge.fml.VersionChecker$1.run(VersionChecker.java:117) ~[fmlcore-1.20.1-47.3.10.jar%23102!/:?] {} Caused by: java.net.http.HttpConnectTimeoutException: HTTP connect timed out         at jdk.internal.net.http.ResponseTimerEvent.handle(ResponseTimerEvent.java:68) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl.purgeTimeoutsAndReturnNextDeadline(HttpClientImpl.java:1788) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl$SelectorManager.run(HttpClientImpl.java:1385) ~[java.net.http:?] {} Caused by: java.net.ConnectException: HTTP connect timed out         at jdk.internal.net.http.ResponseTimerEvent.handle(ResponseTimerEvent.java:69) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl.purgeTimeoutsAndReturnNextDeadline(HttpClientImpl.java:1788) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl$SelectorManager.run(HttpClientImpl.java:1385) ~[java.net.http:?] {} [09:52:31] [Yggdrasil Key Fetcher/ERROR] [mojang/YggdrasilServicesKeyInfo]: Failed to request yggdrasil public key com.mojang.authlib.exceptions.AuthenticationUnavailableException: Cannot contact authentication server         at com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService.makeRequest(YggdrasilAuthenticationService.java:119) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService.makeRequest(YggdrasilAuthenticationService.java:91) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilServicesKeyInfo.fetch(YggdrasilServicesKeyInfo.java:94) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilServicesKeyInfo.lambda$get$1(YggdrasilServicesKeyInfo.java:81) ~[authlib-4.0.43.jar%2375!/:?] {}         at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:572) ~[?:?] {}         at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:358) ~[?:?] {}         at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305) ~[?:?] {}         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1144) ~[?:?] {}         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:642) ~[?:?] {}         at java.lang.Thread.run(Thread.java:1575) ~[?:?] {} Caused by: java.net.SocketTimeoutException: Connect timed out         at sun.nio.ch.NioSocketImpl.timedFinishConnect(NioSocketImpl.java:546) ~[?:?] {}         at sun.nio.ch.NioSocketImpl.connect(NioSocketImpl.java:592) ~[?:?] {}         at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:327) ~[?:?] {}         at java.net.Socket.connect(Socket.java:760) ~[?:?] {}         at sun.security.ssl.SSLSocketImpl.connect(SSLSocketImpl.java:304) ~[?:?] {}         at sun.net.NetworkClient.doConnect(NetworkClient.java:178) ~[?:?] {}         at sun.net.www.http.HttpClient.openServer(HttpClient.java:531) ~[?:?] {}         at sun.net.www.http.HttpClient.openServer(HttpClient.java:636) ~[?:?] {}         at sun.net.www.protocol.https.HttpsClient.<init>(HttpsClient.java:264) ~[?:?] {}         at sun.net.www.protocol.https.HttpsClient.New(HttpsClient.java:377) ~[?:?] {}         at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.getNewHttpClient(AbstractDelegateHttpsURLConnection.java:193) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.plainConnect0(HttpURLConnection.java:1273) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.plainConnect(HttpURLConnection.java:1114) ~[?:?] {}         at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:179) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1676) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1600) ~[?:?] {}         at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:223) ~[?:?] {}         at com.mojang.authlib.HttpAuthenticationService.performGetRequest(HttpAuthenticationService.java:140) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService.makeRequest(YggdrasilAuthenticationService.java:96) ~[authlib-4.0.43.jar%2375!/:?] {}         ... 9 more [09:52:31] [Server thread/WARN] [minecraft/MinecraftServer]: Can't keep up! Is the server overloaded? Running 5985ms or 119 ticks behind
    • Remove the mod tempad from the mods-folder
    • Hi, deleting the config folder did not appear to work, what mod are you referring to I could try to delete to fix the problem?
  • Topics

×
×
  • Create New...

Important Information

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