forked from MagicBane/Server
THIRD AFTER ROLLBACK: contract and rune and glass drop rates adjusted properly
This commit is contained in:
@@ -73,38 +73,38 @@ public enum LootManager {
|
||||
}
|
||||
|
||||
public static void GenerateMobLoot(Mob mob) {
|
||||
int mobBootySet = mob.getMobBase().bootySet;
|
||||
if (mobBootySet != 0) {
|
||||
RunBootySetIfPresent(mobBootySet, mob);
|
||||
}
|
||||
|
||||
mobBootySet = mob.bootySet;
|
||||
if (mobBootySet != 0) {
|
||||
RunBootySetIfPresent(mobBootySet, mob);
|
||||
}
|
||||
//iterate the booty sets
|
||||
|
||||
// Check mob's inventory for godly or disc runes to send a server announcement
|
||||
for (Item item : mob.getInventory()) {
|
||||
ItemBase itemBase = item.getItemBase();
|
||||
if (itemBase != null && itemBase.getName().toLowerCase().contains("of the gods")) {
|
||||
ChatSystemMsg chatMsg = new ChatSystemMsg(
|
||||
null,
|
||||
mob.getName() + " in " + mob.getParentZone().getName() + " has found the " + itemBase.getName() + ". Are you tough enough to take it?"
|
||||
);
|
||||
chatMsg.setMessageType(10);
|
||||
chatMsg.setChannel(Enum.ChatChannelType.SYSTEM.getChannelID());
|
||||
DispatchMessage.dispatchMsgToAll(chatMsg);
|
||||
if (mob.getMobBase().bootySet != 0 && _bootySetMap.containsKey(mob.getMobBase().bootySet) == true)
|
||||
RunBootySet(_bootySetMap.get(mob.getMobBase().bootySet), mob);
|
||||
|
||||
if (mob.bootySet != 0 && _bootySetMap.containsKey(mob.bootySet) == true)
|
||||
RunBootySet(_bootySetMap.get(mob.bootySet), mob);
|
||||
|
||||
//lastly, check mobs inventory for godly or disc runes to send a server announcement
|
||||
for (Item it : mob.getInventory()) {
|
||||
|
||||
ItemBase ib = it.getItemBase();
|
||||
if(ib == null)
|
||||
break;
|
||||
if (ib.getName().toLowerCase().contains("of the gods")) {
|
||||
ChatSystemMsg chatMsg = new ChatSystemMsg(null, mob.getName() + " in " + mob.getParentZone().getName() + " has found the " + ib.getName() + ". Are you tough enough to take it?");
|
||||
chatMsg.setMessageType(10);
|
||||
chatMsg.setChannel(Enum.ChatChannelType.SYSTEM.getChannelID());
|
||||
DispatchMessage.dispatchMsgToAll(chatMsg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private static void RunBootySet(ArrayList<BootySetEntry> entries, Mob mob) {
|
||||
float dropRate = NORMAL_DROP_RATE;
|
||||
boolean isSafeZone = mob.parentZone.getSafeZone() == 0;
|
||||
|
||||
if (isSafeZone) {
|
||||
float dropRate = NORMAL_DROP_RATE;
|
||||
//roll the geenric world drop table
|
||||
if(mob.parentZone.getSafeZone() == 0) {
|
||||
GenerateLootDrop(mob, 1300);
|
||||
if (ThreadLocalRandom.current().nextInt(1, 10000) == 5000) {
|
||||
if(ThreadLocalRandom.current().nextInt(1, 10000) == 5000) {
|
||||
MobLoot extraLoot = rollForGlass(mob);
|
||||
if (extraLoot != null) {
|
||||
mob.getCharItemManager().addItemToInventory(extraLoot);
|
||||
@@ -112,6 +112,7 @@ public enum LootManager {
|
||||
}
|
||||
}
|
||||
|
||||
// Iterate all entries in this bootySet and process accordingly
|
||||
boolean hasExtraRolled = false;
|
||||
for (BootySetEntry bse : entries) {
|
||||
switch (bse.bootyType) {
|
||||
@@ -119,26 +120,17 @@ public enum LootManager {
|
||||
GenerateGoldDrop(mob, bse);
|
||||
break;
|
||||
case "LOOT":
|
||||
if (ThreadLocalRandom.current().nextInt(1, 101) < (bse.dropChance * dropRate)) {
|
||||
GenerateLootDrop(mob, bse.genTable);
|
||||
}
|
||||
if (isSafeZone && !hasExtraRolled && ThreadLocalRandom.current().nextInt(1, 5000) < 15 * dropRate) {
|
||||
MobLoot extraLoot = (ThreadLocalRandom.current().nextInt(1, 101) <= 50)
|
||||
? rollForContract(bse.genTable, mob)
|
||||
: rollForRune(bse.genTable, mob);
|
||||
if (extraLoot != null) {
|
||||
if (ThreadLocalRandom.current().nextInt(1, 100 + 1) < (bse.dropChance * dropRate))
|
||||
GenerateLootDrop(mob, bse.genTable); //generate normal loot drop
|
||||
if(mob.contractCounter >= 250){
|
||||
MobLoot extraLoot = rollForContract(bse.genTable, mob);
|
||||
if (extraLoot != null)
|
||||
mob.getCharItemManager().addItemToInventory(extraLoot);
|
||||
}
|
||||
if(mob.runeCounter >= 250){
|
||||
MobLoot extraLoot = rollForRune(bse.genTable, mob);
|
||||
if (extraLoot != null)
|
||||
mob.getCharItemManager().addItemToInventory(extraLoot);
|
||||
}
|
||||
hasExtraRolled = true;
|
||||
|
||||
if(mob.parentZone.lastContractDrop + 3600000 > System.currentTimeMillis()){
|
||||
//no contract in last hour, force roll for one
|
||||
rollForContract(bse.genTable, mob);
|
||||
}
|
||||
if(mob.parentZone.lastRuneDrop + 3600000 > System.currentTimeMillis()){
|
||||
//no rune in last hour, force roll for one
|
||||
rollForRune(bse.genTable, mob);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case "ITEM":
|
||||
@@ -146,143 +138,147 @@ public enum LootManager {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
MobLoot specialDrop = getSpecialDropForMob(mob);
|
||||
if (specialDrop != null) {
|
||||
enhanceMob(mob, specialDrop);
|
||||
}
|
||||
}
|
||||
|
||||
private static void RunBootySetIfPresent(int bootySet, Mob mob) {
|
||||
if (_bootySetMap.containsKey(bootySet)) {
|
||||
RunBootySet(_bootySetMap.get(bootySet), mob);
|
||||
}
|
||||
}
|
||||
|
||||
private static MobLoot getSpecialDropForMob(Mob mob) {
|
||||
MobLoot specialDrop = null;
|
||||
int mobUUID = mob.getObjectUUID();
|
||||
switch (mobUUID) {
|
||||
case 22595:
|
||||
specialDrop = createSpecialDrop(mob, 252134, "Melandrach The Blood-Mage");
|
||||
switch(mob.getObjectUUID()) {
|
||||
case 22595://elf 1
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252134),true);
|
||||
mob.setFirstName("Melandrach The Blood-Mage");
|
||||
break;
|
||||
case 22432:
|
||||
specialDrop = createSpecialDrop(mob, 252135, "Kyrtaar The Blood-Mage");
|
||||
case 22432: //elf 2
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252135),true);
|
||||
mob.setFirstName("Kyrtaar The Blood-Mage");
|
||||
break;
|
||||
case 22537:
|
||||
specialDrop = createSpecialDrop(mob, 252136, "Vamir The Blood-Mage");
|
||||
case 22537: //elf 3
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252136),true);
|
||||
mob.setFirstName("Vamir The Blood-Mage");
|
||||
break;
|
||||
case 16387:
|
||||
specialDrop = createSpecialDrop(mob, 252129, "Alatar The Blood-Mage");
|
||||
case 16387: //human 4 DONE
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252129),true);
|
||||
mob.setFirstName("Alatar The Blood-Mage");
|
||||
break;
|
||||
case 32724:
|
||||
specialDrop = createSpecialDrop(mob, 252130, "Elphaba The Blood-Mage");
|
||||
case 32724:// human 5 GOOD
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252130),true);
|
||||
mob.setFirstName("Elphaba The Blood-Mage");
|
||||
break;
|
||||
case 23379:
|
||||
specialDrop = createSpecialDrop(mob, 252131, "Bavmorda The Blood-Mage");
|
||||
case 23379: //human 1 GOOD
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252131),true);
|
||||
mob.setFirstName("Bavmorda The Blood-Mage");
|
||||
break;
|
||||
case 10826:
|
||||
specialDrop = createSpecialDrop(mob, 252132, "Draco The Blood-Mage");
|
||||
case 10826: //human 2 REDO
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252132),true);
|
||||
mob.setFirstName("Draco The Blood-Mage");
|
||||
break;
|
||||
case 15929:
|
||||
specialDrop = createSpecialDrop(mob, 252133, "Atlantes The Blood-Mage");
|
||||
case 15929: //human 3 GOOD
|
||||
specialDrop = new MobLoot(mob,ItemBase.getItemBase(252133),true);
|
||||
mob.setFirstName("Atlantes The Blood-Mage");
|
||||
break;
|
||||
}
|
||||
return specialDrop;
|
||||
}
|
||||
|
||||
private static MobLoot createSpecialDrop(Mob mob, int itemBaseId, String name) {
|
||||
mob.setFirstName(name);
|
||||
return new MobLoot(mob, ItemBase.getItemBase(itemBaseId), true);
|
||||
}
|
||||
|
||||
private static void enhanceMob(Mob mob, MobLoot specialDrop) {
|
||||
mob.setLevel((short) 65);
|
||||
mob.setSpawnTime(10800);
|
||||
mob.healthMax = 7500;
|
||||
mob.setHealth(7500);
|
||||
ChatSystemMsg chatMsg = new ChatSystemMsg(null, mob.getName() + " in " + mob.getParentZone().getName() + " has found the " + specialDrop.getName() + ". Are you tough enough to take it?");
|
||||
chatMsg.setMessageType(10);
|
||||
chatMsg.setChannel(Enum.ChatChannelType.SYSTEM.getChannelID());
|
||||
DispatchMessage.dispatchMsgToAll(chatMsg);
|
||||
mob.getCharItemManager().addItemToInventory(specialDrop);
|
||||
mob.setResists(new Resists("Dropper"));
|
||||
if(specialDrop != null) {
|
||||
mob.setLevel((short) 65);
|
||||
mob.setSpawnTime(10800);
|
||||
mob.healthMax = (7500);
|
||||
mob.setHealth(7500);
|
||||
ChatSystemMsg chatMsg = new ChatSystemMsg(null, mob.getName() + " in " + mob.getParentZone().getName() + " has found the " + specialDrop.getName() + ". Are you tough enough to take it?");
|
||||
chatMsg.setMessageType(10);
|
||||
chatMsg.setChannel(Enum.ChatChannelType.SYSTEM.getChannelID());
|
||||
DispatchMessage.dispatchMsgToAll(chatMsg);
|
||||
mob.getCharItemManager().addItemToInventory(specialDrop);
|
||||
mob.setResists(new Resists("Dropper"));
|
||||
}
|
||||
}
|
||||
|
||||
public static MobLoot getGenTableItem(int genTableID, AbstractCharacter mob) {
|
||||
if (mob == null || !_genTables.containsKey(genTableID)) {
|
||||
return null;
|
||||
}
|
||||
|
||||
int genRoll = ThreadLocalRandom.current().nextInt(1, 95);
|
||||
if (mob == null || _genTables.containsKey(genTableID) == false)
|
||||
return null;
|
||||
|
||||
MobLoot outItem;
|
||||
|
||||
int genRoll = ThreadLocalRandom.current().nextInt(1,94 + 1);
|
||||
|
||||
GenTableEntry selectedRow = GenTableEntry.rollTable(genTableID, genRoll, 1.0f);
|
||||
|
||||
if (selectedRow == null || !_itemTables.containsKey(selectedRow.itemTableID)) {
|
||||
if (selectedRow == null)
|
||||
return null;
|
||||
}
|
||||
|
||||
int itemTableRoll = (mob.getObjectType().ordinal() == 52) ?
|
||||
ThreadLocalRandom.current().nextInt(1, 321) :
|
||||
TableRoll(mob.level);
|
||||
int itemTableId = selectedRow.itemTableID;
|
||||
|
||||
ItemTableEntry tableRow = ItemTableEntry.rollTable(selectedRow.itemTableID, itemTableRoll);
|
||||
|
||||
if (tableRow == null || tableRow.cacheID == 0) {
|
||||
if (_itemTables.containsKey(itemTableId) == false)
|
||||
return null;
|
||||
}
|
||||
|
||||
ItemBase itemBase = ItemBase.getItemBase(tableRow.cacheID);
|
||||
if (itemBase == null) {
|
||||
//gets the 1-320 roll for this mob
|
||||
int itemTableRoll = 0;
|
||||
int objectType = mob.getObjectType().ordinal();
|
||||
if(mob.getObjectType().ordinal() == 52) { //52 = player character
|
||||
itemTableRoll = ThreadLocalRandom.current().nextInt(1,320 + 1);
|
||||
} else{
|
||||
itemTableRoll = TableRoll(mob.level);
|
||||
}
|
||||
ItemTableEntry tableRow = ItemTableEntry.rollTable(itemTableId, itemTableRoll);
|
||||
if (tableRow == null)
|
||||
return null;
|
||||
}
|
||||
|
||||
if (itemBase.getType() == Enum.ItemType.RESOURCE) {
|
||||
if (ThreadLocalRandom.current().nextInt(1, 101) > 10) {
|
||||
int itemUUID = tableRow.cacheID;
|
||||
|
||||
if (itemUUID == 0)
|
||||
return null;
|
||||
|
||||
if (ItemBase.getItemBase(itemUUID).getType().ordinal() == Enum.ItemType.RESOURCE.ordinal()) {
|
||||
int chance = ThreadLocalRandom.current().nextInt(1,101);
|
||||
if(chance > 10)
|
||||
return null;
|
||||
}
|
||||
int amount = ThreadLocalRandom.current().nextInt((int) (tableRow.minSpawn * 0.5f),
|
||||
(int) ((tableRow.maxSpawn + 1) * 0.5f));
|
||||
return new MobLoot(mob, itemBase, amount, false);
|
||||
int amount = ThreadLocalRandom.current().nextInt((int)(tableRow.minSpawn * 0.5f), (int)((tableRow.maxSpawn + 1) * 0.5f));
|
||||
return new MobLoot(mob, ItemBase.getItemBase(itemUUID), amount, false);
|
||||
}
|
||||
|
||||
MobLoot outItem = new MobLoot(mob, itemBase, false);
|
||||
try {
|
||||
if (selectedRow.pModTable != 0) {
|
||||
outItem = new MobLoot(mob, ItemBase.getItemBase(itemUUID), false);
|
||||
Enum.ItemType outType = outItem.getItemBase().getType();
|
||||
|
||||
|
||||
if(selectedRow.pModTable != 0){
|
||||
try {
|
||||
outItem = GeneratePrefix(mob, outItem, genTableID, genRoll);
|
||||
outItem.setIsID(false);
|
||||
} catch (Exception e) {
|
||||
Logger.error("Failed to GeneratePrefix for item: " + outItem.getName());
|
||||
}
|
||||
if (selectedRow.sModTable != 0) {
|
||||
}
|
||||
if(selectedRow.sModTable != 0){
|
||||
try {
|
||||
outItem = GenerateSuffix(mob, outItem, genTableID, genRoll);
|
||||
outItem.setIsID(false);
|
||||
} catch (Exception e) {
|
||||
Logger.error("Failed to GenerateSuffix for item: " + outItem.getName());
|
||||
}
|
||||
} catch (Exception e) {
|
||||
Logger.error("Failed to generate mod for item: " + outItem.getName(), e);
|
||||
}
|
||||
|
||||
return outItem;
|
||||
}
|
||||
|
||||
private static MobLoot GeneratePrefix(AbstractCharacter mob, MobLoot inItem, int genTableID, int genRoll) {
|
||||
|
||||
GenTableEntry selectedRow = GenTableEntry.rollTable(genTableID, genRoll, 1.0f);
|
||||
if (selectedRow == null) {
|
||||
|
||||
if (selectedRow == null)
|
||||
return inItem;
|
||||
}
|
||||
|
||||
ModTypeTableEntry prefixTable = ModTypeTableEntry.rollTable(selectedRow.pModTable, ThreadLocalRandom.current().nextInt(1, 101));
|
||||
if (prefixTable == null) {
|
||||
int prefixroll = ThreadLocalRandom.current().nextInt(1, 100 + 1);
|
||||
|
||||
ModTypeTableEntry prefixTable = ModTypeTableEntry.rollTable(selectedRow.pModTable, prefixroll);
|
||||
|
||||
if (prefixTable == null)
|
||||
return inItem;
|
||||
int prefixTableRoll = 0;
|
||||
if(mob.getObjectType().ordinal() == 52) {
|
||||
prefixTableRoll = ThreadLocalRandom.current().nextInt(1,320 + 1);
|
||||
} else{
|
||||
prefixTableRoll = TableRoll(mob.level);
|
||||
}
|
||||
|
||||
int prefixTableRoll = (mob.getObjectType().ordinal() == 52) ?
|
||||
ThreadLocalRandom.current().nextInt(1, 321) :
|
||||
TableRoll(mob.level);
|
||||
|
||||
ModTableEntry prefixMod = ModTableEntry.rollTable(prefixTable.modTableID, prefixTableRoll);
|
||||
if (prefixMod == null) {
|
||||
return inItem;
|
||||
}
|
||||
|
||||
if (!prefixMod.action.isEmpty()) {
|
||||
if (prefixMod == null)
|
||||
return inItem;
|
||||
|
||||
if (prefixMod.action.length() > 0) {
|
||||
inItem.setPrefix(prefixMod.action);
|
||||
inItem.addPermanentEnchantment(prefixMod.action, 0, prefixMod.level, true);
|
||||
}
|
||||
@@ -291,26 +287,30 @@ public enum LootManager {
|
||||
}
|
||||
|
||||
private static MobLoot GenerateSuffix(AbstractCharacter mob, MobLoot inItem, int genTableID, int genRoll) {
|
||||
|
||||
GenTableEntry selectedRow = GenTableEntry.rollTable(genTableID, genRoll, 1.0f);
|
||||
if (selectedRow == null) {
|
||||
|
||||
if (selectedRow == null)
|
||||
return inItem;
|
||||
}
|
||||
|
||||
ModTypeTableEntry suffixTable = ModTypeTableEntry.rollTable(selectedRow.sModTable, ThreadLocalRandom.current().nextInt(1, 101));
|
||||
if (suffixTable == null) {
|
||||
int suffixRoll = ThreadLocalRandom.current().nextInt(1, 100 + 1);
|
||||
|
||||
ModTypeTableEntry suffixTable = ModTypeTableEntry.rollTable(selectedRow.sModTable, suffixRoll);
|
||||
|
||||
if (suffixTable == null)
|
||||
return inItem;
|
||||
int suffixTableRoll = 0;
|
||||
if(mob.getObjectType().ordinal() == 52) {
|
||||
suffixTableRoll = ThreadLocalRandom.current().nextInt(1,320 + 1);
|
||||
} else{
|
||||
suffixTableRoll = TableRoll(mob.level);
|
||||
}
|
||||
|
||||
int suffixTableRoll = (mob.getObjectType().ordinal() == 52) ?
|
||||
ThreadLocalRandom.current().nextInt(1, 321) :
|
||||
TableRoll(mob.level);
|
||||
|
||||
ModTableEntry suffixMod = ModTableEntry.rollTable(suffixTable.modTableID, suffixTableRoll);
|
||||
if (suffixMod == null) {
|
||||
return inItem;
|
||||
}
|
||||
|
||||
if (!suffixMod.action.isEmpty()) {
|
||||
if (suffixMod == null)
|
||||
return inItem;
|
||||
|
||||
if (suffixMod.action.length() > 0) {
|
||||
inItem.setSuffix(suffixMod.action);
|
||||
inItem.addPermanentEnchantment(suffixMod.action, 0, suffixMod.level, false);
|
||||
}
|
||||
@@ -319,141 +319,150 @@ public enum LootManager {
|
||||
}
|
||||
|
||||
public static int TableRoll(int mobLevel) {
|
||||
mobLevel = Math.min(mobLevel, 65);
|
||||
|
||||
int max = Math.min((int) (4.882 * mobLevel + 127.0), 319);
|
||||
int min = Math.max((int) (4.469 * mobLevel - 3.469), 70);
|
||||
if (mobLevel > 65)
|
||||
mobLevel = 65;
|
||||
|
||||
return ThreadLocalRandom.current().nextInt(min, max + 1);
|
||||
int max = (int) (4.882 * mobLevel + 127.0);
|
||||
|
||||
if (max > 319)
|
||||
max = 319;
|
||||
|
||||
int min = (int) (4.469 * mobLevel - 3.469);
|
||||
|
||||
if (min < 70)
|
||||
min = 70;
|
||||
|
||||
int roll = ThreadLocalRandom.current().nextInt(min, max + 1);
|
||||
|
||||
return roll;
|
||||
}
|
||||
|
||||
public static void GenerateGoldDrop(Mob mob, BootySetEntry bse) {
|
||||
int chanceRoll = ThreadLocalRandom.current().nextInt(1, 101); // Simplified the chance roll to be out of 100 directly
|
||||
|
||||
// Early exit if failed to hit minimum chance roll
|
||||
if (chanceRoll > bse.dropChance) {
|
||||
int chanceRoll = ThreadLocalRandom.current().nextInt(1, 100 + 1);
|
||||
|
||||
//early exit, failed to hit minimum chance roll
|
||||
|
||||
if (chanceRoll > bse.dropChance)
|
||||
return;
|
||||
}
|
||||
|
||||
// Determine and add gold to mob inventory
|
||||
int high = (int) (bse.highGold * NORMAL_GOLD_RATE);
|
||||
int low = (int) (bse.lowGold * NORMAL_GOLD_RATE);
|
||||
//determine and add gold to mob inventory
|
||||
|
||||
int high = (int)(bse.highGold * NORMAL_GOLD_RATE);
|
||||
int low = (int)(bse.lowGold * NORMAL_GOLD_RATE);
|
||||
int gold = ThreadLocalRandom.current().nextInt(low, high);
|
||||
|
||||
if (gold > 0) {
|
||||
MobLoot goldAmount = new MobLoot(mob, gold);
|
||||
mob.getCharItemManager().addItemToInventory(goldAmount);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public static void GenerateLootDrop(Mob mob, int tableID) {
|
||||
if (mob.parentZone.getSafeZone() == 1) {
|
||||
return; // Exit early if in a safe zone
|
||||
}
|
||||
|
||||
try {
|
||||
if(mob.parentZone.getSafeZone() == 1) {
|
||||
return;
|
||||
}
|
||||
MobLoot toAdd = getGenTableItem(tableID, mob);
|
||||
if (toAdd != null && !isContractOrRune(toAdd)) {
|
||||
if(toAdd.getItemBase().getType().equals(Enum.ItemType.CONTRACT) || toAdd.getItemBase().getType().equals(Enum.ItemType.RUNE))
|
||||
return;//block all contracts and runes that drop outside the confines of the new system
|
||||
|
||||
if (toAdd != null) {
|
||||
toAdd.setIsID(true);
|
||||
mob.getCharItemManager().addItemToInventory(toAdd);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
// Handle exceptions if necessary
|
||||
//TODO chase down loot generation error, affects roughly 2% of drops
|
||||
}
|
||||
}
|
||||
|
||||
private static boolean isContractOrRune(MobLoot loot) {
|
||||
Enum.ItemType type = loot.getItemBase().getType();
|
||||
return type == Enum.ItemType.CONTRACT || type == Enum.ItemType.RUNE;
|
||||
}
|
||||
|
||||
public static void GenerateEquipmentDrop(Mob mob) {
|
||||
if (mob.parentZone.getSafeZone() == 1) {
|
||||
|
||||
if(mob.parentZone.getSafeZone() == 1) {
|
||||
return;
|
||||
}
|
||||
|
||||
//do equipment here
|
||||
int dropCount = 0;
|
||||
if (mob.getEquip() != null) {
|
||||
if (mob.getEquip() != null)
|
||||
for (MobEquipment me : mob.getEquip().values()) {
|
||||
if (me.getDropChance() == 0) {
|
||||
continue;
|
||||
}
|
||||
|
||||
float equipmentRoll = ThreadLocalRandom.current().nextInt(1, 101); // Simplified the roll to be out of 100 directly
|
||||
if (me.getDropChance() == 0)
|
||||
continue;
|
||||
|
||||
float equipmentRoll = ThreadLocalRandom.current().nextInt(1, 100 + 1);
|
||||
float dropChance = me.getDropChance() * 100;
|
||||
|
||||
if (equipmentRoll > dropChance) {
|
||||
if (equipmentRoll > dropChance)
|
||||
continue;
|
||||
}
|
||||
|
||||
ItemBase genericIB = me.getItemBase();
|
||||
if (genericIB.isVorg()) {
|
||||
genericIB = getRandomVorgPiece(genericIB); // Replaced separate method calls with a single one
|
||||
mob.spawnTime = ThreadLocalRandom.current().nextInt(300, 2700);
|
||||
if(genericIB.isVorg()){
|
||||
if(genericIB.isClothArmor()){
|
||||
//get random cloth piece
|
||||
genericIB = getRandomVorgCloth();//ItemBase.getItemBase(vorg_cloth_uuids.get(ThreadLocalRandom.current().nextInt(0,vorg_cloth_uuids.size() - 1)));
|
||||
} else if(genericIB.isHeavyArmor()){
|
||||
//get random heavy armor piece
|
||||
genericIB = getRandomVorgHA();//ItemBase.getItemBase(vorg_ha_uuids.get(ThreadLocalRandom.current().nextInt(0,vorg_ha_uuids.size() - 1)));
|
||||
} else if(genericIB.isMediumArmor()){
|
||||
//get random medium armor piece
|
||||
genericIB = getRandomVorgMA();//ItemBase.getItemBase(vorg_ma_uuids.get(ThreadLocalRandom.current().nextInt(0,vorg_ma_uuids.size() - 1)));
|
||||
} else if(genericIB.isLightArmor()){
|
||||
//get random light armor piece
|
||||
genericIB = getRandomVorgLA();//ItemBase.getItemBase(vorg_la_uuids.get(ThreadLocalRandom.current().nextInt(0,vorg_la_uuids.size() - 1)));
|
||||
}
|
||||
mob.spawnTime = ThreadLocalRandom.current().nextInt(300,2700);
|
||||
}
|
||||
MobLoot ml = new MobLoot(mob, genericIB, false);
|
||||
|
||||
MobLoot ml = new MobLoot(mob, genericIB, false);
|
||||
|
||||
if (ml != null && dropCount < 1) {
|
||||
if (ml != null && dropCount < 1 && genericIB.isVorg() == false) {
|
||||
ml.setIsID(true);
|
||||
ml.setDurabilityCurrent((short) (ml.getDurabilityCurrent() - ThreadLocalRandom.current().nextInt(5) + 1));
|
||||
mob.getCharItemManager().addItemToInventory(ml);
|
||||
dropCount++;
|
||||
dropCount = 1;
|
||||
//break; // Exit on first successful roll.
|
||||
}
|
||||
|
||||
if (ml != null && genericIB.isVorg() && mob.getMobBaseID() != 14062) {
|
||||
if(ml != null && genericIB.isVorg() && mob.getMobBaseID() != 14062){
|
||||
ml.setIsID(true);
|
||||
ml.setDurabilityCurrent(ml.getDurabilityMax());
|
||||
mob.getCharItemManager().addItemToInventory(ml);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static ItemBase getRandomVorgPiece(ItemBase genericIB) {
|
||||
if (genericIB.isClothArmor()) {
|
||||
return getRandomVorgCloth();
|
||||
} else if (genericIB.isHeavyArmor()) {
|
||||
return getRandomVorgHA();
|
||||
} else if (genericIB.isMediumArmor()) {
|
||||
return getRandomVorgMA();
|
||||
} else if (genericIB.isLightArmor()) {
|
||||
return getRandomVorgLA();
|
||||
}
|
||||
return genericIB; // Return the original item base if it's not a vorg piece
|
||||
}
|
||||
|
||||
public static void GenerateInventoryDrop(Mob mob, BootySetEntry bse) {
|
||||
// Check if the item is a discipline rune
|
||||
if (ItemBase.getItemBase(bse.itemBase).isDiscRune()) {
|
||||
if (!Mob.disciplineDroppers.contains(mob)) {
|
||||
|
||||
if(ItemBase.getItemBase(bse.itemBase).isDiscRune()) {
|
||||
if(!Mob.disciplineDroppers.contains(mob))
|
||||
Mob.disciplineDroppers.add(mob);
|
||||
mob.setResists(new Resists("Dropper"));
|
||||
ChatSystemMsg chatMsg = new ChatSystemMsg(null, mob.getName() + " in " + mob.getParentZone().getName() + " has found the " + ItemBase.getItemBase(bse.itemBase).getName() + ". Are you tough enough to take it?");
|
||||
chatMsg.setMessageType(10);
|
||||
chatMsg.setChannel(Enum.ChatChannelType.SYSTEM.getChannelID());
|
||||
DispatchMessage.dispatchMsgToAll(chatMsg);
|
||||
}
|
||||
|
||||
mob.setResists(new Resists("Dropper"));
|
||||
ChatSystemMsg chatMsg = new ChatSystemMsg(null, mob.getName() + " in " + mob.getParentZone().getName() + " has found the " + ItemBase.getItemBase(bse.itemBase).getName() + ". Are you tough enough to take it?");
|
||||
chatMsg.setMessageType(10);
|
||||
chatMsg.setChannel(Enum.ChatChannelType.SYSTEM.getChannelID());
|
||||
DispatchMessage.dispatchMsgToAll(chatMsg);
|
||||
}
|
||||
|
||||
// Skip drop if mob is in a safe zone
|
||||
if (mob.parentZone.getSafeZone() == 1) {
|
||||
//if((bse.itemBase == 3040 || bse.itemBase == 3021) && mob.level < 80){
|
||||
// chance = 100;
|
||||
//}
|
||||
|
||||
if(mob.parentZone.getSafeZone() == 1) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Roll for drop chance
|
||||
int chanceRoll = ThreadLocalRandom.current().nextInt(1, 100); // Changed upper bound to 100
|
||||
int chanceRoll = ThreadLocalRandom.current().nextInt(1, 99);
|
||||
|
||||
// Check if the chance roll exceeds drop chance
|
||||
if (chanceRoll > bse.dropChance) {
|
||||
return; // Early exit if the drop chance fails
|
||||
}
|
||||
//early exit, failed to hit minimum chance roll
|
||||
|
||||
if (chanceRoll > bse.dropChance)
|
||||
return;
|
||||
|
||||
// Create and add the loot item to the mob's inventory
|
||||
MobLoot lootItem = new MobLoot(mob, ItemBase.getItemBase(bse.itemBase), true);
|
||||
if (lootItem != null) {
|
||||
|
||||
if (lootItem != null)
|
||||
mob.getCharItemManager().addItemToInventory(lootItem);
|
||||
}
|
||||
}
|
||||
|
||||
public static void peddleFate(PlayerCharacter playerCharacter, Item gift) {
|
||||
@@ -540,77 +549,155 @@ public enum LootManager {
|
||||
itemMan.updateInventory();
|
||||
}
|
||||
|
||||
public static MobLoot rollForContract(int table, Mob mob) {
|
||||
mob.parentZone.lastContractDrop = System.currentTimeMillis();
|
||||
int roll = (table == 1900 || table == 1500) ? 73 : 99;
|
||||
public static MobLoot rollForContract(int table, Mob mob){
|
||||
|
||||
int roll = 99;
|
||||
if (table == 1900 || table == 1500)
|
||||
roll = 73;
|
||||
GenTableEntry selectedRow = GenTableEntry.rollTable(table, roll, 1.0f);
|
||||
if (selectedRow == null) {
|
||||
if (selectedRow == null)
|
||||
return null;
|
||||
}
|
||||
|
||||
int itemTableId = selectedRow.itemTableID;
|
||||
if (!_itemTables.containsKey(itemTableId)) {
|
||||
|
||||
if (_itemTables.containsKey(itemTableId) == false)
|
||||
return null;
|
||||
}
|
||||
|
||||
ItemTableEntry tableRow = ItemTableEntry.rollTable(itemTableId, ThreadLocalRandom.current().nextInt(1, 321));
|
||||
if (tableRow == null || tableRow.cacheID == 0) {
|
||||
ItemTableEntry tableRow = ItemTableEntry.rollTable(itemTableId, ThreadLocalRandom.current().nextInt(75,321));
|
||||
if (tableRow == null)
|
||||
return null;
|
||||
}
|
||||
|
||||
return new MobLoot(mob, ItemBase.getItemBase(tableRow.cacheID), false);
|
||||
}
|
||||
int itemUUID = tableRow.cacheID;
|
||||
|
||||
public static MobLoot rollForRune(int table, Mob mob) {
|
||||
mob.parentZone.lastRuneDrop = System.currentTimeMillis();
|
||||
int roll = (table == 1900 || table == 1500) ? 77 : 97;
|
||||
GenTableEntry selectedRow = GenTableEntry.rollTable(table, roll, 1.0f);
|
||||
if (selectedRow == null) {
|
||||
if (itemUUID == 0)
|
||||
return null;
|
||||
}
|
||||
|
||||
int itemTableId = selectedRow.itemTableID;
|
||||
if (!_itemTables.containsKey(itemTableId)) {
|
||||
return null;
|
||||
}
|
||||
|
||||
ItemTableEntry tableRow = ItemTableEntry.rollTable(itemTableId, ThreadLocalRandom.current().nextInt(1, 321));
|
||||
if (tableRow == null || tableRow.cacheID == 0) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return new MobLoot(mob, ItemBase.getItemBase(tableRow.cacheID), false);
|
||||
}
|
||||
|
||||
public static MobLoot rollForGlass(Mob mob) {
|
||||
ItemTableEntry tableRow = ItemTableEntry.rollTable(126, ThreadLocalRandom.current().nextInt(1, 321));
|
||||
if (tableRow != null && tableRow.cacheID != 0) {
|
||||
return new MobLoot(mob, ItemBase.getItemBase(tableRow.cacheID), false);
|
||||
MobLoot outItem = new MobLoot(mob, ItemBase.getItemBase(itemUUID), false);
|
||||
if(outItem != null) {
|
||||
mob.contractCounter = 0;
|
||||
return outItem;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static ItemBase getRandomVorgItem(int maxRandom, int... itemBaseIDs) {
|
||||
int random = ThreadLocalRandom.current().nextInt(maxRandom);
|
||||
int index = random / (maxRandom / itemBaseIDs.length);
|
||||
if (index >= itemBaseIDs.length) {
|
||||
index = itemBaseIDs.length - 1;
|
||||
public static MobLoot rollForRune(int table, Mob mob){
|
||||
int roll = 97;
|
||||
if(table == 1900 || table == 1500){
|
||||
roll = 77;
|
||||
}
|
||||
return ItemBase.getItemBase(itemBaseIDs[index]);
|
||||
GenTableEntry selectedRow = GenTableEntry.rollTable(table, roll, 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(75,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) {
|
||||
mob.runeCounter = 0;
|
||||
return outItem;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
public static ItemBase getRandomVorgCloth() {
|
||||
return getRandomVorgItem(100, 27600, 188700, 188720, 189550, 189560);
|
||||
public static MobLoot rollForGlass( Mob mob){
|
||||
ItemTableEntry tableRow = ItemTableEntry.rollTable(126, ThreadLocalRandom.current().nextInt(220,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 ItemBase getRandomVorgLA() {
|
||||
return getRandomVorgItem(160, 27550, 27560, 189100, 189110, 189120, 189130, 189140, 189150);
|
||||
public static ItemBase getRandomVorgCloth(){
|
||||
int random = ThreadLocalRandom.current().nextInt(100);
|
||||
if(random < 20)
|
||||
return ItemBase.getItemBase(27600);
|
||||
if(random > 20 && random < 40)
|
||||
return ItemBase.getItemBase(188700);
|
||||
if(random > 40 && random < 60)
|
||||
return ItemBase.getItemBase(188720);
|
||||
if(random > 60 && random < 80)
|
||||
return ItemBase.getItemBase(189550);
|
||||
if(random > 80)
|
||||
return ItemBase.getItemBase(189560);
|
||||
return null;
|
||||
}
|
||||
|
||||
public static ItemBase getRandomVorgMA() {
|
||||
return getRandomVorgItem(160, 27570, 188900, 188910, 188920, 188930, 188940, 188950, 189500);
|
||||
public static ItemBase getRandomVorgLA(){
|
||||
int random = ThreadLocalRandom.current().nextInt(160);
|
||||
if(random < 20)
|
||||
return ItemBase.getItemBase(27550);
|
||||
if(random > 20 && random < 40)
|
||||
return ItemBase.getItemBase(27560);
|
||||
if(random > 40 && random < 60)
|
||||
return ItemBase.getItemBase(189100);
|
||||
if(random > 60 && random < 80)
|
||||
return ItemBase.getItemBase(189110);
|
||||
if(random > 80 && random < 100)
|
||||
return ItemBase.getItemBase(189120);
|
||||
if(random > 100 && random < 120)
|
||||
return ItemBase.getItemBase(189130);
|
||||
if(random > 120 && random < 140)
|
||||
return ItemBase.getItemBase(189140);
|
||||
if(random > 140)
|
||||
return ItemBase.getItemBase(189150);
|
||||
return null;
|
||||
}
|
||||
|
||||
public static ItemBase getRandomVorgHA() {
|
||||
return getRandomVorgItem(180, 27580, 27590, 188500, 188510, 188520, 188530, 188540, 188550, 189510);
|
||||
public static ItemBase getRandomVorgMA(){
|
||||
int random = ThreadLocalRandom.current().nextInt(160);
|
||||
if(random < 20)
|
||||
return ItemBase.getItemBase(27570);
|
||||
if(random > 20 && random < 40)
|
||||
return ItemBase.getItemBase(188900);
|
||||
if(random > 40 && random < 60)
|
||||
return ItemBase.getItemBase(188910);
|
||||
if(random > 60 && random < 80)
|
||||
return ItemBase.getItemBase(188920);
|
||||
if(random > 80 && random < 100)
|
||||
return ItemBase.getItemBase(188930);
|
||||
if(random > 100 && random < 120)
|
||||
return ItemBase.getItemBase(188940);
|
||||
if(random > 120 && random < 140)
|
||||
return ItemBase.getItemBase(188950);
|
||||
if(random > 140)
|
||||
return ItemBase.getItemBase(189500);
|
||||
return null;
|
||||
}
|
||||
public static ItemBase getRandomVorgHA(){
|
||||
int random = ThreadLocalRandom.current().nextInt(180);
|
||||
if(random < 20)
|
||||
return ItemBase.getItemBase(27580);
|
||||
if(random > 20 && random < 40)
|
||||
return ItemBase.getItemBase(27590);
|
||||
if(random > 40 && random < 60)
|
||||
return ItemBase.getItemBase(188500);
|
||||
if(random > 60 && random < 80)
|
||||
return ItemBase.getItemBase(188510);
|
||||
if(random > 80 && random < 100)
|
||||
return ItemBase.getItemBase(188520);
|
||||
if(random > 100 && random < 120)
|
||||
return ItemBase.getItemBase(188530);
|
||||
if(random > 120 && random < 140)
|
||||
return ItemBase.getItemBase(188540);
|
||||
if(random > 140 && random < 160)
|
||||
return ItemBase.getItemBase(188550);
|
||||
if(random > 160)
|
||||
return ItemBase.getItemBase(189510);
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
+99
-109
@@ -12,7 +12,6 @@ package engine.objects;
|
||||
import ch.claude_martin.enumbitset.EnumBitSet;
|
||||
import engine.Enum;
|
||||
import engine.Enum.*;
|
||||
import engine.InterestManagement.RealmMap;
|
||||
import engine.InterestManagement.WorldGrid;
|
||||
import engine.exception.SerializationException;
|
||||
import engine.gameManager.*;
|
||||
@@ -26,7 +25,6 @@ import engine.net.Dispatch;
|
||||
import engine.net.DispatchMessage;
|
||||
import engine.net.client.msg.PetMsg;
|
||||
import engine.net.client.msg.PlaceAssetMsg;
|
||||
import engine.net.client.msg.chat.ChatSystemMsg;
|
||||
import engine.powers.MobPowerEntry;
|
||||
import engine.server.MBServerStatics;
|
||||
import org.joda.time.DateTime;
|
||||
@@ -38,6 +36,7 @@ import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.LinkedHashMap;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
import java.util.concurrent.ThreadLocalRandom;
|
||||
import java.util.concurrent.locks.ReentrantReadWriteLock;
|
||||
|
||||
import static engine.gameManager.NPCManager._runeSetMap;
|
||||
@@ -87,6 +86,9 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
|
||||
public boolean dropper = false;
|
||||
|
||||
public int contractCounter = 0;
|
||||
public int runeCounter = 0;
|
||||
|
||||
// New Mobile constructor. Fill in the blanks and then call
|
||||
// PERSIST.
|
||||
public Mob() {
|
||||
@@ -96,6 +98,7 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
this.bindLoc = Vector3fImmutable.ZERO;
|
||||
this.gridObjectType = GridObjectType.DYNAMIC;
|
||||
this.agentType = AIAgentType.MOBILE;
|
||||
setResistsForMob(this);
|
||||
}
|
||||
|
||||
|
||||
@@ -164,6 +167,13 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
this.currentID = this.dbID;
|
||||
|
||||
this.agentType = AIAgentType.MOBILE;
|
||||
|
||||
//this.setResists(Resists.getResists(rs.getInt("mob_spawnType")));
|
||||
|
||||
setResistsForMob(this);
|
||||
|
||||
this.contractCounter = ThreadLocalRandom.current().nextInt(250);
|
||||
this.runeCounter = ThreadLocalRandom.current().nextInt(250);
|
||||
} catch (Exception e) {
|
||||
Logger.error(e + " " + this.dbID);
|
||||
}
|
||||
@@ -172,77 +182,78 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
|
||||
public static void setResistsForMob(Mob mob){
|
||||
Resists resists = new Resists("Generic");
|
||||
|
||||
Zone parentMacro = null;
|
||||
for(Zone zone : ZoneManager.getAllZonesIn(mob.loc)){
|
||||
if(zone.isMacroZone() == false)
|
||||
continue;
|
||||
parentMacro = zone;
|
||||
}
|
||||
if(parentMacro != null) {
|
||||
switch (parentMacro.getName()) {
|
||||
//ice generics
|
||||
case "Ymur's Crown":
|
||||
case "Kralgaar Holm":
|
||||
case "Ecklund Wilds":
|
||||
case "Aurrochs Skrae":
|
||||
resists.addResists(Resists.getResists(28));
|
||||
break;
|
||||
//Desert Generics
|
||||
case "Leth'khalivar Desert":
|
||||
case "Kharsoom":
|
||||
case "Vale of Nar Addad":
|
||||
case "The Blood Sands":
|
||||
resists.addResists(Resists.getResists(2));
|
||||
break;
|
||||
//Swamp Generics
|
||||
case "Thollok Marsh":
|
||||
case "The Black Bog":
|
||||
case "Sevaath Mere":
|
||||
resists.addResists(Resists.getResists(8));
|
||||
break;
|
||||
//Oblivion Generics
|
||||
case "Plain of Ashes":
|
||||
case "Bone Marches":
|
||||
case "The Doomplain":
|
||||
case "Greensward Pyre":
|
||||
resists.addResists(Resists.getResists(4));
|
||||
break;
|
||||
//Maelstrom Generics
|
||||
case "Pandemonium":
|
||||
case "Western Battleground":
|
||||
resists.addResists(Resists.getResists(32));
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(MobBase.mobbase_race_types.size() == 0){
|
||||
DbManager.MobBaseQueries.LOAD_ALL_MOBBASE_RACES();
|
||||
}
|
||||
String raceType = MobBase.mobbase_race_types.get(mob.getMobBaseID());
|
||||
if(raceType != null) {
|
||||
switch (raceType) {
|
||||
int mobbaseID = mob.getMobBaseID();
|
||||
if(mobbaseID != 0) {
|
||||
switch (MobBase.mobbase_race_types.get(mobbaseID)) {
|
||||
case "Aelfborn":
|
||||
case "NPC":
|
||||
case "Rat":
|
||||
case "Reptile":
|
||||
case "Grave":
|
||||
case "Human":
|
||||
case "Goblin":
|
||||
case "CSR":
|
||||
case "Construct":
|
||||
case "Celestial":
|
||||
case "Animal":
|
||||
case "All":
|
||||
case "SiegeEngineer":
|
||||
int realmID = RealmMap.getRealmIDAtLocation(mob.bindLoc);
|
||||
Realm realm = Realm.getRealm(realmID);
|
||||
if (realm != null) {
|
||||
switch (realm.getRealmName()) {
|
||||
//ice generics
|
||||
case "Hethlund":
|
||||
case "Hregenlund":
|
||||
case "Ecklund":
|
||||
case "Kralgaard":
|
||||
resists.addResists(Resists.getResists(28));
|
||||
break;
|
||||
//Desert Generics
|
||||
case "Letharuun":
|
||||
case "Adduram":
|
||||
case "Neshraa":
|
||||
resists.addResists(Resists.getResists(2));
|
||||
break;
|
||||
//Swamp Generics
|
||||
case "Aeglund":
|
||||
case "Thollmar":
|
||||
resists.addResists(Resists.getResists(8));
|
||||
break;
|
||||
//Oblivion Generics
|
||||
case "Oblivion":
|
||||
case "Vandernoch":
|
||||
resists.addResists(Resists.getResists(4));
|
||||
break;
|
||||
//Maelstrom Generics
|
||||
case "Maelstrom":
|
||||
resists.addResists(Resists.getResists(32));
|
||||
break;
|
||||
case "Valkos":
|
||||
case "Ulward":
|
||||
resists.addResists(Resists.getResists(5));
|
||||
}
|
||||
}
|
||||
break;
|
||||
case "Reptile":
|
||||
case "Dragon":
|
||||
resists.addResists(Resists.getResists(10));
|
||||
break;
|
||||
case "Goblin":
|
||||
resists.addResists(Resists.getResists(9));
|
||||
resists.addResists(new Resists("Generic"));
|
||||
break;
|
||||
case "Aracoix":
|
||||
resists.addResists(Resists.getResists(22));
|
||||
break;
|
||||
case "Rat":
|
||||
case "Troll":
|
||||
resists.addResists(Resists.getResists(33));
|
||||
break;
|
||||
case "Centaur":
|
||||
resists.addResists(Resists.getResists(24));
|
||||
break;
|
||||
case "Dragon":
|
||||
resists.addResists(Resists.getResists(10));
|
||||
break;
|
||||
case "Dwarf":
|
||||
resists.addResists(Resists.getResists(25));
|
||||
break;
|
||||
@@ -284,6 +295,9 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
case "Siege":
|
||||
resists.addResists(Resists.getResists(38));
|
||||
break;
|
||||
case "Troll":
|
||||
resists.addResists(Resists.getResists(33));
|
||||
break;
|
||||
case "Undead":
|
||||
resists.addResists(Resists.getResists(27));
|
||||
break;
|
||||
@@ -1010,7 +1024,7 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
//Next upda
|
||||
}
|
||||
|
||||
this.setLoc(newLoc);
|
||||
setLoc(newLoc);
|
||||
this.region = AbstractWorldObject.GetRegionByWorldObject(this);
|
||||
//Next update will be end Loc, lets stop him here.
|
||||
|
||||
@@ -1185,17 +1199,6 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
return;
|
||||
|
||||
LootManager.GenerateMobLoot(this);
|
||||
if(this.dropper){
|
||||
for(Item item : this.charItemManager.getInventory()) {
|
||||
ItemBase ib = item.getItemBase();
|
||||
if(ib.isDiscRune()) {
|
||||
ChatSystemMsg chatMsg = new ChatSystemMsg(null, this.getName() + " in " + this.getParentZone().getName() + " has found the " + ib.getName() + ". Are you tough enough to take it?");
|
||||
chatMsg.setMessageType(10);
|
||||
chatMsg.setChannel(Enum.ChatChannelType.SYSTEM.getChannelID());
|
||||
DispatchMessage.dispatchMsgToAll(chatMsg);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -1711,10 +1714,7 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
this.behaviourType = MobBehaviourType.GuardCaptain;
|
||||
this.spawnTime = 60 * 15;
|
||||
this.isPlayerGuard = true;
|
||||
if(this.building != null && ZoneManager.getCityAtLocation(this.building.getLoc()) != null)
|
||||
this.guardedCity = ZoneManager.getCityAtLocation(this.building.getLoc());
|
||||
else
|
||||
this.guardedCity = null;
|
||||
this.guardedCity = ZoneManager.getCityAtLocation(this.building.getLoc());
|
||||
}
|
||||
|
||||
// Load AI for wall archers
|
||||
@@ -1771,8 +1771,8 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
//TODO set these correctly later
|
||||
this.rangeHandOne = this.mobBase.getAttackRange();
|
||||
this.rangeHandTwo = -1;
|
||||
this.minDamageHandOne = (int) this.mobBase.getMinDmg();
|
||||
this.maxDamageHandOne = (int) this.mobBase.getMaxDmg();
|
||||
this.minDamageHandOne = (int)this.mobBase.getMinDmg();
|
||||
this.maxDamageHandOne = (int)this.mobBase.getMaxDmg();
|
||||
this.minDamageHandTwo = 0;
|
||||
this.maxDamageHandTwo = 0;
|
||||
this.atrHandOne = this.mobBase.getAtr();
|
||||
@@ -1852,10 +1852,10 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
try {
|
||||
NPCManager.applyRuneSetEffects(this);
|
||||
recalculateStats();
|
||||
if (this.mobBase.getLevel() > 80) {
|
||||
if (this.getMobBaseID() == 14319) {//ithriana
|
||||
if(this.mobBase.getLevel() > 80){
|
||||
if(this.getMobBaseID() == 14319){//ithriana
|
||||
this.healthMax = 5400000;
|
||||
} else {
|
||||
} else{
|
||||
this.healthMax = 1500000;
|
||||
}
|
||||
}
|
||||
@@ -1879,51 +1879,41 @@ public class Mob extends AbstractIntelligenceAgent {
|
||||
Logger.error(e.getMessage());
|
||||
}
|
||||
|
||||
if (this.behaviourType.equals(MobBehaviourType.HamletGuard) && this.getMobBaseID() == 14104) {//guards
|
||||
if(this.behaviourType.equals(MobBehaviourType.HamletGuard) && this.getMobBaseID() == 14104) {//guards
|
||||
this.behaviourType = MobBehaviourType.Aggro;
|
||||
}
|
||||
|
||||
for (MobEquipment equipped : this.equip.values()) {
|
||||
if (equipped.getItemBase().isVorg() && this.getMobBaseID() != 14062 && this.getMobBaseID() != 14163) {
|
||||
for(MobEquipment equipped: this.equip.values()){
|
||||
if(equipped.getItemBase().isVorg() && this.getMobBaseID() != 14062 && this.getMobBaseID() != 14163){
|
||||
this.dropper = true;
|
||||
}
|
||||
}
|
||||
for (Item item : this.charItemManager.getInventory()) {
|
||||
if (item.getItemBase().isDiscRune() && this.level < 75) {
|
||||
for(Item item : this.charItemManager.getInventory()){
|
||||
if(item.getItemBase().isDiscRune() && this.level < 75){
|
||||
this.dropper = true;
|
||||
}
|
||||
}
|
||||
switch (this.getObjectUUID()) {
|
||||
case 40551://ithrianna
|
||||
this.mobResists = Resists.getResists(14);
|
||||
break;
|
||||
case 11297: // mordoth
|
||||
this.mobResists = Resists.getResists(16);
|
||||
break;
|
||||
case 19842://vranaxxas
|
||||
this.mobResists = Resists.getResists(37);
|
||||
break;
|
||||
case 6407://draug tovald
|
||||
this.mobResists = Resists.getResists(15);
|
||||
break;
|
||||
case 30959://shuggroth mael
|
||||
this.mobResists = Resists.getResists(17);
|
||||
break;
|
||||
default:
|
||||
if (this.dropper) {
|
||||
this.level = 65;
|
||||
this.atrHandOne *= 2;
|
||||
this.atrHandTwo *= 2;
|
||||
this.defenseRating *= 2;
|
||||
this.maxDamageHandOne *= 2;
|
||||
this.maxDamageHandTwo *= 2;
|
||||
this.minDamageHandOne *= 2;
|
||||
this.minDamageHandTwo *= 2;
|
||||
this.mobResists = new Resists("Dropper");
|
||||
}// else {
|
||||
//setResistsForMob(this);
|
||||
//}
|
||||
|
||||
if(this.dropper){
|
||||
this.level = 65;
|
||||
this.atrHandOne *= 2;
|
||||
this.atrHandTwo *= 2;
|
||||
this.defenseRating *= 2;
|
||||
this.maxDamageHandOne *= 2;
|
||||
this.maxDamageHandTwo *= 2;
|
||||
this.minDamageHandOne *= 2;
|
||||
this.minDamageHandTwo *= 2;
|
||||
}
|
||||
//for(Item loot : this.charItemManager.getInventory()){
|
||||
// if(loot.getItemBase().isDiscRune() && this.level < 80){
|
||||
// if(this.firstSpawn) {
|
||||
// this.killCharacter("first spawn");
|
||||
// this.firstSpawn = false;
|
||||
// if(this.despawned == false)
|
||||
// this.despawn();
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
Reference in New Issue
Block a user