Sync with L2jServer HighFive Mar 1st 2015.
This commit is contained in:
@@ -52,25 +52,21 @@ public final class Detection extends AbstractEffect
|
||||
|
||||
final L2PcInstance player = info.getEffector().getActingPlayer();
|
||||
final L2PcInstance target = info.getEffected().getActingPlayer();
|
||||
final boolean hasParty = player.isInParty();
|
||||
final boolean hasClan = player.getClanId() > 0;
|
||||
final boolean hasAlly = player.getAllyId() > 0;
|
||||
|
||||
if (target.isInvisible())
|
||||
{
|
||||
if (hasParty && (target.isInParty()) && (player.getParty().getLeaderObjectId() == target.getParty().getLeaderObjectId()))
|
||||
if (player.isInPartyWith(target))
|
||||
{
|
||||
return;
|
||||
}
|
||||
else if (hasClan && (player.getClanId() == target.getClanId()))
|
||||
if (player.isInClanWith(target))
|
||||
{
|
||||
return;
|
||||
}
|
||||
else if (hasAlly && (player.getAllyId() == target.getAllyId()))
|
||||
if (player.isInAllyWith(target))
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
// Remove Hide.
|
||||
target.getEffectList().stopSkillEffects(true, AbnormalType.HIDE);
|
||||
}
|
||||
|
@@ -58,7 +58,7 @@ public final class HeadquarterCreate extends AbstractEffect
|
||||
public void onStart(BuffInfo info)
|
||||
{
|
||||
final L2PcInstance player = info.getEffector().getActingPlayer();
|
||||
if ((player.getClan() == null) || (player.getClan().getLeaderId() != player.getObjectId()))
|
||||
if (!player.isClanLeader())
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
107
trunk/dist/game/data/scripts/handlers/effecthandlers/MaxCp.java
vendored
Normal file
107
trunk/dist/game/data/scripts/handlers/effecthandlers/MaxCp.java
vendored
Normal file
@@ -0,0 +1,107 @@
|
||||
/*
|
||||
* Copyright (C) 2004-2015 L2J DataPack
|
||||
*
|
||||
* This file is part of L2J DataPack.
|
||||
*
|
||||
* L2J DataPack 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.
|
||||
*
|
||||
* L2J DataPack 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.effecthandlers;
|
||||
|
||||
import com.l2jserver.gameserver.enums.EffectCalculationType;
|
||||
import com.l2jserver.gameserver.model.StatsSet;
|
||||
import com.l2jserver.gameserver.model.actor.stat.CharStat;
|
||||
import com.l2jserver.gameserver.model.conditions.Condition;
|
||||
import com.l2jserver.gameserver.model.effects.AbstractEffect;
|
||||
import com.l2jserver.gameserver.model.skills.BuffInfo;
|
||||
import com.l2jserver.gameserver.model.stats.Stats;
|
||||
import com.l2jserver.gameserver.model.stats.functions.FuncAdd;
|
||||
import com.l2jserver.gameserver.model.stats.functions.FuncMul;
|
||||
|
||||
/**
|
||||
* @author Zealar
|
||||
*/
|
||||
public final class MaxCp extends AbstractEffect
|
||||
{
|
||||
private final double _power;
|
||||
private final EffectCalculationType _type;
|
||||
private final boolean _heal;
|
||||
|
||||
public MaxCp(Condition attachCond, Condition applyCond, StatsSet set, StatsSet params)
|
||||
{
|
||||
super(attachCond, applyCond, set, params);
|
||||
|
||||
_type = params.getEnum("type", EffectCalculationType.class, EffectCalculationType.DIFF);
|
||||
switch (_type)
|
||||
{
|
||||
case DIFF:
|
||||
{
|
||||
_power = params.getInt("power", 0);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
_power = 1 + (params.getInt("power", 0) / 100.0);
|
||||
}
|
||||
}
|
||||
_heal = params.getBoolean("heal", false);
|
||||
|
||||
if (params.isEmpty())
|
||||
{
|
||||
_log.warning(getClass().getSimpleName() + ": must have parameters.");
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStart(BuffInfo info)
|
||||
{
|
||||
final CharStat charStat = info.getEffected().getStat();
|
||||
|
||||
synchronized (charStat)
|
||||
{
|
||||
final double currentCp = info.getEffected().getCurrentCp();
|
||||
switch (_type)
|
||||
{
|
||||
case DIFF:
|
||||
{
|
||||
charStat.getActiveChar().addStatFunc(new FuncAdd(Stats.MAX_CP, 1, this, _power, null));
|
||||
if (_heal)
|
||||
{
|
||||
info.getEffected().setCurrentCp((currentCp + _power));
|
||||
}
|
||||
break;
|
||||
}
|
||||
case PER:
|
||||
{
|
||||
charStat.getActiveChar().addStatFunc(new FuncMul(Stats.MAX_CP, 1, this, _power, null));
|
||||
if (_heal)
|
||||
{
|
||||
info.getEffected().setCurrentCp((currentCp * _power));
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onExit(BuffInfo info)
|
||||
{
|
||||
final CharStat charStat = info.getEffected().getStat();
|
||||
synchronized (charStat)
|
||||
{
|
||||
charStat.getActiveChar().removeStatsOwner(this);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
108
trunk/dist/game/data/scripts/handlers/effecthandlers/MaxHp.java
vendored
Normal file
108
trunk/dist/game/data/scripts/handlers/effecthandlers/MaxHp.java
vendored
Normal file
@@ -0,0 +1,108 @@
|
||||
/*
|
||||
* Copyright (C) 2004-2015 L2J DataPack
|
||||
*
|
||||
* This file is part of L2J DataPack.
|
||||
*
|
||||
* L2J DataPack 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.
|
||||
*
|
||||
* L2J DataPack 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.effecthandlers;
|
||||
|
||||
import com.l2jserver.gameserver.enums.EffectCalculationType;
|
||||
import com.l2jserver.gameserver.model.StatsSet;
|
||||
import com.l2jserver.gameserver.model.actor.stat.CharStat;
|
||||
import com.l2jserver.gameserver.model.conditions.Condition;
|
||||
import com.l2jserver.gameserver.model.effects.AbstractEffect;
|
||||
import com.l2jserver.gameserver.model.skills.BuffInfo;
|
||||
import com.l2jserver.gameserver.model.stats.Stats;
|
||||
import com.l2jserver.gameserver.model.stats.functions.FuncAdd;
|
||||
import com.l2jserver.gameserver.model.stats.functions.FuncMul;
|
||||
|
||||
/**
|
||||
* @author Zealar
|
||||
*/
|
||||
public final class MaxHp extends AbstractEffect
|
||||
{
|
||||
private final double _power;
|
||||
private final EffectCalculationType _type;
|
||||
private final boolean _heal;
|
||||
|
||||
public MaxHp(Condition attachCond, Condition applyCond, StatsSet set, StatsSet params)
|
||||
{
|
||||
super(attachCond, applyCond, set, params);
|
||||
|
||||
_type = params.getEnum("type", EffectCalculationType.class, EffectCalculationType.DIFF);
|
||||
switch (_type)
|
||||
{
|
||||
case DIFF:
|
||||
{
|
||||
_power = params.getInt("power", 0);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
_power = 1 + (params.getInt("power", 0) / 100.0);
|
||||
}
|
||||
}
|
||||
_heal = params.getBoolean("heal", false);
|
||||
|
||||
if (params.isEmpty())
|
||||
{
|
||||
_log.warning(getClass().getSimpleName() + ": must have parameters.");
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStart(BuffInfo info)
|
||||
{
|
||||
final CharStat charStat = info.getEffected().getStat();
|
||||
|
||||
synchronized (charStat)
|
||||
{
|
||||
final double currentHp = info.getEffected().getCurrentHp();
|
||||
switch (_type)
|
||||
{
|
||||
case DIFF:
|
||||
{
|
||||
charStat.getActiveChar().addStatFunc(new FuncAdd(Stats.MAX_HP, 1, this, _power, null));
|
||||
if (_heal)
|
||||
{
|
||||
info.getEffected().setCurrentHp((currentHp + _power));
|
||||
}
|
||||
break;
|
||||
}
|
||||
case PER:
|
||||
{
|
||||
charStat.getActiveChar().addStatFunc(new FuncMul(Stats.MAX_HP, 1, this, _power, null));
|
||||
if (_heal)
|
||||
{
|
||||
info.getEffected().setCurrentHp((currentHp * _power));
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onExit(BuffInfo info)
|
||||
{
|
||||
final CharStat charStat = info.getEffected().getStat();
|
||||
synchronized (charStat)
|
||||
{
|
||||
charStat.getActiveChar().removeStatsOwner(this);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user