diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/map/mob.h | 17 | ||||
-rw-r--r-- | src/map/skill.c | 39 |
2 files changed, 48 insertions, 8 deletions
diff --git a/src/map/mob.h b/src/map/mob.h index 3510030f7..8232b726a 100644 --- a/src/map/mob.h +++ b/src/map/mob.h @@ -272,6 +272,17 @@ enum { * Mob IDs */ enum mob_id { + MOBID_RED_PLANT = 1078, ///< RED_PLANT / Red Plant + MOBID_BLUE_PLANT = 1079, ///< BLUE_PLANT / Blue Plant + MOBID_GREEN_PLANT = 1080, ///< GREEN_PLANT / Green Plant + MOBID_YELLOW_PLANT = 1081, ///< YELLOW_PLANT / Yellow Plant + MOBID_WHITE_PLANT = 1082, ///< WHITE_PLANT / White Plant + MOBID_SHINING_PLANT = 1083, ///< SHINING_PLANT / Shining Plant + MOBID_BLACK_MUSHROOM = 1084, ///< BLACK_MUSHROOM / Black Mushroom + MOBID_RED_MUSHROOM = 1085, ///< RED_MUSHROOM / Red Mushroom + + MOBID_MARINE_SPHERE = 1142, ///< MARINE_SPHERE / Marine Sphere + MOBID_EMPELIUM = 1288, ///< EMPELIUM / Emperium MOBID_TREASURE_BOX1 = 1324, ///< TREASURE_BOX1 / Treasure Chest @@ -315,6 +326,12 @@ enum mob_id { MOBID_TREASURE_BOX39 = 1362, ///< TREASURE_BOX39 / Treasure Chest MOBID_TREASURE_BOX40 = 1363, ///< TREASURE_BOX40 / Treasure Chest + MOBID_G_PARASITE = 1555, ///< G_PARASITE / Parasite + MOBID_G_FLORA = 1575, ///< G_FLORA / Flora + MOBID_G_HYDRA = 1579, ///< G_HYDRA / Hydra + MOBID_G_MANDRAGORA = 1589, ///< G_MANDRAGORA / Mandragora + MOBID_G_GEOGRAPHER = 1590, ///< G_GEOGRAPHER / Geographer + MOBID_BARRICADE = 1905, ///< BARRICADE / Barricade MOBID_BARRICADE_ = 1906, ///< BARRICADE_ / Barricade MOBID_S_EMPEL_1 = 1907, ///< S_EMPEL_1 / Guardian Stone diff --git a/src/map/skill.c b/src/map/skill.c index 2e3d7957d..260bc47db 100644 --- a/src/map/skill.c +++ b/src/map/skill.c @@ -10520,10 +10520,20 @@ int skill_castend_pos2(struct block_list* src, int x, int y, uint16 skill_id, ui case AM_SPHEREMINE: case AM_CANNIBALIZE: { - int summons[5] = { 1589, 1579, 1575, 1555, 1590 }; - //int summons[5] = { 1020, 1068, 1118, 1500, 1368 }; - int class_ = skill_id==AM_SPHEREMINE?1142:summons[skill_lv-1]; struct mob_data *md; + int class_ = 0; + if (skill_id == AM_SPHEREMINE) { + class_ = MOBID_MARINE_SPHERE; + } else { + Assert_retb(skill_lv > 0 && skill_lv <= 5); + switch (skill_lv) { + case 1: class_ = MOBID_G_MANDRAGORA; break; + case 2: class_ = MOBID_G_HYDRA; break; + case 3: class_ = MOBID_G_FLORA; break; + case 4: class_ = MOBID_G_PARASITE; break; + case 5: class_ = MOBID_G_GEOGRAPHER; break; + } + } // Correct info, don't change any of this! [Celest] md = mob->once_spawn_sub(src, src->m, x, y, status->get_name(src), class_, "", SZ_SMALL, AI_NONE); @@ -10624,7 +10634,8 @@ int skill_castend_pos2(struct block_list* src, int x, int y, uint16 skill_id, ui if (rnd()%100 < 50) { clif->skill_fail(sd,skill_id,USESKILL_FAIL_LEVEL,0); } else { - TBL_MOB* md = mob->once_spawn_sub(src, src->m, x, y, "--ja--",(skill_lv < 2 ? 1084+rnd()%2 : 1078+rnd()%6),"", SZ_SMALL, AI_NONE); + int mob_id = skill_lv < 2 ? MOBID_BLACK_MUSHROOM + rnd()%2 : MOBID_RED_PLANT + rnd()%6; + TBL_MOB* md = mob->once_spawn_sub(src, src->m, x, y, "--ja--", mob_id, "", SZ_SMALL, AI_NONE); int i; if (!md) break; if ((i = skill->get_time(skill_id, skill_lv)) > 0) @@ -14018,10 +14029,22 @@ int skill_check_condition_castend(struct map_session_data* sd, uint16 skill_id, case AM_CANNIBALIZE: case AM_SPHEREMINE: { int c=0; - int summons[5] = { 1589, 1579, 1575, 1555, 1590 }; - //int summons[5] = { 1020, 1068, 1118, 1500, 1368 }; - int maxcount = (skill_id==AM_CANNIBALIZE)? 6-skill_lv : skill->get_maxcount(skill_id,skill_lv); - int mob_class = (skill_id==AM_CANNIBALIZE)? summons[skill_lv-1] :1142; + int maxcount = 0; + int mob_class = 0; + if (skill_id == AM_CANNIBALIZE) { + Assert_retb(skill_lv > 0 && skill_lv <= 5); + maxcount = 6-skill_lv; + switch (skill_lv) { + case 1: mob_class = MOBID_G_MANDRAGORA; break; + case 2: mob_class = MOBID_G_HYDRA; break; + case 3: mob_class = MOBID_G_FLORA; break; + case 4: mob_class = MOBID_G_PARASITE; break; + case 5: mob_class = MOBID_G_GEOGRAPHER; break; + } + } else { + maxcount = skill->get_maxcount(skill_id,skill_lv); + mob_class = MOBID_MARINE_SPHERE; + } if(battle_config.land_skill_limit && maxcount>0 && (battle_config.land_skill_limit&BL_PC)) { i = map->foreachinmap(skill->check_condition_mob_master_sub ,sd->bl.m, BL_MOB, sd->bl.id, mob_class, skill_id, &c); if( c >= maxcount |