Skip to content

Commit

Permalink
fix serverside/clientside for multiplayer and add rarity slider
Browse files Browse the repository at this point in the history
  • Loading branch information
arlyon committed Aug 5, 2017
1 parent a5f97e6 commit 0ab3127
Show file tree
Hide file tree
Showing 5 changed files with 65 additions and 17 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
version 1.2.

- fix serverside and clientside
- add rarity setting

version 1.2

- added enchantment book to creative
Expand Down
7 changes: 7 additions & 0 deletions src/main/java/arlyon/felling/Configuration.java
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@

/**
* Created by Alexander Lyon on 30.07.2017.
*
* Controls the configurable options in the mod config menu.
*/

@Config(modid = Constants.MODID)
Expand Down Expand Up @@ -35,6 +37,11 @@ public class Configuration {
@Config.RangeInt(min=0, max=200)
public static int leafMultiplier = 100;

@Config.Name("Rarity (%)")
@Config.Comment("Controls how rare the enchantment is (with 100% being as the mod was intended). It is recommended to keep it between 80% and 120%, and more statistics can be found on the wiki.")
@Config.RangeInt(min=0, max=200)
public static int enchantmentRarity = 100;

@Mod.EventBusSubscriber
private static class EventHandler {

Expand Down
42 changes: 27 additions & 15 deletions src/main/java/arlyon/felling/Enchantment.java
Original file line number Diff line number Diff line change
Expand Up @@ -8,37 +8,49 @@

import java.util.Arrays;

/**
* The enchantment class for the Felling enchantment.
*/
public class Enchantment extends net.minecraft.enchantment.Enchantment {

// creates a new enchantment type called axe that can be applied on any tool with the class axe.
private static EnumEnchantmentType AXE = EnumHelper.addEnchantmentType("AXE", item -> item.getToolClasses(new ItemStack(item)).stream().anyMatch(toolClass -> toolClass.equals("axe")));
/**
* Axe enchantment type.
*/
public static EnumEnchantmentType AXE = EnumHelper.addEnchantmentType("AXE", item -> {
assert item != null;
return item.getToolClasses(new ItemStack(item)).stream().anyMatch(toolClass -> toolClass.equals("axe"));
});

public Enchantment(Rarity rarityIn, EntityEquipmentSlot... slots) {
/**
* Sets name and registry name and assigns the proper predicate.
*
* @param rarityIn the rarity of the enchantment
* @param slots the slots in which the enchantment is valid
*/
Enchantment(Rarity rarityIn, EntityEquipmentSlot... slots) {
super(rarityIn, AXE, slots);
setName("felling");
setRegistryName("felling");

// add it to the creative tab
EnumEnchantmentType[] enchantmentTypes = CreativeTabs.TOOLS.getRelevantEnchantmentTypes();
enchantmentTypes = Arrays.copyOf(enchantmentTypes, enchantmentTypes.length+1);
enchantmentTypes[enchantmentTypes.length-1] = AXE;

CreativeTabs.TOOLS.setRelevantEnchantmentTypes(enchantmentTypes);
}

/**
* Returns the minimal value of enchantability needed on the enchantment level passed.
*
* Felling I - 20
* Felling II - 35
*
* @param enchantmentLevel The level you want to get minimum enchantability weight for.
* @return Minimus value of enchantability for the given enchantment level.
*/
public int getMinEnchantability(int enchantmentLevel) { return 5 + (enchantmentLevel) * 15; }
public int getMinEnchantability(int enchantmentLevel) { return ((5 + (enchantmentLevel) * 15) * Configuration.enchantmentRarity) / 100; }

/**
* Returns the maximum value of enchantability needed on the enchantment level passed.
* Felling I - 35
* Felling II - 50
*
* @param enchantmentLevel The level you want to get maximun enchantability weight for.
* @return Maximum value of enchantability for the given enchantment level.
*/
public int getMaxEnchantability(int enchantmentLevel) {
return this.getMinEnchantability(enchantmentLevel) + 50;
return this.getMinEnchantability(enchantmentLevel) + 15;
}

/**
Expand Down
15 changes: 13 additions & 2 deletions src/main/java/arlyon/felling/EventHandler.java
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,19 @@
import java.util.Random;

/**
* Handles the destroying of trees with the felling enchantment.
* The event handler container for both the FellingEvent and the RegistryEvent
*/

public class EventHandler {

/**
* The felling event subscriber class, which contains all the required functions for the subscriber.
*/
@Mod.EventBusSubscriber(modid = Constants.MODID)
public static class FellingEventHandler {

/**
* Used to determine which part of the tree a block is.
*/
private enum TreePart {
LEAF,
LOG,
Expand Down Expand Up @@ -81,6 +87,11 @@ private static TreePart getTreePart(Block block) {
*/
@SubscribeEvent
public static void fellTreeSubscriber(BlockEvent.BreakEvent event) {

if (event.getWorld().isRemote) {
return;
}

EntityPlayer thePlayer = event.getPlayer();
ItemStack mainHandItem = thePlayer.getHeldItemMainhand();
int enchantmentLevel = EnchantmentHelper.getEnchantmentLevel(Constants.felling, mainHandItem);
Expand Down
13 changes: 13 additions & 0 deletions src/main/java/arlyon/felling/proxy/ProxyClient.java
Original file line number Diff line number Diff line change
@@ -1,14 +1,27 @@
package arlyon.felling.proxy;

import arlyon.felling.Enchantment;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.enchantment.EnumEnchantmentType;
import net.minecraftforge.fml.common.event.FMLInitializationEvent;
import net.minecraftforge.fml.common.event.FMLPostInitializationEvent;
import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;

import java.util.Arrays;

public class ProxyClient extends ProxyCommon {

@Override
public void preInit(FMLPreInitializationEvent e) {

super.preInit(e);

// add it to the creative tab
EnumEnchantmentType[] enchantmentTypes = CreativeTabs.TOOLS.getRelevantEnchantmentTypes();
enchantmentTypes = Arrays.copyOf(enchantmentTypes, enchantmentTypes.length+1);
enchantmentTypes[enchantmentTypes.length-1] = Enchantment.AXE;
CreativeTabs.TOOLS.setRelevantEnchantmentTypes(enchantmentTypes);

}

@Override
Expand Down

0 comments on commit 0ab3127

Please sign in to comment.