Siege skill related additions.
Thanks to dontknowdontcare.
This commit is contained in:
		| @@ -95,7 +95,7 @@ public class SkillConditionMasterHandler | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpHaveSummon", OpHaveSummonSkillCondition::new); | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpHaveSummonedNpc", OpHaveSummonedNpcSkillCondition::new); | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpHome", OpHomeSkillCondition::new); | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpInSiegeTime", OpInSiegeTimeSkillCondition::new); | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpInSiege", OpInSiegeSkillCondition::new); | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpInstantzone", OpInstantzoneSkillCondition::new); | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpMainjob", OpMainjobSkillCondition::new); | ||||
| 		SkillConditionHandler.getInstance().registerHandler("OpNeedAgathion", OpNeedAgathionSkillCondition::new); | ||||
|   | ||||
| @@ -33,12 +33,12 @@ import org.l2jmobius.gameserver.model.skill.Skill; | ||||
|  */ | ||||
| public class OpCheckResidenceSkillCondition implements ISkillCondition | ||||
| { | ||||
| 	private final Set<Integer> _residencesId = new HashSet<>(); | ||||
| 	private final Set<Integer> _residenceIds = new HashSet<>(); | ||||
| 	private final boolean _isWithin; | ||||
| 	 | ||||
| 	public OpCheckResidenceSkillCondition(StatSet params) | ||||
| 	{ | ||||
| 		_residencesId.addAll(params.getList("residencesId", Integer.class)); | ||||
| 		_residenceIds.addAll(params.getList("residenceIds", Integer.class)); | ||||
| 		_isWithin = params.getBoolean("isWithin"); | ||||
| 	} | ||||
| 	 | ||||
| @@ -53,7 +53,7 @@ public class OpCheckResidenceSkillCondition implements ISkillCondition | ||||
| 				final ClanHall clanHall = ClanHallData.getInstance().getClanHallByClan(clan); | ||||
| 				if (clanHall != null) | ||||
| 				{ | ||||
| 					return _isWithin ? _residencesId.contains(clanHall.getResidenceId()) : !_residencesId.contains(clanHall.getResidenceId()); | ||||
| 					return _isWithin ? _residenceIds.contains(clanHall.getResidenceId()) : !_residenceIds.contains(clanHall.getResidenceId()); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|   | ||||
| @@ -0,0 +1,75 @@ | ||||
| /* | ||||
|  * This file is part of the L2J Mobius project. | ||||
|  *  | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  *  | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||||
|  * General Public License for more details. | ||||
|  *  | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| package handlers.skillconditionhandlers; | ||||
|  | ||||
| import java.util.HashSet; | ||||
| import java.util.Set; | ||||
|  | ||||
| import org.l2jmobius.gameserver.instancemanager.FortSiegeManager; | ||||
| import org.l2jmobius.gameserver.instancemanager.SiegeManager; | ||||
| import org.l2jmobius.gameserver.model.StatSet; | ||||
| import org.l2jmobius.gameserver.model.WorldObject; | ||||
| import org.l2jmobius.gameserver.model.actor.Creature; | ||||
| import org.l2jmobius.gameserver.model.siege.FortSiege; | ||||
| import org.l2jmobius.gameserver.model.siege.Siege; | ||||
| import org.l2jmobius.gameserver.model.skill.ISkillCondition; | ||||
| import org.l2jmobius.gameserver.model.skill.Skill; | ||||
|  | ||||
| /** | ||||
|  * @author dontknowdontcare | ||||
|  */ | ||||
| public class OpInSiegeSkillCondition implements ISkillCondition | ||||
| { | ||||
| 	private final Set<Integer> _residenceIds = new HashSet<>(); | ||||
| 	 | ||||
| 	public OpInSiegeSkillCondition(StatSet params) | ||||
| 	{ | ||||
| 		_residenceIds.addAll(params.getList("residenceIds", Integer.class)); | ||||
| 	} | ||||
| 	 | ||||
| 	@Override | ||||
| 	public boolean canUse(Creature caster, Skill skill, WorldObject target) | ||||
| 	{ | ||||
| 		for (int id : _residenceIds) | ||||
| 		{ | ||||
| 			if (valid(caster, id)) | ||||
| 			{ | ||||
| 				return true; | ||||
| 			} | ||||
| 		} | ||||
| 		return false; | ||||
| 	} | ||||
| 	 | ||||
| 	private boolean valid(Creature caster, int id) | ||||
| 	{ | ||||
| 		final FortSiege fortSiege = FortSiegeManager.getInstance().getSiege(id); | ||||
| 		if (fortSiege != null) | ||||
| 		{ | ||||
| 			return fortSiege.isInProgress() && fortSiege.getFort().getZone().isInsideZone(caster); | ||||
| 		} | ||||
| 		 | ||||
| 		final Siege castleSiege = SiegeManager.getInstance().getSiege(id); | ||||
| 		if (castleSiege != null) | ||||
| 		{ | ||||
| 			return castleSiege.isInProgress() && castleSiege.getCastle().getZone().isInsideZone(caster); | ||||
| 		} | ||||
| 		 | ||||
| 		// TODO: Check for clan hall siege | ||||
| 		 | ||||
| 		return false; | ||||
| 	} | ||||
| } | ||||
| @@ -1,40 +0,0 @@ | ||||
| /* | ||||
|  * This file is part of the L2J Mobius project. | ||||
|  *  | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  *  | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||||
|  * General Public License for more details. | ||||
|  *  | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| package handlers.skillconditionhandlers; | ||||
|  | ||||
| import org.l2jmobius.gameserver.model.StatSet; | ||||
| import org.l2jmobius.gameserver.model.WorldObject; | ||||
| import org.l2jmobius.gameserver.model.actor.Creature; | ||||
| import org.l2jmobius.gameserver.model.skill.ISkillCondition; | ||||
| import org.l2jmobius.gameserver.model.skill.Skill; | ||||
| import org.l2jmobius.gameserver.model.zone.ZoneId; | ||||
|  | ||||
| /** | ||||
|  * @author Mobius | ||||
|  */ | ||||
| public class OpInSiegeTimeSkillCondition implements ISkillCondition | ||||
| { | ||||
| 	public OpInSiegeTimeSkillCondition(StatSet params) | ||||
| 	{ | ||||
| 	} | ||||
| 	 | ||||
| 	@Override | ||||
| 	public boolean canUse(Creature caster, Skill skill, WorldObject target) | ||||
| 	{ | ||||
| 		return caster.isInsideZone(ZoneId.SIEGE); | ||||
| 	} | ||||
| } | ||||
| @@ -658,7 +658,7 @@ | ||||
| 		<conditions> | ||||
| 			<condition name="CanSummonPet" /> | ||||
| 			<condition name="OpCheckResidence"> | ||||
| 				<residencesId> | ||||
| 				<residenceIds> | ||||
| 					<item>36</item> | ||||
| 					<item>37</item> | ||||
| 					<item>38</item> | ||||
| @@ -672,7 +672,7 @@ | ||||
| 					<item>55</item> | ||||
| 					<item>56</item> | ||||
| 					<item>57</item> | ||||
| 				</residencesId> | ||||
| 				</residenceIds> | ||||
| 				<isWithin>false</isWithin> | ||||
| 			</condition> | ||||
| 		</conditions> | ||||
|   | ||||
| @@ -1559,10 +1559,19 @@ | ||||
| 		<targetType>SELF</targetType> | ||||
| 		<affectScope>SINGLE</affectScope> | ||||
| 		<conditions> | ||||
| 			<condition name="OpInSiegeTime"> | ||||
| 				<time>64</time> | ||||
| 			<condition name="OpInSiege"> | ||||
| 				<residenceIds> | ||||
| 					<item>64</item> | ||||
| 				</residenceIds> | ||||
| 			</condition> | ||||
| 		</conditions> | ||||
| 		<effects> | ||||
| 			<effect name="SummonNpc"> | ||||
| 				<npcId>33767</npcId> <!-- Jacquard --> | ||||
| 				<npcCount>1</npcCount> | ||||
| 				<despawnDelay>300000</despawnDelay> | ||||
| 			</effect> | ||||
| 		</effects> | ||||
| 	</skill> | ||||
| 	<skill id="15284" toLevel="1" name="Summon Brakel"> | ||||
| 		<!-- Summons Brakel, the Herald from the Fortress of Resistance. The Clan Hall Siege for the contestable Fortress of Resistance runs between 21:00 and 22:00 on the Friday of the Castle Siege week. Brakel teleports you to the battleground, and despawns after 5 min. Cooldown is 30 min. --> | ||||
| @@ -1576,10 +1585,19 @@ | ||||
| 		<targetType>SELF</targetType> | ||||
| 		<affectScope>SINGLE</affectScope> | ||||
| 		<conditions> | ||||
| 			<condition name="OpInSiegeTime"> | ||||
| 				<time>21</time> | ||||
| 			<condition name="OpInSiege"> | ||||
| 				<residenceIds> | ||||
| 					<item>21</item> | ||||
| 				</residenceIds> | ||||
| 			</condition> | ||||
| 		</conditions> | ||||
| 		<effects> | ||||
| 			<effect name="SummonNpc"> | ||||
| 				<npcId>33769</npcId> <!-- Brakel --> | ||||
| 				<npcCount>1</npcCount> | ||||
| 				<despawnDelay>300000</despawnDelay> | ||||
| 			</effect> | ||||
| 		</effects> | ||||
| 	</skill> | ||||
| 	<skill id="15285" toLevel="1" name="Summon Loken"> | ||||
| 		<!-- Summons Loken, the Herald from Devastated Castle. The Clan Hall Siege for the contestable Devastated Castle runs between 21:00 and 22:00 on the Friday of the Castle Siege week. Loken teleports you to the battleground, and despawns after 5 min. Cooldown is 30 min. --> | ||||
| @@ -1593,10 +1611,19 @@ | ||||
| 		<targetType>SELF</targetType> | ||||
| 		<affectScope>SINGLE</affectScope> | ||||
| 		<conditions> | ||||
| 			<condition name="OpInSiegeTime"> | ||||
| 				<time>34</time> | ||||
| 			<condition name="OpInSiege"> | ||||
| 				<residenceIds> | ||||
| 					<item>34</item> | ||||
| 				</residenceIds> | ||||
| 			</condition> | ||||
| 		</conditions> | ||||
| 		<effects> | ||||
| 			<effect name="SummonNpc"> | ||||
| 				<npcId>33771</npcId> <!-- Loken --> | ||||
| 				<npcCount>1</npcCount> | ||||
| 				<despawnDelay>300000</despawnDelay> | ||||
| 			</effect> | ||||
| 		</effects> | ||||
| 	</skill> | ||||
| 	<skill id="15286" toLevel="1" name="Blood Siphon Master"> | ||||
| 		<!-- Steals a large portion of the target's HP. --> | ||||
|   | ||||
| @@ -494,7 +494,7 @@ | ||||
| 															</xs:complexType> | ||||
| 														</xs:element> | ||||
| 														<xs:element minOccurs="0" name="isFemale" type="xs:boolean" /> | ||||
| 														<xs:element minOccurs="0" name="residencesId"> | ||||
| 														<xs:element minOccurs="0" name="residenceIds"> | ||||
| 															<xs:complexType> | ||||
| 																<xs:sequence> | ||||
| 																	<xs:element maxOccurs="unbounded" name="item" type="xs:unsignedByte" /> | ||||
|   | ||||
| @@ -22,6 +22,7 @@ import java.io.InputStream; | ||||
| import java.sql.Connection; | ||||
| import java.sql.PreparedStatement; | ||||
| import java.sql.ResultSet; | ||||
| import java.util.Collection; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
| import java.util.Properties; | ||||
| @@ -60,7 +61,7 @@ public class FortSiegeManager | ||||
| 	private int _siegeLength = 60; // Time in minute. Changeable in fortsiege.properties | ||||
| 	private int _countDownLength = 10; // Time in minute. Changeable in fortsiege.properties | ||||
| 	private int _suspiciousMerchantRespawnDelay = 180; // Time in minute. Changeable in fortsiege.properties | ||||
| 	private List<FortSiege> _sieges; | ||||
| 	private final Map<Integer, FortSiege> _sieges = new ConcurrentHashMap<>(); | ||||
| 	 | ||||
| 	protected FortSiegeManager() | ||||
| 	{ | ||||
| @@ -255,18 +256,19 @@ public class FortSiegeManager | ||||
| 		return _countDownLength; | ||||
| 	} | ||||
| 	 | ||||
| 	public List<FortSiege> getSieges() | ||||
| 	public Collection<FortSiege> getSieges() | ||||
| 	{ | ||||
| 		if (_sieges == null) | ||||
| 		{ | ||||
| 			_sieges = new CopyOnWriteArrayList<>(); | ||||
| 		} | ||||
| 		return _sieges; | ||||
| 		return _sieges.values(); | ||||
| 	} | ||||
| 	 | ||||
| 	public FortSiege getSiege(int fortId) | ||||
| 	{ | ||||
| 		return _sieges.get(fortId); | ||||
| 	} | ||||
| 	 | ||||
| 	public void addSiege(FortSiege fortSiege) | ||||
| 	{ | ||||
| 		getSieges().add(fortSiege); | ||||
| 		_sieges.put(fortSiege.getFort().getResidenceId(), fortSiege); | ||||
| 	} | ||||
| 	 | ||||
| 	public boolean isCombat(int itemId) | ||||
|   | ||||
| @@ -20,6 +20,7 @@ import java.sql.Connection; | ||||
| import java.sql.PreparedStatement; | ||||
| import java.sql.ResultSet; | ||||
| import java.util.ArrayList; | ||||
| import java.util.Collection; | ||||
| import java.util.HashMap; | ||||
| import java.util.LinkedList; | ||||
| import java.util.List; | ||||
| @@ -263,7 +264,7 @@ public class SiegeManager | ||||
| 		return _bloodAllianceReward; | ||||
| 	} | ||||
| 	 | ||||
| 	public List<Siege> getSieges() | ||||
| 	public Collection<Siege> getSieges() | ||||
| 	{ | ||||
| 		final List<Siege> sieges = new LinkedList<>(); | ||||
| 		for (Castle castle : CastleManager.getInstance().getCastles()) | ||||
| @@ -273,6 +274,18 @@ public class SiegeManager | ||||
| 		return sieges; | ||||
| 	} | ||||
| 	 | ||||
| 	public Siege getSiege(int castleId) | ||||
| 	{ | ||||
| 		for (Castle castle : CastleManager.getInstance().getCastles()) | ||||
| 		{ | ||||
| 			if (castle.getResidenceId() == castleId) | ||||
| 			{ | ||||
| 				return castle.getSiege(); | ||||
| 			} | ||||
| 		} | ||||
| 		return null; | ||||
| 	} | ||||
| 	 | ||||
| 	private void loadTrapUpgrade(int castleId) | ||||
| 	{ | ||||
| 		try (Connection con = DatabaseFactory.getConnection(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 MobiusDevelopment
					MobiusDevelopment