Jump to content

Recommended Posts

Posted (edited)

Hello,

This npc shows the players and the weapons with the highest enchant in the server for l2jaCis.

 

 

https://prnt.sc/1v9lstl

 

 

/*
 * 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.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Map;
 
import net.sf.l2j.L2DatabaseFactory;
import net.sf.l2j.gameserver.datatables.ItemTable;
import net.sf.l2j.gameserver.model.actor.template.NpcTemplate;
import net.sf.l2j.gameserver.model.item.kind.Weapon;
import net.sf.l2j.gameserver.network.serverpackets.NpcHtmlMessage;
 
/**
 * @author Ugleethyn
 *
 */
public class TopManager extends Folk
{
	public TopManager(int objectId, NpcTemplate template)
	{
		super(objectId, template);
	}
 
	@Override
	public void onBypassFeedback(Player player, String command)
	{
			if(command.equals("topench")) {
			NpcHtmlMessage htm = new NpcHtmlMessage(getObjectId(), player);
			htm.setFile("data/html/topmanager/topench.htm");
			htm.replace("%stats%", getTopEnchant());
			player.sendPacket(htm);
		}
	}
 
 
	private static String getTopEnchant()
	{
		String ret = "";
		try (Connection con = L2DatabaseFactory.getInstance().getConnection())
		{
			PreparedStatement stm = con.prepareStatement("SELECT C.char_name, I.enchant_level,I.item_id\r\n"
				+ "FROM characters C\r\n"
				+ "INNER JOIN items I\r\n"
				+ "ON C.obj_Id = I.owner_id\r\n"
				+ "WHERE C.accesslevel = 0\r\n"
				+ "AND I.item_id IN (6364, 6365,6366,6367,6368,6369,6370,6371,6372,6579,6581,6582,6583,6584,6585,6586,6587,6588,6589,6590,6591,6592,6594,6595,6596,6597,6598,6599,6600,6601,6602,6603,6604,6605,6606,6607,6608,7578,7577,7576,7575,7575,6610,6609,6593)\r\n"
				+ "ORDER BY I.enchant_level DESC LIMIT 15");
			ResultSet rset = stm.executeQuery();
			int i = 1;
			while (rset.next())
			{
				String name = rset.getString("char_name");
				int enchantLevel = rset.getInt("enchant_level");
				int itemId = rset.getInt("item_id");
				String weaponName = "";
				for (Map.Entry<Integer, Weapon> entry : ItemTable._weapons.entrySet()) {
					if((itemId== entry.getKey())) {
						weaponName = entry.getValue().getName();
					}
				}
				ret += "<table width=\"290\">"
					+ "<tr>"
					+ "<td FIXWIDTH=\"13\" align=\"left\">"+i+++"</td>"
					+ "<td FIXWIDTH=\"70\" align=\"left\">"+name+"</td>"
					+ "<td FIXWIDTH=\"50\" align=\"left\">"+enchantLevel+"</td>"
					+ "<td FIXWIDTH=\"157\" align=\"left\">"+weaponName+"</td>"
					+ "</tr>"
					+ "</table>"
					+ "<img src=\"L2UI.Squaregray\" width=\"300\" height=\"5\">";
			}
 
			rset.close();
			stm.close();
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		return ret;
	}
 
	@Override
	public String getHtmlPath(int npcId, int val)
	{
		String filename = "";
		if (val == 0)
			filename = "" + npcId;
		else
			filename = npcId + "-" + val;
 
		return "data/html/topmanager/" + filename + ".htm";
	}
}
 

 

Html files : https://www.mediafire.com/file/xxn794ok2an46to/topmanager.rar/file

Edited by Ugleethyn
  • Like 1
  • Upvote 2
  • 4 months later...

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

    • Hello everyone, I am looking to purchase a Premium Lineage 2 High Five server pack. My main requirements are: Stability & Quality (Most Important): The pack must be highly stable with no system errors or major bugs. Custom Features: It must include ready-to-use custom features such as a fully functional Community Board, custom NPC Buffers, and Custom Item Sellers (GM Shops), etc. Complete Files: It is absolutely necessary that the full source code (src) and complete Geodata are included. If you are selling a pack that meets these criteria, please send me a PM or leave a reply with the following information: Brief details and key features of the pack Price Test server availability (I would like to test it before buying) Thank you!
    • L2jmobiusDevClon — Classic Interlude p110 Emulator L2jmobiusDevClon is actively developing a Lineage 2 Classic Interlude p110 emulator. Development is done in free time with a strong focus on: • Stability • Authentic Classic mechanics • Clean and optimized architecture The project is based on the L2jMobius source and is continuously evolving and improving. System Requirements: • Java 25 • MariaDB 12.0 • Client p110 Current Revision: 3.0 Development Status: Active Distribution: Free Official Website: https://www.l2jmobiusdevclon.pp.ua Discord Server: https://discord.gg/23a9S8g4Bn Contact: Telegram — @L2jmobiusDevClon Also available via private messages Project Goals: ✔ Improved stability ✔ Maximum Classic accuracy ✔ Core optimization We are currently looking for: • Testers • Server administrators Suggestions, bug reports, and ideas are always welcome. Contact us via: ✔ Discord ✔ Telegram ✔ Private Messages
    • i guess loading only the effects that are needed it will maybe work, like removing from reshade shader folder the ones that are not needed, depends on the pc also i guess, also limithing the game at 30fps can be better maybe
    • Up   SELL CHARACTERS L2 REBORN FRANZ x1     destroyer 74 lvl naked - 120 euro sws 71 lvl naked - 120 euro pp 66 skills - 120 euro se 64 lvl - 90 euro   Characters are legit with mail   i can wtt the characters for adena server franz   sell adena franz 250kk stock     add discord topeseller4081  
  • 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..