Jump to content

Choonster

Moderators
  • Posts

    5126
  • Joined

  • Last visited

  • Days Won

    76

Everything posted by Choonster

  1. You installed a client-only mod (Resource Loader) on the server.
  2. World#spawnParticle calls IWorldAccess#spawnParticle for every registered IWorldAccess . RenderGlobal (the client-side IWorldAccess ) spawns a particle in its implementation of this method, WorldManager (the server-side IWorldAccess ) does nothing. WorldServer#func_147487_a(String particleName, double x, double y, double z, int numParticles, double displacementX, double displacementY, double displacementZ, double velocity) sends a packet from the server to the clients of the players within 256 blocks of the specified position telling them to spawn particles there. Look at RenderGlobal#doSpawnParticle to see which particle names you can use. Use your IDE to find usages of these methods to see how they're used.
  3. I can't help you much with models or animation myself, but Forge recently added an animation system for models. You can see an example of it here (assets).
  4. That's the crash report rather than the FML log, but it does reveal the issue. The EAQ has a bullet point for this crash, the solution is to lower your view distance.
  5. Like LexManos said, post the FML log. Even the EAQ (which you're supposed to read before posting) tells you to do this. The log will tell us what's actually happening, we can't do much more than guess without it.
  6. Put a breakpoint on the line that the exception is thrown from (line 654 of NetHandlerPlayServer ) and run Minecraft in debug mode. When the breakpoint is hit, look at what's null and having a method called on it or a field access from it.
  7. You need to AND the position index with 2 before you look it up in the values array.
  8. Override Item#onEntityItemUpdate . This is called once per tick by every EntityItem containing an ItemStack of your Item . In your override of this method, check that the entity is on the ground (its onGround field is true ), the block at the entity's position isn't fire and fire can be placed at the entity's position ( Block#canPlaceBlockAt returned true ). If this condition is met, set the block at the entity's position to fire. In 1.7.10, use World#getBlock and World#setBlock to get and set the Block at the specified position. Use the posX , posY and posZ fields of Entity to get an entity's position and MathHelper.floor_double to convert them to integers. In 1.8.x, use World#getBlockState and World#setBlockState to get and set the IBlockState at the specified position. Use IBlockState#getBlock to get the state's Block . Use the BlockPos(Entity) constructor to get an entity's position as a BlockPos .
  9. Call EntityPlayer#setItemInUse from Item#onItemRightClick like ItemBow does.
  10. If you set the item in use from Item#onItemRightClick , the pulling models returned by Item#getModel will be used (you can adjust the timings for each model in that method). Just make sure you override Item#onItemUseStopped to do nothing.
  11. Just register a model for the bow like you would any other item ( ModelBakery.registerItemVariants and ModelLoader.setCustomModelResourceLocation or ModelLoader.setCustomMeshDefinition ). Since it's never set in use, the pulling models will never be used.
  12. Since the player doesn't actually draw back your bow like they do with the vanilla one, I'd just use a fixed charge value.
  13. I suggest storing the FACING values's horizontal index ( EnumFacing#getHorizontalIndex , an integer in the range [0,3] ) in the lower two bits of the metadata and the POSITION value's ordinal ( Position#ordinal , an integer in the range [0,2] ) or a similar index field in the higher two bits of the metadata. Shift the POSITION index left 2 bits ( << ) then OR ( | ) it with the FACING index. To get the FACING value from the metadata, AND ( & ) it with 3 (the maximum index) and use EnumFacing.getHorizontal to convert it to an EnumFacing . To get the POSITION value from the metadata, shift it right 2 bits ( >> ), AND it with 2 (the maximum index) and get the Position at that index of the array returned by Potion#values . I'll try to implement this myself to provide an example of how it's done. Edit: Correctly capitalised AND.
  14. That should be suitable, but you still need to create the BlockState and convert between state and metadata.
  15. Note that if NEI is running, ItemTooltipEvent won't be fired. To modify NEI's tooltips, you need to implement IContainerTooltipHandler and register it using GuiContainerManager.addTooltipHandler instead.
  16. You can probably use an EnumFacing property limited to Plane.HORIZONTAL for the y-axis rotation and a custom enum property with UP , DOWN and SIDEWAYS values for the x-axis rotation. You can integrate the custom enum with EnumFacing and its subclasses if needed.
  17. Forge recently added a model animation system. I have no idea what the video is using and annoyingly he doesn't seem to explain it or provide a map/resource pack download.
  18. I don't think Cricket is maintaining Chisel 2 any more, update to Chisel by Chisel Team (tterag1008, Drullkus, Minecreatr).
  19. You've got a block (pair of braces) surrounding the if statement, which isn't required. You don't need to consume an arrow in the body of the if statement, the InventoryPlayer#consumeInventoryItem call in the conditional already does that. There's no point in setting the maximum use duration ( Item#getMaxItemUseDuration ) and use action ( Item#getItemUseAction ) if you never set the item in use ( EntityPlayer#setItemInUse ). You should rename the variables in onItemRightClick with meaningful names that describe their purpose, e.g. charge instead if i (because that holds the bow's charge). You never declare the variable i . What is it that want to know?
  20. You need to store the last use time ( World#getTotalWorldTime ) in the NBT and compare it against the current time in Item#onItemRightClick . If it's been at least COOLDOWN ticks, update the last use time and fire the arrow. I have an example of a similar weapon here that fires snowballs at a fixed rate while right click is held.
  21. Ah, I got a bit confused. That is indeed the method I meant.
  22. Set the maximum use duration to 0, the use action to NONE and fire the arrows from Item#onItemRightClick instead of Item#onItemUseFinish .
  23. Use JDK 8 for the ForgeGradle-based 1.7.10 and 1.8.x builds. Use JDK 7 for the ForgeGradle-based 1.6.4 builds (960-965) or JDK 8 for the most recent MCP-based 1.6.4 build (1345). This tutorial explains how to get started and set up a ForgeGradle workspace.
  24. The damage dealt by arrows is calculated in EntityArrow#onUpdate , which uses values set in ItemBow#onPlayerStoppedUsing . You can override these methods in your own classes to do whatever you want.
×
×
  • Create New...

Important Information

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