I hope you're all having a good afternoon. I wanted to ask for your help with an issue I've been having while trying to create a community board for the Interlude chronicle using the L2JMobius CT 0 Interlude datapack. My goal is to make a top PvP and PK ranking and implement it into the custom community board that comes with this datapack.
I've adapted some code that works with the Interlude datapack from L2JMobius which I found in this link: Link. The creator of this code is "StinkyMadness".
Continuing on, I've created the RankingsBoard class and added it into the MasterHandlers, but the client throws a critical error. No errors are shown in the game server.
One idea that occurred to me is to implement this method in HomeBoard.java, but it also encounters the same error in the client. Since there are no errors shown in the game server, I'm having trouble finding a solution.
I would greatly appreciate any help or suggestions you can offer. Thank you in advance!
Here class RankingsBoard
* This file is part of the L2J Mobius project.
*
* 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 handlers.communityboard;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.stream.IntStream;
import org.l2jmobius.commons.database.DatabaseFactory;
import org.l2jmobius.commons.util.StringUtil;
import org.l2jmobius.gameserver.cache.HtmCache;
import org.l2jmobius.gameserver.handler.CommunityBoardHandler;
import org.l2jmobius.gameserver.handler.IParseBoardHandler;
import org.l2jmobius.gameserver.model.World;
import org.l2jmobius.gameserver.model.actor.Player;
/**
*/
public class RankingsBoard implements IParseBoardHandler
{
private static final StringBuilder PVP = new StringBuilder();
private static final StringBuilder PKS = new StringBuilder();
private static final int PAGE_LIMIT_15 = 15;
private long _nextUpdate;
public RankingsBoard()
{
}
private static final String[] COMMANDS =
{
"_bbsranking",
};
@Override
public boolean parseCommunityBoardCommand(String command, Player player)
{
try
{
if (command.equals("_bbsranking"))
{
showRakingList(player);
return true;
}
}
catch (Exception exc)
{
System.out.println(exc);
}
return false;
}
public void showRakingList(Player player)
{
if (_nextUpdate < System.currentTimeMillis())
{
PVP.setLength(0);
PKS.setLength(0);
try (Connection con = DatabaseFactory.getConnection();)
{
try (PreparedStatement ps = con.prepareStatement("SELECT char_name, pvpkills FROM characters WHERE pvpkills > 0 ORDER BY pvpkills DESC LIMIT " + PAGE_LIMIT_15);
ResultSet rs = ps.executeQuery())
{
int index = 1;
while (rs.next())
{
final String name = rs.getString("char_name");
final Player databasePlayer = World.getInstance().getPlayer(name);
final String status = "L2UI_CH3.msnicon" + ((databasePlayer != null) && databasePlayer.isOnline() ? "1" : "4");
StringUtil.append(PVP, "<tablewidth=300bgcolor=000000><tr><tdwidth=20align=right>", getColor(index), String.format("%02d", index), "</td>");
StringUtil.append(PVP, "<tdwidth=20height=18><imgsrc=", status, "width=16height=16></td><tdwidth=160align=left>", name, "</td>");
StringUtil.append(PVP, "<tdwidth=100align=right>", StringUtil.formatNumber(rs.getInt("pvpkills")), "</font></td></tr></table><imgsrc=L2UI.SquareGraywidth=296height=1>");
index++;
}
IntStream.range(index - 1, PAGE_LIMIT_15).forEach(x -> applyEmpty(PVP));
}
try (PreparedStatement ps = con.prepareStatement("SELECT char_name, pkkills FROM characters WHERE pkkills > 0 ORDER BY pkkills DESC LIMIT " + PAGE_LIMIT_15);
ResultSet rs = ps.executeQuery())
{
int index = 1;
while (rs.next())
{
final String name = rs.getString("char_name");
final Player databasePlayer = World.getInstance().getPlayer(name);
final String status = "L2UI_CH3.msnicon" + ((databasePlayer != null) && databasePlayer.isOnline() ? "1" : "4");
StringUtil.append(PKS, "<tablewidth=300bgcolor=000000><tr><tdwidth=20align=right>", getColor(index), String.format("%02d", index), "</td>");
StringUtil.append(PKS, "<tdwidth=20height=18><imgsrc=", status, "width=16height=16></td><tdwidth=160align=left>", name, "</td>");
StringUtil.append(PKS, "<tdwidth=100align=right>", StringUtil.formatNumber(rs.getInt("pkkills")), "</font></td></tr></table><imgsrc=L2UI.SquareGraywidth=296height=1>");
index++;
}
IntStream.range(index - 1, PAGE_LIMIT_15).forEach(x -> applyEmpty(PKS));
}
}
catch (Exception e)
{
}
_nextUpdate = System.currentTimeMillis() + 60000L;
}
String content = HtmCache.getInstance().getHtm(player, "data/html/CommunityBoard/Custom/ranking/rankinglist.html");
if (content != null)
{
content = content.replaceAll("%name%", player.getName());
content = content.replaceAll("%pvp%", PVP.toString());
content = content.replaceAll("%pks%", PKS.toString());
content = content.replaceAll("%time%", String.valueOf((_nextUpdate - System.currentTimeMillis()) / 1000));
CommunityBoardHandler.separateAndSend(content, player);
}
else
{
}
}
public String getColor(int index)
{
switch (index)
{
case 1:
return "<fontcolor=FFFF00>";
case 2:
return "<fontcolor=FFA500>";
case 3:
return "<fontcolor=E9967A>";
}
return "";
}
@Override
public String[] getCommunityBoardCommands()
{
return COMMANDS;
}
public void applyEmpty(StringBuilder sb)
{
sb.append("<tablewidth=300bgcolor=000000><tr>");
sb.append("<tdwidth=20align=right><fontcolor=B09878>--</font></td><tdwidth=20height=18></td>");
sb.append("<tdwidth=160align=left><fontcolor=B09878>----------------</font></td>");
sb.append("<tdwidth=100align=right><fontcolor=FF0000>0</font></td>");
sb.append("</tr></table><imgsrc=L2UI.SquareGraywidth=296height=1>");
}
public static RankingsBoard getInstance()
{
return SingletonHolder.INSTANCE;
}
private static class SingletonHolder
{
protected static final RankingsBoard INSTANCE = new RankingsBoard();
}
}
Here the method implemented in the HomeBoard.java class in an else if, I do not put the entire class because it is very large and I think it is unnecessary, but the constants it uses
constanst
private static final StringBuilder PVP = new StringBuilder();
private static final StringBuilder PKS = new StringBuilder();
private static final int PAGE_LIMIT_15 = 15;
private long _nextUpdate;
else if (command.startsWith("_bbsranking"))
{
if (_nextUpdate < System.currentTimeMillis())
{
PVP.setLength(0);
PKS.setLength(0);
try (Connection con = DatabaseFactory.getConnection();)
{
try (PreparedStatement ps = con.prepareStatement("SELECT char_name, pvpkills FROM characters WHERE pvpkills > 0 ORDER BY pvpkills DESC LIMIT " + PAGE_LIMIT_15);
ResultSet rs = ps.executeQuery())
{
int index = 1;
while (rs.next())
{
final String name = rs.getString("char_name");
final Player databasePlayer = World.getInstance().getPlayer(name);
final String status = "L2UI_CH3.msnicon" + ((databasePlayer != null) && databasePlayer.isOnline() ? "1" : "4");
StringUtil.append(PVP, "<tablewidth=300bgcolor=000000><tr><tdwidth=20align=right>", getColor(index), String.format("%02d", index), "</td>");
StringUtil.append(PVP, "<tdwidth=20height=18><imgsrc=", status, "width=16height=16></td><tdwidth=160align=left>", name, "</td>");
StringUtil.append(PVP, "<tdwidth=100align=right>", StringUtil.formatNumber(rs.getInt("pvpkills")), "</font></td></tr></table><imgsrc=L2UI.SquareGraywidth=296height=1>");
index++;
}
IntStream.range(index - 1, PAGE_LIMIT_15).forEach(x -> applyEmpty(PVP));
}
try (PreparedStatement ps = con.prepareStatement("SELECT char_name, pkkills FROM characters WHERE pkkills > 0 ORDER BY pkkills DESC LIMIT " + PAGE_LIMIT_15);
ResultSet rs = ps.executeQuery())
{
int index = 1;
while (rs.next())
{
final String name = rs.getString("char_name");
final Player databasePlayer = World.getInstance().getPlayer(name);
final String status = "L2UI_CH3.msnicon" + ((databasePlayer != null) && databasePlayer.isOnline() ? "1" : "4");
StringUtil.append(PKS, "<tablewidth=300bgcolor=000000><tr><tdwidth=20align=right>", getColor(index), String.format("%02d", index), "</td>");
StringUtil.append(PKS, "<tdwidth=20height=18><imgsrc=", status, "width=16height=16></td><tdwidth=160align=left>", name, "</td>");
StringUtil.append(PKS, "<tdwidth=100align=right>", StringUtil.formatNumber(rs.getInt("pkkills")), "</font></td></tr></table><imgsrc=L2UI.SquareGraywidth=296height=1>");
index++;
}
IntStream.range(index - 1, PAGE_LIMIT_15).forEach(x -> applyEmpty(PKS));
}
}
catch (Exception e)
{
}
_nextUpdate = System.currentTimeMillis() + 60000L;
}
final String customPath = Config.CUSTOM_CB_ENABLED ? "Custom/" : "";
final String path = command.replace("_bbsranking;", "");
String content = HtmCache.getInstance().getHtm(player, "data/html/CommunityBoard/" + customPath + path);
if (content != null)
{
content = content.replaceAll("%name%", player.getName());
content = content.replaceAll("%pvp%", PVP.toString());
content = content.replaceAll("%pks%", PKS.toString());
content = content.replaceAll("%time%", String.valueOf((_nextUpdate - System.currentTimeMillis()) / 1000));
CommunityBoardHandler.separateAndSend(content, player);
}
}
@Huggo Thank you for asking!
When you join our Discord, on the Nexus Marketing section there is a #work-showcase channel.
There you can see a little bit of what we are able to produce as a final ready-to-post product.
There is also this link in my new personal montage YouTube channel, in which I will be uploading every recent work:
https://youtube.com/playlist?list=PLkzBKexKw8Wj8dC2diYndd5yOWOXUQCJW&si=-HGxlovqzvD4qqy2
Two more videos are coming up this week, and a #reviews channel has opened for our clients to let other people know about their experience working with us.
Feel free to join our Hub in Discord, and for any inquries you might have don't hesitate to contact me or post your suggestion at #suggestions channel.
Следи за своим вонючим языком, мудак.
Your mouth stinks, go wash your mouth, it's a dump)
I don't know who you are or what you are, and I don't recommend buying anything from people outside of my network, as they may sell garbage under the guise of my work. There have been cases where my sales have been compromised.
Additionally, reselling below the purchase price has been prohibited.
I wish you all the best and peace.
I kindly request that the moderators close this topic, as it is no longer relevant and the contact information is outdated.
Question
ak4n1
Hello everyone,
I hope you're all having a good afternoon. I wanted to ask for your help with an issue I've been having while trying to create a community board for the Interlude chronicle using the L2JMobius CT 0 Interlude datapack. My goal is to make a top PvP and PK ranking and implement it into the custom community board that comes with this datapack.
I've adapted some code that works with the Interlude datapack from L2JMobius which I found in this link: Link. The creator of this code is "StinkyMadness".
Continuing on, I've created the RankingsBoard class and added it into the MasterHandlers, but the client throws a critical error. No errors are shown in the game server.
One idea that occurred to me is to implement this method in HomeBoard.java, but it also encounters the same error in the client. Since there are no errors shown in the game server, I'm having trouble finding a solution.
I would greatly appreciate any help or suggestions you can offer. Thank you in advance!
Here class RankingsBoard
Here the method implemented in the HomeBoard.java class in an else if, I do not put the entire class because it is very large and I think it is unnecessary, but the constants it uses
Critical Error:
2 answers to this question
Recommended Posts
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 accountSign in
Already have an account? Sign in here.
Sign In Now