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

    • First, don't really follow the "main voice", moreover if you consider it an hobby. Simply do what you want, you got only one life so use it as you want. If you make it an hobby, it's exactly like piano, or velo - only practice makes you better.   Secondly, how do you learn things ? It's actually a really important question, since some can simply be scholar, read books (theory) then practice ; and some simply can't read books. I'm the second type, I hated school, I find it boring - my knowledge in Java comes from try-and-fail. You improve your coding style every year or so, I can myself rewrite my own code (which I already considered top-notched) after a while. You always learn something new - even if Java barely evolves. L2J is a fun way to learn programming, it's a giant sandbox where you can edit anything, and I believe it should be taken as it.   My own way of learning was as follow : Add existing customs, no matter what they are : the point is to know main classes used by L2J / customs. L2J is barely Java knowledge ; the true knowledge is to know WHAT to search in WHICH location (what I call, organization). You have to understand than EVERYTHING you think already exists, in a form on another, in the source code. A custom is only the association of the different mechanisms you found "here and there", glued together in a proper goal. Once you know main classes to edit, and the customs you added are compiling fine, the main point is to know WHAT exactly you DID. Try to understand WHY and WHERE you actually copied the code. Third point would be to MANIPULATE the customs you added in order to fit your wish. First edit little values, then logic conditions ; eventually add a new Config, or a new functionality to the custom. Fourth point would be to begin to craft your own ideas. Once again, EVERYTHING already exists, in a form or another. You want a cycled event ? You got Seven Signs main task as exemple. Npc ? Search any type of Npc and figure out what it does. Fifth point would be to understand Java - mostly containers (WHAT and WHERE to use them), variables types and main Java mechanisms (inheritance, static modifier, etc). You should also begin to cut your code into maintainable classes or methods. Java can actually run without optimization, but bigger your ideas, more optimized and well-thought it should be. It's direct saved time in the future, and you would thank yourself doing so. Main tips : ALWAYS use any type of versioning system - GIT or SVN. It allows to save your work, step by step and eventually revert back anytime you want if you terribly messed up. L2J is 80% organization knowledge, and 20% Java knowledge. Basically, if you know WHAT and WHERE to search, if you aren't dumb, it's easy to replicate and re-use things. Cherry on top is to use a already good coded pack to avoid copy-paste crap and get bad habits. Avoid any type of russian or brazilian packs, for exemple - their best ability is to leak someone's else code. Obviously you need some default sense of logic, but Java and programming in general help you to improve it.   Finally, most of your questions could be solved joining related Discord (at least for aCis, I can't speak for others) - from the moment your question was correctly asked (and you seemed to search for the answer). My community (and myself) welcomes newbies, but got some issues with noobies.   The simpliest is to try, fail and repeat until you succeed - it sounds stupid, but that's basically how life works.   PS : about Java ressources, before ChatGPT, it was mostly about stackoverflow website, and site like Baeldung's one. With ChatGPT and alike, you generally double-cross AI output to avoid fucked up answers. Also, care about AI, they are often hallucinating really hard, even today. They can give you complete wrong answer, you tell them they are wrong, and they say "indeed, I suck, sorry - here's a new fucked up answer". You shouldn't 100% rely over AI answer, even if that can give sometimes legit answers, full code or just skeletons of ideas.   PPS : I don't think there are reliable ressources regarding L2J itself, also most of the proposed code decays pretty fast if the source code is actually maintained (at least for aCis). Still, old coded customs for old aCis sources are actually a good beginner challenge to apply on latest source.
    • WTS: - AQ - Baium - Zaken  - Frintezza - Vesper Fighter Focus Fire Element   pm for detalis
    • We have the best price! L2Reborn.org Signature x1 Franz NEW!! 1KK = $20 HURRY TO BUY AT THE TOP PRICE discord - adver745645
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock