Jump to content

Recommended Posts

Posted (edited)

This system is just to give merchants a life. To avoid floods create a config for this I left "FloodProtector.SOCIAL" as an example only. code

 

+<?xml version="1.0" encoding="UTF-8"?>
+<list>
+<!--  SayType
+
+	ALL,
+	SHOUT, // !
+	TELL, // "
+	PARTY, // #
+	CLAN, // @
+	GM,
+	PETITION_PLAYER,
+	PETITION_GM,
+	TRADE, // +
+	ALLIANCE, // $
+	ANNOUNCEMENT,
+	BOAT,
+	L2FRIEND,
+	MSNCHAT,
+	PARTYMATCH_ROOM,
+	PARTYROOM_COMMANDER, // (Yellow)
+	PARTYROOM_ALL, // (Red)
+	HERO_VOICE,
+	CRITICAL_ANNOUNCE;
+ -->
+	<settings npcId="30001" text="Hello what do you want ?" sayType="SHOUT" effect="true" />
+</list>

 

 

code optimization

edioN5X.png

Update

Edited by Williams
Posted (edited)

1. If you're working with Java 15+ this

 

public class MerchantSay
+{
+	private final int _npcId;
+	private final String _text;
+	private final SayType _type;
+	private final boolean _effect;
+	
+	public MerchantSay(int npcId, String text, SayType type, boolean effect)
+	{
+		_npcId = npcId;
+		_text = text;
+		_type = type;
+		_effect = effect;
+	}
+	
+	public int getNpcId()
+	{
+		return _npcId;
+	}
+	
+	public String getText()
+	{
+		return _text;
+	}
+	
+	public SayType getType()
+	{
+		return _type;
+	}
+	
+	public boolean isEffects()
+	{
+		return _effect;
+	}
+}

 

Can be simply in 1 line like this:

 

+ public record MerchantSay(int npcId, String text, SayType type, boolean effect){}

 

2. Your code broadcast to all players the text and the effect. If 3-4 players click at the same time it will be a mess. Send packet only to the player who clicked. 

 

3. Why return if the data is null ?

 

final MerchantSay says = MerchantSayData.getInstance().getNpc(getNpcId());
+		if (says == null)
+			return "";

 

Doesn't this mean that the other NPC that are not registered as MerchantSay won't display a proper html path? 

 

4. Kinda pointless to use all Say2 channels. Nobody is going to use for example L2FRIEND, MSNCHAT or CRITICAL_ANNOUNCE. Especially the way you wrote your code if any Admin does it will spam the whole place surrounded by players (can also be a gate to flood), simply use All chat. 

 

In addition if you made the video it's very annoying to have 8 seconds of dubstep intro while the video is 19. 50% of the video is the intro.

Edited by Kara
Posted (edited)
2 hours ago, Kara said:

1. If you're working with Java 15+ this

 



public class MerchantSay
+{
+	private final int _npcId;
+	private final String _text;
+	private final SayType _type;
+	private final boolean _effect;
+	
+	public MerchantSay(int npcId, String text, SayType type, boolean effect)
+	{
+		_npcId = npcId;
+		_text = text;
+		_type = type;
+		_effect = effect;
+	}
+	
+	public int getNpcId()
+	{
+		return _npcId;
+	}
+	
+	public String getText()
+	{
+		return _text;
+	}
+	
+	public SayType getType()
+	{
+		return _type;
+	}
+	
+	public boolean isEffects()
+	{
+		return _effect;
+	}
+}

 

Can be simply in 1 line like this:

 



+ public record MerchantSay(int npcId, String text, SayType type, boolean effect){}

 

2. Your code broadcast to all players the text and the effect. If 3-4 players click at the same time it will be a mess. Send packet only to the player who clicked. 

 

3. Why return if the data is null ?

 



final MerchantSay says = MerchantSayData.getInstance().getNpc(getNpcId());
+		if (says == null)
+			return "";

 

Doesn't this mean that the other NPC that are not registered as MerchantSay won't display a proper html path? 

 

4. Kinda pointless to use all Say2 channels. Nobody is going to use for example L2FRIEND, MSNCHAT or CRITICAL_ANNOUNCE. Especially the way you wrote your code if any Admin does it will spam the whole place surrounded by players (can also be a gate to flood), simply use All chat. 

 

In addition if you made the video it's very annoying to have 8 seconds of dubstep intro while the video is 19. 50% of the video is the intro.

Really xD I use java 11 and not 15, I cleaned the code. Didn't you like my intro?🤣🤣

 

edioN5X.png

Update

Edited by Williams
Posted (edited)

1 phrase cmon man. Make a pool of phrases which are chosen randomly upon talk with an npc. U can also check npc's sex and use that to deliver different phrases.

Then if player used more 1kk upon buying something the trader should comment that in general chat.

Or a big drop was sold so npc says that he received some nice goods etc.

If you start to hit  the merchant he should call the guards and they're spawning outside the shop and rush in to attack player ;)))

Edited by Xtellia

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • Hello, I'm working with custom Icons and noticed that you can use 64x64 icons and the client will handle them without problems in the Inventory and when you Drag them, they look HD so it's really cool, the problem starts when you move them to the shortcut bar, when they're placed there instead of rescaling the icon it just show the upper left corner (so it's 32x32 but showing only the part that fits in that space). I tried checking interface.u but can't find the line where the size for the icons in the shortcut bar are handled.   When in Inventory the item shows in a 32x32 size, if I use a 64x64 icon it re-scales so the icon looks great When dragging the item the image becomes 64x64 which looks pretty big, but it works good When placing the item in the shortcut bar only the top left of the icon is visible   Is there a way I can adjust the shortcut bar so that it re-scales the icon?
    • If you want to edit a large amount of entries in the L2 File-edit I recommend using excel, since both work with columns you can copy the entire file or just a few lines and paste it in excel and it will copy without problems, after you're done with editing you just select the cells and paste them in the .dat file making sure you're formatting correctly. I'm currently doing a massive edit on all gear and that's how i'm handling the .dat work
    • the logic is the "stacking" that is a filter if you use it then the item cannot co-exist (stack)
    • [Exclusive L2Gold Weekend Server] Available ONLY on Saturdays & Sundays – nowhere else, no other time ! Custom Armors (Dynasty, Apella) Custom Weapons (L2Gold Weapons) Custom Jewelry (L2Gold Jewelry) Custom Teleport System Custom AIO Buffer Custom Zones & NPCs Custom Raidboss … and much more waiting for you every weekend! This is not just another private server – it’s a limited-time battleground. When the weekend comes, everyone gathers in one place for the ultimate L2 experience. 👉 Online: Saturday–Sunday only 👉 Contact / Info: [https://www.facebook.com/profile.php?id=61578869175323]
    • ⏳ The price drops like sand slipping down in an hourglass.   📉 USA numbers are already at the lowest 💸 🌍 Next in line: Europe, Asia, and dozens of other countries.     All next week we’ll be actively working on lowering prices. The process has already started  soon costs will be much cheaper. 🔥 Get ready: the price drop will affect every country!   Website link — https://vibe-sms.net/ Our Telegram channel — https://t.me/vibe_sms
  • 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