custom rates for contracts runes and glass
This commit is contained in:
@@ -112,9 +112,22 @@ public enum LootManager {
|
|||||||
case "LOOT":
|
case "LOOT":
|
||||||
if (ThreadLocalRandom.current().nextInt(1, 100 + 1) < (bse.dropChance * dropRate))
|
if (ThreadLocalRandom.current().nextInt(1, 100 + 1) < (bse.dropChance * dropRate))
|
||||||
GenerateLootDrop(mob, bse.genTable); //generate normal loot drop
|
GenerateLootDrop(mob, bse.genTable); //generate normal loot drop
|
||||||
if(ThreadLocalRandom.current().nextInt(1, 20000) < mob.level) {
|
if(ThreadLocalRandom.current().nextInt(1, 20000) == 10000) {
|
||||||
if (_genTables.containsKey(bse.genTable + 1) && ThreadLocalRandom.current().nextInt(1, 100 + 1) < (bse.dropChance * dropRate)) {
|
if (_genTables.containsKey(bse.genTable + 1)) {
|
||||||
GenerateLootDrop(mob, bse.genTable + 1); //generate loot drop from hotzone table
|
int roll = ThreadLocalRandom.current().nextInt(1,101);
|
||||||
|
MobLoot extraLoot = null;
|
||||||
|
if(roll >= 1 && roll <= 47){
|
||||||
|
extraLoot = rollForContract(bse.genTable + 1, mob);
|
||||||
|
}
|
||||||
|
if(roll >= 48 && roll <= 94){
|
||||||
|
extraLoot = rollForRune(bse.genTable + 1, mob);
|
||||||
|
}
|
||||||
|
if(roll >= 95){
|
||||||
|
extraLoot = rollForGlass(mob);
|
||||||
|
}
|
||||||
|
if(extraLoot != null){
|
||||||
|
mob.getCharItemManager().addItemToInventory(extraLoot);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -453,4 +466,66 @@ public enum LootManager {
|
|||||||
itemMan.addItemToInventory(playerWinnings);
|
itemMan.addItemToInventory(playerWinnings);
|
||||||
itemMan.updateInventory();
|
itemMan.updateInventory();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static MobLoot rollForContract(int table, Mob mob){
|
||||||
|
GenTableEntry selectedRow = GenTableEntry.rollTable(table, 95, 1.0f);
|
||||||
|
if (selectedRow == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
int itemTableId = selectedRow.itemTableID;
|
||||||
|
|
||||||
|
if (_itemTables.containsKey(itemTableId) == false)
|
||||||
|
return null;
|
||||||
|
ItemTableEntry tableRow = ItemTableEntry.rollTable(itemTableId, ThreadLocalRandom.current().nextInt(1,321));
|
||||||
|
if (tableRow == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
int itemUUID = tableRow.cacheID;
|
||||||
|
|
||||||
|
if (itemUUID == 0)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
MobLoot outItem = new MobLoot(mob, ItemBase.getItemBase(itemUUID), false);
|
||||||
|
if(outItem != null)
|
||||||
|
return outItem;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
public static MobLoot rollForRune(int table, Mob mob){
|
||||||
|
GenTableEntry selectedRow = GenTableEntry.rollTable(table, 95, 1.0f);
|
||||||
|
if (selectedRow == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
int itemTableId = selectedRow.itemTableID;
|
||||||
|
|
||||||
|
if (_itemTables.containsKey(itemTableId) == false)
|
||||||
|
return null;
|
||||||
|
ItemTableEntry tableRow = ItemTableEntry.rollTable(itemTableId, ThreadLocalRandom.current().nextInt(1,321));
|
||||||
|
if (tableRow == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
int itemUUID = tableRow.cacheID;
|
||||||
|
|
||||||
|
if (itemUUID == 0)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
MobLoot outItem = new MobLoot(mob, ItemBase.getItemBase(itemUUID), false);
|
||||||
|
if(outItem != null)
|
||||||
|
return outItem;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
public static MobLoot rollForGlass( Mob mob){
|
||||||
|
ItemTableEntry tableRow = ItemTableEntry.rollTable(126, ThreadLocalRandom.current().nextInt(1,321));
|
||||||
|
if (tableRow == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
int itemUUID = tableRow.cacheID;
|
||||||
|
|
||||||
|
if (itemUUID == 0)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
MobLoot outItem = new MobLoot(mob, ItemBase.getItemBase(itemUUID), false);
|
||||||
|
if(outItem != null)
|
||||||
|
return outItem;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user