Jump to content
  • 0

[HELP] Extractable quest items bug


Question

Posted

hello,

Does any1 know how to change settings for quest item to open it with 100% chance ? because now i get system message - There was nothing inside and only 1 quest item out of all every time when i try to open extractable item. I have this problem almost with every quest.... reagent pounches, ancient tome of the demon ect.ect . atm im using l2jinfinity freya server pack

 

here is an example how my setup looks like for Ancient Parchment's

 

 

<item id="5944" type="EtcItem" name="Ancient Parchment">

<set name="icon" val="icon.etc_roll_of_paper_black_i00" />

<set name="default_action" val="capsule" />

<set name="immediate_effect" val="1" />

<set name="material" val="liquid" />

<set name="is_stackable" val="true" />

<set name="item_skill" val="2172-1" />

<skill id="2172" levels="1" name="Scroll of Giants">

<!--

Last Modify: 03.03.2011

Confirmed: CT2.5

Comments:

Description:

-->

<table name="#extractableItems">

5922,1,2.5;5923,1,2.5;5924,1,2.5;5925,1,2.5;5926,1,2.5;5927,1,2.5;5928,1,2.5;5929,1,2.5;5930,1,2.5;5931,1,2.5;5932,1,2.5;5933,1,2.5;5934,1,2.5;5935,1,2.5;5936,1,2.5;5937,1,2.5;5938,1,2.5;5939,1,2.5;5940,1,2.5;5941,1,2.5;5942,1,25;5943,1,25

</table>

<set name="capsuled_items_skill" val="#extractableItems" />

<set name="itemConsumeCount" val="1" />

<set name="operateType" val="OP_ACTIVE" />

<set name="skillType" val="EXTRACTABLE" />

<set name="target" val="TARGET_SELF" />

<cond msgId="129">

<and>

<player invSize="10" />

<player weight="80" />

</and>

</cond>

</skill>

 

 

thanks in advance

 

4 answers to this question

Recommended Posts

  • 0
Posted

I am pretty sure that problem is somewhere in Extractable.Java or ExtractableItems.Java but if i change something masterhandler doesnt load so maybe some1 would have a solution for it, here is my java files.

 

Extractable.Java

 

package handlers.skillhandlers;

 

import l2.universe.Config;

import l2.universe.gameserver.datatables.ItemTable;

import l2.universe.gameserver.handler.ISkillHandler;

import l2.universe.gameserver.model.L2ExtractableProductItem;

import l2.universe.gameserver.model.L2ExtractableSkill;

import l2.universe.gameserver.model.L2Object;

import l2.universe.gameserver.model.L2Skill;

import l2.universe.gameserver.model.actor.L2Character;

import l2.universe.gameserver.model.actor.instance.L2PcInstance;

import l2.universe.gameserver.network.SystemMessageId;

import l2.universe.gameserver.network.serverpackets.SystemMessage;

import l2.universe.gameserver.templates.skills.L2SkillType;

import l2.universe.util.Rnd;

 

/**

* @author Zoey76, based on previous version.

*/

public class Extractable implements ISkillHandler

{

private static final L2SkillType[] SKILL_IDS =

{

L2SkillType.EXTRACTABLE,

L2SkillType.EXTRACTABLE_FISH

};

 

public void useSkill(L2Character activeChar, L2Skill skill, L2Object[] targets)

{

if (!(activeChar instanceof L2PcInstance))

{

return;

}

 

L2ExtractableSkill exItem = skill.getExtractableSkill();

 

if (exItem == null)

{

return;

}

 

if (exItem.getProductItemsArray().length == 0)

{

_log.warning("Extractable Item Skill with no data, probably wrong/empty table with Skill Id: " + skill.getId());

return;

}

 

double rndNum = 100 * Rnd.nextDouble();

double chanceFrom = 0;

int[] createItemID = new int[20];

int[] createAmount = new int[20];

 

// calculate extraction

for (L2ExtractableProductItem expi : exItem.getProductItemsArray())

{

double chanceTo = expi.getChance();

chanceTo += chanceFrom;

if ((rndNum >= chanceFrom) && (rndNum <= chanceTo))

{

for (int i = 0; i < expi.getId().length; i++)

{

createItemID = expi.getId();

 

if (skill.getSkillType() == L2SkillType.EXTRACTABLE_FISH)

createAmount = (int) (expi.getAmmount() * Config.RATE_EXTR_FISH);

else

createAmount = expi.getAmmount();

}

break;

}

chanceFrom = chanceTo;

}

 

L2PcInstance player = (L2PcInstance) activeChar;

 

//FIXME: remove this once skill reuse will be global for main/subclass

if (player.isSubClassActive() && (skill.getReuseDelay() > 0))

{

player.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.MAIN_CLASS_SKILL_ONLY));

player.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.S1_CANNOT_BE_USED).addSkillName(skill));

return;

}

 

if ((createItemID[0] <= 0) || (createItemID.length == 0))

{

if (exItem.useMessage())

player.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.NOTHING_INSIDE_THAT));

return;

}

else

{

for (int i = 0; i < createItemID.length; i++)

{

if (createItemID <= 0)

{

continue;

}

 

if (ItemTable.getInstance().createDummyItem(createItemID) == null)

{

_log.warning("Extractable Item Skill Id:" + skill.getId() + " createItemID " + createItemID + " doesn't have a template!");

player.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.NOTHING_INSIDE_THAT));

return;

}

 

if (ItemTable.getInstance().createDummyItem(createItemID).isStackable())

{

player.addItem("Extract", createItemID, createAmount, targets[0], false);

}

else

{

for (int j = 0; j < createAmount; j++)

{

player.addItem("Extract", createItemID, 1, targets[0], false);

}

}

 

if (createItemID == 57)

{

SystemMessage sm = SystemMessage.getSystemMessage(SystemMessageId.EARNED_S1_ADENA);;

sm.addNumber(createAmount);

player.sendPacket(sm);

}

else

{

SystemMessage sm = SystemMessage.getSystemMessage(SystemMessageId.EARNED_S2_S1_S);;

sm.addItemName(createItemID);

if (createAmount > 1)

{

sm.addNumber(createAmount);

}

player.sendPacket(sm);

}

}

}

}

 

public L2SkillType[] getSkillIds()

{

return SKILL_IDS;

}

}

 

ExtractableItems.Java

 

package handlers.itemhandlers;

 

import java.util.List;

import java.util.logging.Logger;

 

import l2.universe.Config;

import l2.universe.gameserver.datatables.ItemTable;

import l2.universe.gameserver.handler.IItemHandler;

import l2.universe.gameserver.model.L2ExtractableProduct;

import l2.universe.gameserver.model.L2ItemInstance;

import l2.universe.gameserver.model.actor.L2Playable;

import l2.universe.gameserver.model.actor.instance.L2PcInstance;

import l2.universe.gameserver.network.SystemMessageId;

import l2.universe.gameserver.network.serverpackets.SystemMessage;

import l2.universe.gameserver.templates.item.L2EtcItem;

import l2.universe.util.Rnd;

 

 

/**

*

* @author FBIagent 11/12/2006

*

*/

 

public class ExtractableItems implements IItemHandler

{

private static Logger _log = Logger.getLogger(ItemTable.class.getName());

 

public void useItem(L2Playable playable, L2ItemInstance item, boolean forceUse)

{

if (!(playable instanceof L2PcInstance))

return;

 

L2PcInstance activeChar = (L2PcInstance) playable;

 

int itemID = item.getItemId();

L2EtcItem etcitem = (L2EtcItem) item.getItem();

List<L2ExtractableProduct> exitem = etcitem.getExtractableItems();

 

if (exitem == null)

{

_log.info("No extractable data defined for "+etcitem);

return;

}

 

//destroy item

if (!activeChar.destroyItem("Extract", item.getObjectId(), 1, activeChar, true))

return;

 

boolean created= false;

 

// calculate extraction

for (L2ExtractableProduct expi : exitem)

{

if (Rnd.get(100) <= expi.getChance())

{

int min = expi.getMin();

int max = expi.getMax();

int createItemID = expi.getId();

 

if ((itemID >= 6411 && itemID <= 6518) || (itemID >= 7726 && itemID <= 7860) || (itemID >= 8403 && itemID <= 8483))

{

min *= Config.RATE_EXTR_FISH;

max *= Config.RATE_EXTR_FISH;

}

 

int createitemAmount = 0;

if (max == min)

createitemAmount = min;

else

createitemAmount = Rnd.get(max-min+1) + min;

activeChar.addItem("Extract", createItemID, createitemAmount, activeChar, true);

created = true;

}

}

 

if (!created)

{

activeChar.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.NOTHING_INSIDE_THAT));

}

}

}

 

 

 

  • 0
Posted

so many devs and no1 have a clue about this ? :D

 

This is like the last file ppl have to touch/touch, so don't expect too much. Plus you use a fork of L2J, and they have perhaps modify something.

 

As you said yourself, if (Rnd.get(100) <= expi.getChance()) is the place where the check is made.

 

L2ExtractableProduct is supposed to give the good chance, according to the item registered. So except if the code is (really) messed, which should make something "tilt" in your brain (like : change of fork), it's a datapack problem.

 

It takes in consideration you search in the good place too, lol.

 

I would like to give more infos, but for the moment, I didn't update my pack with that and didn't bother about to know "what's going on".

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • Yeah, for sure. Hardly anyone doesn't use it yet, but those few are gonna give in soon. I'm not judging anyone who uses it – that's not the point. The point is that people do use it. I use it, you use it, we all use it. These days, it's just NORMAL. And it's gonna keep getting more and more normal. But like I said, you still gotta know what you're actually doing.
    • Then that's the problem. Server owners are as bad as they used to be in 2005, 2010 and so on.    This scene has technically mature developers, always money-hungry server owners, but what both these groups lack, is some creativity ... I would never play in a server that needs 7 layers of anti-bot. If it needs 7 layers of anti-bot, it means its a bot friendly server and not something worth playing. 
    • Lineage just has a giga boring quest line / lore and since server owners are not reinventing the wheel, players are forced to F1 F2 spam by server design.
    • Players say: We don't have time, please add auto-farm to the server, after all, farming in L2 is the most repetitive and boring thing, it gives no enjoyment.    Then players say: OMG your server is full of auto-farmers with adrenaline. Use anti-cheat guards.    Excluding the hilarious fact that an auto-farm player is essentiall botting without botting software ...   Noone stops to ask the simple question: If nobody likes farming to that extend that they go as far as building complex bots and ask for server-side bot programs and then for no apparent reason have to build anti-bot guards ... MAYBE the problem is that "farming" is an outdated feature that has to be removed from your servers ?   What you people are building here is software that protects a game feature, nobody likes and nobody wants to use.   Has the mental capacity of server owners and developers fallen so many IQ points the last decade ? One comes back to see the same server setups of a decade ago, with zero innovation, zero creativity and a huge amount of time and resources protecting a game feature nobody wants to even use ... The other dissappointing thing one sees here, is that a lot of GREAT developers who now work full time jobs in corporate, come back here, to bash the work of others because they find their current job tasks not as fullfilling as when they would develope game related code for Lineage 2...   Talking about life choices eh ? 😛
    • Have u seen the message i sent you?
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..