Jump to content
  • 0

Community Button Adquire Skills


Question

Posted (edited)

Hi people!. I have created a button on my communityboard that show available skills to learn but with this code when SkillsList Opens and i try to click on that windows it closes.

 

 

public void showSkillsList(L2PcInstance player)
	{
		
		// Normal skills, No LearnedByFS, no AutoGet skills.
		final List<L2SkillLearn> skills = SkillTreesData.getInstance().getAvailableSkills(player, player.getClassId(), false, false);
		final AcquireSkillList asl = new AcquireSkillList(AcquireSkillType.CLASS);
		int count = 0;
		player.setLearningClass(player.getClassId());
		for (L2SkillLearn s : skills)
		{
			if (SkillData.getInstance().getInfo(s.getSkillId(), s.getSkillLevel()) != null)
			{
				asl.addSkill(s.getSkillId(), s.getSkillLevel(), s.getSkillLevel(), s.getCalculatedLevelUpSp(player.getClassId(), player.getClassId()), 0);
				count++;
			}
		}
		
		if (count == 0)
		{
			final Map<Integer, L2SkillLearn> skillTree = SkillTreesData.getInstance().getCompleteClassSkillTree(player.getClassId());
			final int minLevel = SkillTreesData.getInstance().getMinLevelForNewSkill(player, skillTree);
			if (minLevel > 0)
			{
				SystemMessage sm = SystemMessage.getSystemMessage(SystemMessageId.DO_NOT_HAVE_FURTHER_SKILLS_TO_LEARN_S1);
				sm.addInt(minLevel);
				player.sendPacket(sm);
			}
			else
			{
				if (player.getClassId().level() == 1)
				{
					SystemMessage sm = SystemMessage.getSystemMessage(SystemMessageId.NO_SKILLS_TO_LEARN_RETURN_AFTER_S1_CLASS_CHANGE);
					sm.addInt(2);
					player.sendPacket(sm);
				}
				else
				{
					player.sendPacket(SystemMessageId.NO_MORE_SKILLS_TO_LEARN);
				}
			}
		}
		else
		{
			player.sendPacket(asl);
		}
	}

 

 

Do you know if there ir a solution for that problem?.

 

 

Edited by Vision

9 answers to this question

Recommended Posts

  • 0
Posted
4 hours ago, LoVe+ said:
AcquireSkillList.java

show this file

 

 

public final class AcquireSkillList extends L2GameServerPacket
{
	private final List<Skill> _skills;
	private final AcquireSkillType _skillType;
	
	/**
	 * Private class containing learning skill information.
	 */
	private static class Skill
	{
		public int id;
		public int nextLevel;
		public int maxLevel;
		public int spCost;
		public int requirements;
		
		public Skill(int pId, int pNextLevel, int pMaxLevel, int pSpCost, int pRequirements)
		{
			id = pId;
			nextLevel = pNextLevel;
			maxLevel = pMaxLevel;
			spCost = pSpCost;
			requirements = pRequirements;
		}
	}
	
	public AcquireSkillList(AcquireSkillType type)
	{
		_skillType = type;
		_skills = new ArrayList<>();
	}
	
	public void addSkill(int id, int nextLevel, int maxLevel, int spCost, int requirements)
	{
		_skills.add(new Skill(id, nextLevel, maxLevel, spCost, requirements));
	}
	
	@Override
	protected void writeImpl()
	{
		if (_skills.isEmpty())
		{
			return;
		}
		
		writeC(0x90);
		writeD(_skillType.ordinal());
		writeD(_skills.size());
		
		for (Skill temp : _skills)
		{
			writeD(temp.id);
			writeD(temp.nextLevel);
			writeD(temp.maxLevel);
			writeD(temp.spCost);
			writeD(temp.requirements);
			if (_skillType == AcquireSkillType.SUBPLEDGE)
			{
				writeD(0); // TODO: ?
			}
		}
	}
}

 

  • 0
Posted

your condition is in this file: RequestAcquireSkill.java

 

package net.sf.l2j.gameserver.network.clientpackets;

import net.sf.l2j.Config;
import net.sf.l2j.gameserver.datatables.SkillTable;
import net.sf.l2j.gameserver.datatables.SkillTreeTable;
import net.sf.l2j.gameserver.datatables.SpellbookTable;
import net.sf.l2j.gameserver.model.L2PledgeSkillLearn;
import net.sf.l2j.gameserver.model.L2ShortCut;
import net.sf.l2j.gameserver.model.L2Skill;
import net.sf.l2j.gameserver.model.L2SkillLearn;
import net.sf.l2j.gameserver.model.actor.Npc;
import net.sf.l2j.gameserver.model.actor.instance.Fisherman;
import net.sf.l2j.gameserver.model.actor.instance.Folk;
import net.sf.l2j.gameserver.model.actor.instance.Player;
import net.sf.l2j.gameserver.model.actor.instance.VillageMaster;
import net.sf.l2j.gameserver.network.SystemMessageId;
import net.sf.l2j.gameserver.network.serverpackets.ExStorageMaxCount;
import net.sf.l2j.gameserver.network.serverpackets.ShortCutRegister;
import net.sf.l2j.gameserver.network.serverpackets.SystemMessage;

public class RequestAcquireSkill extends L2GameClientPacket
{
    private int _skillId;
    private int _skillLevel;
    private int _skillType;
    
    @Override
    protected void readImpl()
    {
        _skillId = readD();
        _skillLevel = readD();
        _skillType = readD();
    }
    
    @Override
    protected void runImpl()
    {
        // Not valid skill data, return.
        if (_skillId <= 0 || _skillLevel <= 0)
            return;
        
        // Incorrect player, return.
        final Player activeChar = getClient().getActiveChar();
        if (activeChar == null)
            return;
        
        // Incorrect npc, return.
        final Npc trainer = activeChar.getCurrentFolkNPC();
        if (trainer == null)
            return;
        
        // Distance check for player <-> npc.
        if (!activeChar.isInsideRadius(trainer, Npc.INTERACTION_DISTANCE, false, false) && !activeChar.isGM())
            return;
        
        // Skill doesn't exist, return.
        final L2Skill skill = SkillTable.getInstance().getInfo(_skillId, _skillLevel);
        if (skill == null)
            return;
        

        // Set learn class.
        activeChar.setSkillLearningClassId(activeChar.getClassId());
        
        boolean exists = false;
        
        // Types.
        switch (_skillType)
        {
            case 0: // General skills.
                // Player already has such skill with same or higher level.
                int skillLvl = activeChar.getSkillLevel(_skillId);
                if (skillLvl >= _skillLevel)
                    return;
                
                // Requested skill must be 1 level higher than existing skill.
                if (Math.max(skillLvl, 0) + 1 != _skillLevel)
                    return;
                
                int spCost = 0;
                
                // Find skill information.
                for (L2SkillLearn sl : SkillTreeTable.getInstance().getAvailableSkills(activeChar, activeChar.getSkillLearningClassId()))
                {
                    // Skill found.
                    if (sl.getId() == _skillId && sl.getLevel() == _skillLevel)
                    {
                        exists = true;
                        spCost = sl.getSpCost();
                        break;
                    }
                }
                
                // No skill found, return.
                if (!exists)
                    return;
                
                // Not enought SP.
                if (activeChar.getSp() < spCost)
                {
                    activeChar.sendPacket(SystemMessageId.NOT_ENOUGH_SP_TO_LEARN_SKILL);
                    Folk.showSkillList(activeChar, trainer, activeChar.getSkillLearningClassId());
                    return;
                }
                
                // Get spellbook and try to consume it.
                int spbId = SpellbookTable.getInstance().getBookForSkill(_skillId, _skillLevel);
                if (spbId > 0)
                {
                    if (!activeChar.destroyItemByItemId("SkillLearn", spbId, 1, trainer, true))
                    {
                        activeChar.sendPacket(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL);
                        Folk.showSkillList(activeChar, trainer, activeChar.getSkillLearningClassId());
                        return;
                    }
                }
                
                // Consume SP.
                activeChar.removeExpAndSp(0, spCost);
                
                // Add skill new skill.
                activeChar.addSkill(skill, true);
                activeChar.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.LEARNED_SKILL_S1).addSkillName(skill));
                
                // Update player and return.
                updateShortCuts(activeChar);
                activeChar.sendSkillList();
                Folk.showSkillList(activeChar, trainer, activeChar.getSkillLearningClassId());
                break;
            
            case 1: // Common skills.
                skillLvl = activeChar.getSkillLevel(_skillId);
                if (skillLvl >= _skillLevel)
                    return;
                
                if (Math.max(skillLvl, 0) + 1 != _skillLevel)
                    return;
                
                int costId = 0;
                int costCount = 0;
                
                for (L2SkillLearn sl : SkillTreeTable.getInstance().getAvailableFishingDwarvenCraftSkills(activeChar))
                {
                    if (sl.getId() == _skillId && sl.getLevel() == _skillLevel)
                    {
                        exists = true;
                        costId = sl.getIdCost();
                        costCount = sl.getCostCount();
                        break;
                    }
                }
                
                if (!exists)
                    return;
                
                if (!activeChar.destroyItemByItemId("Consume", costId, costCount, trainer, true))
                {
                    activeChar.sendPacket(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL);
                    Fisherman.showFishSkillList(activeChar);
                    return;
                }
                
                activeChar.addSkill(skill, true);
                activeChar.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.LEARNED_SKILL_S1).addSkillName(skill));
                
                if (_skillId >= 1368 && _skillId <= 1372)
                    activeChar.sendPacket(new ExStorageMaxCount(activeChar));
                
                updateShortCuts(activeChar);
                activeChar.sendSkillList();
                Fisherman.showFishSkillList(activeChar);
                break;
            
            case 2: // Pledge skills.
                if (!activeChar.isClanLeader())
                    return;
                
                int itemId = 0;
                int repCost = 0;
                
                for (L2PledgeSkillLearn psl : SkillTreeTable.getInstance().getAvailablePledgeSkills(activeChar))
                {
                    if (psl.getId() == _skillId && psl.getLevel() == _skillLevel)
                    {
                        exists = true;
                        itemId = psl.getItemId();
                        repCost = psl.getRepCost();
                        break;
                    }
                }
                
                if (!exists)
                    return;
                
                if (activeChar.getClan().getReputationScore() < repCost)
                {
                    activeChar.sendPacket(SystemMessageId.ACQUIRE_SKILL_FAILED_BAD_CLAN_REP_SCORE);
                    VillageMaster.showPledgeSkillList(activeChar);
                    return;
                }
                
                if (Config.LIFE_CRYSTAL_NEEDED)
                {
                    if (!activeChar.destroyItemByItemId("Consume", itemId, 1, trainer, true))
                    {
                        activeChar.sendPacket(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL);
                        VillageMaster.showPledgeSkillList(activeChar);
                        return;
                    }
                }
                
                activeChar.getClan().takeReputationScore(repCost);
                activeChar.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.S1_DEDUCTED_FROM_CLAN_REP).addNumber(repCost));
                
                activeChar.getClan().addNewSkill(skill);
                
                VillageMaster.showPledgeSkillList(activeChar);
                return;
        }
    }
    
    private void updateShortCuts(Player player)
    {
        if (_skillLevel > 1)
        {
            for (L2ShortCut sc : player.getAllShortCuts())
            {
                if (sc.getId() == _skillId && sc.getType() == L2ShortCut.TYPE_SKILL)
                {
                    L2ShortCut newsc = new L2ShortCut(sc.getSlot(), sc.getPage(), L2ShortCut.TYPE_SKILL, _skillId, _skillLevel, 1);
                    player.sendPacket(new ShortCutRegister(newsc));
                    player.registerShortCut(newsc);
                }
            }
        }
    }
}

  • 0
Posted (edited)

The code is'ts equals or like that. but this parts is missing and i added.

 

   // Distance check for player <-> npc.
        if (!activeChar.isInsideRadius(trainer, Npc.INTERACTION_DISTANCE, false, false) && !activeChar.isGM())
            return;

 

but i tested and it closes when you click the window. only works when you click on npc. an then you can click on that window.

 

 

i think that i need to touch more classes. because when i want to learn skills on a windows or community is not equal that when you try to learn skills on a npc.

Edited by barao45
wrong
  • 0
Posted

IT BASSICALY 1 LINE UPPER  , DO YOU WANT ME TO COMPILE FOR U?

 

  // Incorrect npc, return.
        final Npc trainer = activeChar.getCurrentFolkNPC();
        if (trainer == null)
            return;

  • 0
Posted

I think you don't understand or you don't read more than 1 line onwards, so the solutions are not resolved because with that bugs are generated. If you solve everything like this, no thanks, I don't ask you for anything else xD. I have found the right way.
Thanks anyway

  • 0
Posted (edited)

you just said you created something and is not working ? why bcs you are brainless. im not trying to solve your problems , im trying to help you use you brain .. if you don't want to fix your source on your own and all time pay someone you should hire 1 guy as developer for your projects.

Edited by LoVe+

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

    • ## SuperPoint Editor   SuperPoint Editor is a practical visual editor for Lineage II PTS 'SuperPoint.bin' files. It is built for people who need to inspect, fix, rebuild, and draw server routes without digging through binary data by hand.   ### What You Can Do   - Open and edit 'SuperPoint.bin' files. - Export BIN data into a readable TXT format. - Save edited data back into a valid BIN file. - Validate routes before saving. - Work with SuperPoint routes, points, directed connections, and path records in tables. - Add, duplicate, delete, and reorder points. - Create direct and reverse connections between route points. - Automatically generate connections between neighboring points. - Edit raw point coordinates: 'X', 'Y', 'Z', 'Index', and 'Delay'. - Keep route names and internal route data organized. - Use either English or Ukrainian interface language.   ### C4 Server Support   Some C4 servers have 'SuperPoint.bin', but do not have 'superpointinfo.txt' in scripts. The editor supports this case directly. When 'superpointinfo.txt' is not found near the BIN file, the editor can open the BIN in C4 mode. In this mode, 'Fstring ID' is disabled because that value belongs to 'superpointinfo.txt', not to the BIN itself. The editor will not generate or modify 'superpointinfo.txt' while working in this mode. This keeps C4 data clean and avoids creating script files that the server does not actually use.   ### superpointinfo.txt Support   For chronicles that do use 'superpointinfo.txt', the editor can load and synchronize it together with the BIN data. When saving, the editor updates route nodes and coordinates while preserving existing metadata such as: - 'npc_name' - 'move_type' - 'fstring_index' - 'social_number' - 'delay' New nodes are generated with safe default values, so existing script metadata is not accidentally wiped.   ### Geodata Tools   The editor can also open converted geodata '.dat' files and display them as a map. This makes route editing much more visual. You can: - Load geodata and inspect the terrain by layer. - Zoom and pan around the map. - Create a new SuperPoint directly from a map cell. - Draw a route by clicking on the geodata. - Drag existing points to new positions. - Automatically snap 'X/Y' to the selected geo cell. - Use the selected geodata layer to fill the point 'Z'. - See all routes on the map or focus only on the selected one. This is especially useful when building new NPC movement paths or correcting bad route coordinates.   ### Connections and Paths   SuperPoint connections are directional. A connection from point '3' to point '2' is not the same as a connection from point '2' to point '3'. The editor makes this explicit by separating: - route points, - directed connections, - and the actual path records used by each connection. For simple cases, it can create direct path records automatically. For more complex movement, you can edit the path points manually. ### Built for Safe Editing The editor includes validation before saving, so common structural problems can be caught before a broken BIN is produced. It also verifies rebuilt BIN files through the converter engine. The goal is simple: edit quickly, but do not silently damage server data.   ### Unknown Field   This small 'Unknown' field is part of the original BIN structure. Most official-looking files keep it as '0', and for regular route editing there is usually no reason to change it. The editor exposes it so nothing from the BIN is hidden or lost. If you do not know exactly what your server uses it for, keep it at '0'. Download
    • NpcGrp não salva no interlúdio e da crítico quando coloca ele no cliente, já testei ele antes.
  • 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..