Jump to content
  • 0

Question

Posted (edited)

If i have the complete set equiped...there are some stats

If i unequip a amor part and equip again,my stats are increased.Its like its not reading the armorset skill only if i unequip and equip again.

 

edit: lowered the skill id to 8200 and still the same

edit 2: disabled "Check skills on enter" and now it works,but i dont like the ideea of disabling that.

 

Skills for sets:

	<skill id="9999" levels="1" name="Poseidon Robe Set">
<!--
  Description(s):
      Decreases magic cancel rate and increases resistance to paralysis attacks. P. Def., Casting Spd. and Speed are also increased. WIT+2, MEN-2
-->
  <set name="target" val="TARGET_SELF"/>
  <set name="skillType" val="BUFF"/>
  <set name="operateType" val="OP_PASSIVE"/>
  <set name="castRange" val="-1"/>
  <set name="effectRange" val="-1"/>
  <for>
    <mul order="0x30" stat="pDef" val="1.40"/> <!-- P. Def. +20% -->
    <mul order="0x30" stat="mAtkSpd" val="1.15"/> <!-- Casting Spd. +15% -->
    <add order="0x40" stat="runSpd" val="7"/> <!-- Speed +7 -->
    <sub order="0x40" stat="cancel" val="18"/> <!-- Small decrease in chance of spell interruption - TO CHECK -->
    <mul order="0x30" stat="paralyzeVuln" val="0.5"/> <!-- Paralysis Resistance +50% -->
    <add order="0x40" stat="WIT" val="2"/> <!-- WIT +2 -->
    <sub order="0x40" stat="MEN" val="2"/> <!-- MEN -2 -->
  </for>
</skill>
<skill id="9998" levels="1" name="Poseidon Light Armor Set">
<!--
  Description(s):
      Increases MaxHP, Atk. Spd, P. Atk, and maximum weight limit. DEX+1, STR+1, CON-2
-->
  <set name="target" val="TARGET_SELF"/>
  <set name="skillType" val="BUFF"/>
  <set name="operateType" val="OP_PASSIVE"/>
  <set name="castRange" val="-1"/>
  <set name="effectRange" val="-1"/>
  <for>
    <mul order="0x30" stat="pAtkSpd" val="1.04"/> <!-- Attack Speed +4% -->
	<mul order="0x30" stat="pDef" val="1.30"/> <!-- P.Def +30% -->
    <mul order="0x30" stat="pAtk" val="1.04"/> <!-- P. Atk +4% -->
    <add order="0x40" stat="maxMp" val="289"/> <!-- Maximum MP +289 -->
    <add order="0x40" stat="maxLoad" val="5759"/> <!-- Weight Limit +5759 -->
	<add order="0x40" stat="accCombat" val="10" /> <!-- Accuracy +1 -->
	
    <add order="0x40" stat="DEX" val="1"/> <!-- DEX +1 -->
    <add order="0x40" stat="STR" val="1"/> <!-- STR +1 -->
    <sub order="0x40" stat="CON" val="2"/> <!-- CON -2 -->
  </for>
</skill>
<skill id="9997" levels="1" name="Poseidon Heavy Armor Set">
<!--
  Description(s):
      Increases MaxHP, P. Def and resistance to sleep/hold attacks. STR+2, DEX-2
-->
  <set name="target" val="TARGET_SELF"/>
  <set name="skillType" val="BUFF"/>
  <set name="operateType" val="OP_PASSIVE"/>
  <set name="castRange" val="-1"/>
  <set name="effectRange" val="-1"/>
  <for>
    <mul order="0x30" stat="pDef" val="1.40"/> <!-- P Def. +8% -->
    <add order="0x40" stat="maxHp" val="445"/> <!-- Maximum HP +445 -->
		<add order="0x40" stat="accCombat" val="10" /> <!-- Accuracy +1 -->
    <mul order="0x30" stat="sleepVuln" val="0.3"/> <!-- Sleep Probability -70% -->
    <mul order="0x30" stat="rootVuln" val="0.3"/> <!-- Hold Probability -70% -->
    <sub order="0x40" stat="DEX" val="2"/> <!-- DEX -2 -->
    <add order="0x40" stat="STR" val="2"/> <!-- STR +2 -->
  </for>
</skill>

 

DB photo:

armorsets.png

Edited by KIDutz

3 answers to this question

Recommended Posts

  • 0
Posted
5 hours ago, KIDutz said:

 

I had this problem too .

Its caused by this config:

gameserver\config\protected\other.properties

CheckSkillsOnEnter = True

If you have it False you will have no problem. If you change it to True for extra protections the server detects the armor passives and doesn't allow them only with re-equip .

Go here and exclude all the armor passives and you will be fine:

gameserver\config\functions\l2jfrozen.properties

AllowedSkills = your ids

  • Thanks 1
  • 0
Posted

Off-topic: what a stupid config.. Good luck adding all armor skill id's just to make things work as it should :happyforever:

I would simply turn off that config. There is no reason to keep it enabled. I doubt there are holes in code to bug and get some skills. Even if there are, it's not stopping anyone to make the bug again after the relog. So yeah, such a useless config.

  • 0
Posted
16 hours ago, SweeTs said:

Off-topic: what a stupid config.. Good luck adding all armor skill id's just to make things work as it should :happyforever:

I would simply turn off that config. There is no reason to keep it enabled. I doubt there are holes in code to bug and get some skills. Even if there are, it's not stopping anyone to make the bug again after the relog. So yeah, such a useless config.

Yea its a really stupid config.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • Verify if following is supposed to be the way to handle movement npc.getAI().setIntention(CtrlIntention.AI_INTENTION_MOVE_TO, new Location(point.getX(), point.getY(), point.getZ())); For me, it's not enough. And if it's the case, whole AI system is probably buggy.
    • hello, i want to wtt my charracter in l2elmorelab 1x harbor for 1.5kkk adena in l2reborn 10x new. Or if you interested tell me your offer. :)) Clean Mail 30 lvl Cleric Naked   Updated.
    • package ai.npc.NFWalker; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Random; import l2r.gameserver.enums.CtrlIntention; import l2r.gameserver.model.Location; import l2r.gameserver.model.actor.L2Npc; import l2r.gameserver.model.quest.Quest; import l2r.gameserver.network.clientpackets.Say2; import l2r.gameserver.network.serverpackets.NpcSay; public class NFWalkerAI extends Quest { private static final int WALKER_NPC_ID = 20116; private final Map<String, Route> routes = new HashMap<>(); private final Map<Integer, Integer> npcIndexes = new HashMap<>(); private final Map<Integer, Boolean> npcReverse = new HashMap<>(); private final Map<Integer, String> npcCurrentRoute = new HashMap<>(); public NFWalkerAI() { super(-1, NFWalkerAI.class.getSimpleName(), "ai/npc/NFWalker"); loadRoutes(); addSpawnId(WALKER_NPC_ID); } private void loadRoutes() { // Route 1 Data Route route1 = new Route("route1"); route1.addPoint(new RoutePoint(0, 149363, 172341, -941, 0, false, "")); route1.addPoint(new RoutePoint(1, 148568, 172328, -980, 5, true, "Puff")); route1.addPoint(new RoutePoint(2, 148536, 172792, -980, 0, false, "")); // Route 2 Data Route route2 = new Route("route2"); route2.addPoint(new RoutePoint(0, 149363, 172341, -941, 0, false, "")); route2.addPoint(new RoutePoint(1, 150248, 172328, -980, 5, true, "Rise my children! Bring me the servants of the god! Let them be offered to our god Bifrons!")); route2.addPoint(new RoutePoint(2, 150248, 172776, -980, 0, false, "")); // Add routes to the map routes.put("route1", route1); routes.put("route2", route2); } @Override public String onSpawn(L2Npc npc) { if (npc.getId() == WALKER_NPC_ID) { selectInitialRouteForNpc(npc); } return super.onSpawn(npc); } @Override public String onAdvEvent(String event, L2Npc npc, l2r.gameserver.model.actor.instance.L2PcInstance player) { if (event.equalsIgnoreCase("move")) { moveNpc(npc); } else if (event.equalsIgnoreCase("check_reached")) { checkIfReached(npc); } return null; } private void moveNpc(L2Npc npc) { String routeName = npcCurrentRoute.get(npc.getObjectId()); Route route = routes.get(routeName); Integer pointIndex = npcIndexes.get(npc.getObjectId()); if (route != null && pointIndex != null) { RoutePoint point = route.getPoints().get(pointIndex); if (point.isRun()) { npc.setRunning(); } else { npc.setWalking(); } if (!point.getChat().isEmpty()) { npc.broadcastPacket(new NpcSay(npc.getObjectId(), Say2.NPC_ALL, npc.getId(), point.getChat())); } npc.getAI().setIntention(CtrlIntention.AI_INTENTION_MOVE_TO, new Location(point.getX(), point.getY(), point.getZ())); // Log movement intention System.out.println("NPC " + npc.getObjectId() + " moving to " + point.getX() + ", " + point.getY() + ", " + point.getZ()); // Schedule a check to see if the NPC has reached its destination startQuestTimer("check_reached", 1000, npc, null); } } private void checkIfReached(L2Npc npc) { String routeName = npcCurrentRoute.get(npc.getObjectId()); Route route = routes.get(routeName); Integer pointIndex = npcIndexes.get(npc.getObjectId()); if (route != null && pointIndex != null) { RoutePoint point = route.getPoints().get(pointIndex); Location currentLocation = npc.getLocation(); Location targetLocation = new Location(point.getX(), point.getY(), point.getZ()); // Check if the NPC has reached the target location if (currentLocation.equals(targetLocation)) { // Log that the NPC has reached the target System.out.println("NPC " + npc.getObjectId() + " reached target " + targetLocation); // Schedule the next movement startQuestTimer("move", point.getDelay() * 1000, npc, null); if (!npcReverse.get(npc.getObjectId())) { pointIndex++; if (pointIndex >= route.getPoints().size()) { npcReverse.put(npc.getObjectId(), true); pointIndex = route.getPoints().size() - 1; } } else { pointIndex--; if (pointIndex < 0) { npcReverse.put(npc.getObjectId(), false); pointIndex = 0; // Choose a new route after completing the current one in both directions switchRouteForNpc(npc); return; } } npcIndexes.put(npc.getObjectId(), pointIndex); } else { // Check again after 1 second startQuestTimer("check_reached", 1000, npc, null); } } } private void selectInitialRouteForNpc(L2Npc npc) { // Randomly select either route1 or route2 String selectedRouteName = "route" + (new Random().nextInt(2) + 1); npcCurrentRoute.put(npc.getObjectId(), selectedRouteName); npcIndexes.put(npc.getObjectId(), 0); npcReverse.put(npc.getObjectId(), false); startQuestTimer("move", 5000, npc, null); // Log initial route selection System.out.println("NPC " + npc.getObjectId() + " selected initial route " + selectedRouteName); } private void switchRouteForNpc(L2Npc npc) { String currentRoute = npcCurrentRoute.get(npc.getObjectId()); String newRoute = currentRoute.equals("route1") ? "route2" : "route1"; npcCurrentRoute.put(npc.getObjectId(), newRoute); npcIndexes.put(npc.getObjectId(), 0); npcReverse.put(npc.getObjectId(), false); startQuestTimer("move", 5000, npc, null); // Log route switching System.out.println("NPC " + npc.getObjectId() + " switched to route " + newRoute); } private static class Route { private List<RoutePoint> points = new ArrayList<>(); public Route(String name) { } public void addPoint(RoutePoint point) { points.add(point); } public List<RoutePoint> getPoints() { return points; } } private static class RoutePoint { private int id; private int x, y, z, delay; private boolean run; private String chat; public RoutePoint(int id, int x, int y, int z, int delay, boolean run, String chat) { this.id = id; this.x = x; this.y = y; this.z = z; this.delay = delay; this.run = run; this.chat = chat; } public int getId() { return id; } public int getX() { return x; } public int getY() { return y; } public int getZ() { return z; } public int getDelay() { return delay; } public boolean isRun() { return run; } public String getChat() { return chat; } } } I looking for help, with this, the npc not start to move. Im trying to create, an NPC wich have multiple walk routes basic logic is  random pick a route complite the route  like Route 1 start form zero (0 -> 1 -> 2(or more) -> 1 -> 0) When the npc return to 0, the script should pic the other route and start again.  And if there is a message like point 1 here     "route1.addPoint(new RoutePoint(1, 148568, 172328, -980, 5, true, "Puff"));" The npc should display the chat message. Currently my problem is the npc not moving, but if I manage it to start moving its randomly move between the route 1 and 2 set of coordinates. Currently for me its  a nightmare. I hope anyone can help somhow.
  • Topics

×
×
  • Create New...