Jump to content

Recommended Posts

Posted

This share is hmm how can i say basic website php scripts but ingame!

Its untested so plz give me some feedback:)

 

Insert the code into net.sf.l2j.gameserver.model.actor.instance and name it as L2StatManagerInstance.java

 

Then make a new npc with the type L2StatManager.

 

Ohh i forgot that :D

Credits to me:)

 

Now its show you:

top 10pvp

top 10pk

top 10Level

If its working properly i will add more stuff to it

 

/* 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 net.sf.l2j.gameserver.model.actor.instance;

import java.sql.PreparedStatement;
import java.sql.ResultSet;

import javolution.text.TextBuilder;

import net.sf.l2j.L2DatabaseFactory;
import net.sf.l2j.gameserver.network.serverpackets.NpcHtmlMessage;
import net.sf.l2j.gameserver.templates.chars.L2NpcTemplate;


/**
* Stat Manager
* 
* @author Intrepid
*/

public class L2StatManagerInstance extends L2FolkInstance
{

public L2StatManagerInstance(int objectId, L2NpcTemplate template)
{
	super(objectId, template);
}

@Override
public void onBypassFeedback(L2PcInstance player, String command)
{
	if (command.startsWith("TopPvp"))
	{
	      java.sql.Connection con = null;
	      try
	      {
	      	con = L2DatabaseFactory.getInstance().getConnection();
	        PreparedStatement statement;
	        statement = con.prepareStatement("SELECT char_name,pvpkills FROM characters where accesslevel = 0 order by pvpkills DESC LIMIT 10;");
	        ResultSet rset = statement.executeQuery();        
	        while(rset.next())
	        {
	        	NpcHtmlMessage html = new NpcHtmlMessage(getObjectId());
	        	TextBuilder sb = new TextBuilder();
	        	sb.append ("Character: "+rset.getString("char_name")+" ("+rset.getInt("pvpkills")+" kills");
	        	html.setHtml(sb.toString());
                    player.sendPacket(html);
    	    }
    	    rset.close();
          statement.close();
          con.close();
    	  }
    	  catch (Exception e)
    	  {
    	  	e.printStackTrace();
    	  }
	}
	if (command.startsWith("TopPk"))
	{
	      java.sql.Connection con = null;
	      try
	      {
	      	con = L2DatabaseFactory.getInstance().getConnection();
	        PreparedStatement statement;
	        statement = con.prepareStatement("SELECT char_name,pkkills FROM characters where accesslevel = 0 order by pkkills DESC LIMIT 10;");
	        ResultSet rset = statement.executeQuery();
	        while(rset.next())
	        {
	        	NpcHtmlMessage html = new NpcHtmlMessage(getObjectId());
	        	TextBuilder sb = new TextBuilder();
	        	sb.append ("Character: "+rset.getString("char_name")+" ("+rset.getInt("pkkills")+" kills");
	        	html.setHtml(sb.toString());
                    player.sendPacket(html);
    	    }
    	    rset.close();
          statement.close();
          con.close();
    	  }
    	  catch (Exception e)
    	  {
    	  	e.printStackTrace();
    	  }
	}
	if (command.startsWith("TopLvl"))
	{
	      java.sql.Connection con = null;
	      try
	      {
	      	con = L2DatabaseFactory.getInstance().getConnection();
	        PreparedStatement statement;
	        statement = con.prepareStatement("SELECT char_name,level FROM characters where accesslevel = 0 order by level DESC LIMIT 10;");
	        ResultSet rset = statement.executeQuery();
	        while(rset.next())
	        {
	        	NpcHtmlMessage html = new NpcHtmlMessage(getObjectId());
	        	TextBuilder sb = new TextBuilder();
	        	sb.append ("Character: "+rset.getString("char_name")+" ("+rset.getInt("level")+" level");
	        	html.setHtml(sb.toString());
                    player.sendPacket(html);
    	    }
    	    rset.close();
          statement.close();
          con.close();
    	  }
    	  catch (Exception e)
    	  {
    	  	e.printStackTrace();
    	  }
	}
}
}

Posted

Nice Intrepid,but i have a question...

How to add this in the server interlude ???

Can i to use only the java decompiler and it's works ???

Thx in advanced.

Posted

Nice Intrepid,but i have a question...

How to add this in the server interlude ???

Can i to use only the java decompiler and it's works ???

Thx in advanced.

never use java decompiler use eclipse than insert the file change the imports if you need and thats all spawn the npc ingame and you see

Posted

never use java decompiler use eclipse than insert the file change the imports if you need and thats all spawn the npc ingame and you see

Thx for reply man,but any ideia for to insert this modification in the interlude pack already compiled ???

In the gameserver have this files in .jar :

7108Image.png

But i don't know how to insert >.< .

Help-me plz =\.

Posted

Thx for reply man,but any ideia for to insert this modification in the interlude pack already compiled ???

In the gameserver have this files in .jar :

7108Image.png

But i don't know how to insert >.< .

Help-me plz =\.

 

You need the source code not the jar files:)

Posted

I am going to test it. If it works you will have +1 from me. Thanks

No problem man,i just want to use this great mod in my server Interlude  =\.

Posted

I made the code compatible with l2j interlude . Compiled the source with no problem but ingame npc says: 'i have nothing to tell you.'

Now checking on l2jct2.2

Posted

I made the code compatible with l2j interlude . Compiled the source with no problem but ingame npc says: 'i have nothing to tell you.'

Now checking on l2jct2.2

 

Thanks for test i make some test too and i find out whats the error.

Posted

working for me working for dimis...also working for my friends...

 

and WTF i NEVER post non working code...that code needs only a html file thats true i forget that...

Guest
This topic is now closed to further replies.



  • Posts

    • From Salvation onwards I think you need a patched nwindow.dll that allows such modifications, try to see if you get what you need here: https://drive.google.com/drive/u/1/folders/1LLbQFGf8KlR-O0Iv5umfF-pwZgrDh9bd
    • hello everyone! I am wanting to save the files (Ini. - Data - ) of the EP5 Client: Salvation... But they generate the error "corrupt files"... I tried several versions of L2FileEditor without good results. I need help! Thank you!
    • Opening December 6th at 19:00 (GMT +3)! Open Beta Test from November 30th!   https://l2soe.com/   🌟 Introducing L2 Saga of Eternia: A Revolution in Lineage 2 High Five! 🌟   Dear Lineage 2 enthusiasts, Prepare to witness the future of private servers! L2 Saga of Eternia is not just another High Five project—it’s a game-changing experience designed to compete with the giants of the Lineage 2 private server scene. Built for the community, by the community, we’re here to raise the bar in quality, innovation, and longevity. What Sets Us Apart? 💎 No Wipes, Ever Say goodbye to the fear of losing your progress. Our server is built to last and will never close. Stability and consistency are our promises to you. ⚔️ Weekly New Content Our dedicated development team ensures fresh challenges, events, and updates every week. From custom quests to exclusive features, there will always be something exciting to explore. 💰 No Pay-to-Win Skill and strategy matter most here. Enjoy a balanced gameplay environment where your achievements come from effort, not your wallet. 🌍 A Massive Community With 2000+ players expected, join a vibrant and active community of like-minded adventurers ready to conquer the world of Aden. 🏆 Fair and Competitive Gameplay Our systems are designed to promote healthy competition while avoiding abusive mechanics and exploits. 🔧 Professional Development From advanced bug fixes to carefully curated content, we pride ourselves on smooth performance, no lag, and unparalleled server quality. Key Features Chronicle: High Five with unique interface Rate: Dynamic x10 rates Class Balance: Carefully fine-tuned for a fair experience PvP Focused: PvP Ranking & aura display effect for 3 Top PvPers every week Custom Events: Seasonal and permanent events to keep you engaged Additional Features:   Custom Endgame Content: Introduce unique dungeons, raids, or zones unavailable in other servers. Player-Driven Economy: Implement a strong market system and avoid overinflated drops or rewards. Epic Siege Battles: Announce special large-scale sieges and PvP events. Incentives for Streamers and Clans: Attract influencers and big clans to boost server publicity. Roadmap Transparency: Share a public roadmap of planned updates to build trust and excitemen   Here you can read all the features: https://l2soe.com/features   Video preview: Join the Revolution! This is your chance to be part of something legendary. L2 Saga of Eternia is not just a server; it’s a movement to redefine what Lineage 2 can be. Whether you’re a seasoned veteran or a newcomer to the world of Aden, we invite you to experience Lineage 2 at its finest.   Official Launch Date: December 6th 2024 Website: https://l2soe.com/ Facebook: https://www.facebook.com/l2soe Discord: https://discord.com/invite/l2eternia   Let’s build the ultimate Lineage 2 experience together. See you in-game! 🎮
    • That's like a tutorial on how to run l2 on MacOS Xd but good job for the investigation. 
  • Topics

×
×
  • Create New...