Jump to content

Recommended Posts

Posted (edited)

Hello guys,

I wanna share with you my custom enchant skill list. What this list contains?

 

  1. 100% safe enchant till enchant reach the config value
  2. If the enchant is higher than this value you have the retail chance
  3. if you fail to enchant and character is nobl ( nobl condition was for testing you have to change this with your condition ) the skill enchant will become -1 of the current enchant
  4. Its working for both conditions ( < 130 , < 170 ex. power,cost )
  5. 2 configs ( no need more )

Coded in acis 364

video

 

 

diff

 

### Eclipse Workspace Patch 1.0
#P aCis_gameserver
Index: java/net/sf/l2j/gameserver/network/clientpackets/RequestExEnchantSkillInfo.java
===================================================================
--- java/net/sf/l2j/gameserver/network/clientpackets/RequestExEnchantSkillInfo.java	(revision 7)
+++ java/net/sf/l2j/gameserver/network/clientpackets/RequestExEnchantSkillInfo.java	(working copy)
@@ -84,7 +84,9 @@
 					return;
 				
 				// Send ExEnchantSkillInfo packet.
-				ExEnchantSkillInfo esi = new ExEnchantSkillInfo(_skillId, _skillLevel, data.getCostSp(), data.getCostExp(), data.getRate(activeChar.getLevel()));
+				int fElem = 100 + Config.SAFE_ENCHANT;
+				int sElem = 140 + Config.SAFE_ENCHANT;
+				ExEnchantSkillInfo esi = new ExEnchantSkillInfo(_skillId, _skillLevel, data.getCostSp(), data.getCostExp(), (activeChar.isNoble() && ((_skillLevel > 130 && _skillLevel <= sElem) || (_skillLevel <= fElem))) ? 100 : data.getRate(activeChar.getLevel()));
 				if (Config.ES_SP_BOOK_NEEDED)
 					if (data.getItemId() != 0 && data.getItemCount() != 0)
 						esi.addRequirement(4, data.getItemId(), data.getItemCount(), 0);
Index: java/net/sf/l2j/Config.java
===================================================================
--- java/net/sf/l2j/Config.java	(revision 7)
+++ java/net/sf/l2j/Config.java	(working copy)
@@ -52,6 +52,7 @@
 	public static final String SIEGE_FILE = "./config/siege.properties";
 	public static final String PARTY_EVENT_FILE = "./config/PartyEvent.properties";
 	public static final String VOTE_MANAGER_FILE = "./config/VoteManager.properties";
+	public static final String ENCHANT_SKILL_FILE = "./config/CustomEnchantSkills.properties";
 	
 	
 	/** VoteManager Settings */
@@ -107,6 +108,10 @@
 	public static boolean ALT_MEMBERS_CAN_WITHDRAW_FROM_CLANWH;
 	public static boolean REMOVE_CASTLE_CIRCLETS;
 	
+	/** Enchant Skills */
+	 public static int SAFE_ENCHANT;
+	 public static boolean REDUCE_BY_ONE;
+	 
 	/** Manor */
 	public static int ALT_MANOR_REFRESH_TIME;
 	public static int ALT_MANOR_REFRESH_MIN;
@@ -1056,6 +1061,12 @@
 		RED_RAID_MSG = ptEvent.getProperty("RedRaidMessage","And remember!! Your enemies are noobs! Go Go Go!");
 
 	}
+	private static final void loadEnchantSkills()
+	{
+		final ExProperties eSkills = initProperties(ENCHANT_SKILL_FILE);
+		SAFE_ENCHANT = eSkills.getProperty("SkillSafeEnchantMax", 15);
+		REDUCE_BY_ONE = eSkills.getProperty("ReduceEnchant", false);
+	}
 	/**
 	 * Loads NPC settings.<br>
 	 * Such as champion monsters, NPC buffer, class master, wyvern, raid bosses and grand bosses, AI.
@@ -1512,6 +1523,9 @@
 		
 		// server settings
 		loadServer();
+		
+		// Enchant Skills
+		loadEnchantSkills();
 	}
 	
 	public static final void loadLoginServer()
Index: java/net/sf/l2j/gameserver/network/clientpackets/RequestExEnchantSkill.java
===================================================================
--- java/net/sf/l2j/gameserver/network/clientpackets/RequestExEnchantSkill.java	(revision 7)
+++ java/net/sf/l2j/gameserver/network/clientpackets/RequestExEnchantSkill.java	(working copy)
@@ -121,7 +121,9 @@
 		activeChar.removeExpAndSp(data.getCostExp(), data.getCostSp());
 		
 		// Try to enchant skill.
-		if (Rnd.get(100) <= data.getRate(activeChar.getLevel()))
+		int fElem = 100 + Config.SAFE_ENCHANT;
+		int sElem = 140 + Config.SAFE_ENCHANT;
+		if ((activeChar.isNoble() && ((_skillLevel > 130 && _skillLevel <= sElem) || (_skillLevel <= fElem))) ? true : Rnd.get(100) <= data.getRate(activeChar.getLevel()))
 		{
 			activeChar.addSkill(skill, true);
 			activeChar.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.YOU_HAVE_SUCCEEDED_IN_ENCHANTING_THE_SKILL_S1).addSkillName(_skillId, _skillLevel));
@@ -131,7 +133,13 @@
 			activeChar.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.YOU_HAVE_FAILED_TO_ENCHANT_THE_SKILL_S1).addSkillName(_skillId, _skillLevel));
 			if (_skillLevel > 100)
 			{
-				_skillLevel = baseLvl;
+				if (Config.REDUCE_BY_ONE && activeChar.isNoble())
+				{
+					if (_skillLevel > 140 || _skillLevel < 130)
+						_skillLevel-=2;		
+				}
+				else
+					_skillLevel = baseLvl;
 				activeChar.addSkill(SkillTable.getInstance().getInfo(_skillId, _skillLevel), true);
 			}
 		}
 

 

 

CustomEnchantSkills.properties

 

# ================================================================
#                          Enchant Skills setting
# ================================================================

#If the char meet the conditions will enchant with 100% success rate
#Till the this value
#default 15
SkillSafeEnchantMax = 10

#If this is true and the enchant will fail , the skill enchantment will lost 1 enchant
ReduceEnchant = true 

 

Edited by melron
  • Upvote 2
Posted

I think it should be better to require 1 book of giant everytime skill enchant fails .(for the noblesse part)

  Because without requiring one he can go all the way to max enchant with just 1 bog  ^-^

Posted (edited)

I think it should be better to require 1 book of giant everytime skill enchant fails .(for the noblesse part)

  Because without requiring one he can go all the way to max enchant with just 1 bog  ^-^

Nop, you supposed to use this code for a special case (like nobl in this case) so , its better as it is :P

Edited by melron
Posted

Nop, you supposed to use this code for a special case (like nobl in this case) so , its better as it is :P

You know better :)

Posted

I think it should be better to require 1 book of giant everytime skill enchant fails .(for the noblesse part)

  Because without requiring one he can go all the way to max enchant with just 1 bog  ^-^

 +1 to this setting ( You can add it as config )

Thanks for sharing

Posted

 +1 to this setting ( You can add it as config )

Thanks for sharing

thank you :)

If he can make it that way it would be a pretty nice npc :P

Posted (edited)

 +1 to this setting ( You can add it as config )

Thanks for sharing

 

ill not add something like this because..

 

it can be use for donators xD :P

 

also if i add this setting that means i have to add require item and the check must be before the character will click enchant... like normal one

Edited by melron
Posted (edited)

If the success rate is 100%, better reward directly last segment, and compute the SP cost for looping +1 to +30.

 

That will avoid you 30 clicks per skill.

the rate is 100 only till the value u set .. next enchants chance is retail one from xmls.. i made this one for low values like +10 .. now if someone wants +30 he can do it like this in +30 case :P

 

btw i already did that (instantly +30) :-beep- yeah:

 

Edited by melron
Posted

the rate is 100 only till the value u set .. next enchants chance is retail one from xmls.. i made this one for low values like +10 .. now if someone wants +30 he can do it like this in +30 case :P

 

btw i already did that (instantly +30) :-beep- yeah:

 

https://www.youtube.com/watch?v=KK7Y-QxYfF8&feature=youtu.be

I like this way seems better than the first one
Posted

Awww my little melron made a share. Normally i'm bad with everyone but you're exception.

I will give you tomorrow the +1 cause im sleepy.

 

Also tryskell stop being lazy bananawhore who eat cookies from other's kitchen and watch family series you b*itch i6tW8n1.png

Posted

Awww my little melron made a share. Normally i'm bad with everyone but you're exception.

I will give you tomorrow the +1 cause im sleepy.

 

Also tryskell stop being lazy bananawhore who eat cookies from other's kitchen and watch family series you b*itch i6tW8n1.png

Hehe thanks baby :D

  • 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

    • Hi everyone,   In 2014, I completely stepped away from developing L2 servers and doing L2J-related work. Since then, I’ve only opened this server about once a year and helped a few servers and individuals for free. I haven’t taken on any paid L2J work since then.   LINEAGE2.GOLD is a project that has reached about Season 6. The first season launched at the end of 2020 and was a fully rebuilt Gold-style server on the Classic client (protocol 110). It featured many custom systems and enhancements. After several seasons, I decided to abandon the Mobius-based project and move to Lucera, as my goal was to get as close as possible to Interlude PTS behavior while still staying on the L2J platform.   The current project was once again completely rebuilt, this time on the Essence client (protocol 306), and is based on Lucera. Because of that, acquiring a license from Deazer is required.   My Lucera extender includes, but is not limited to: Formulas.java Basic anti-bot detection, which proved quite effective, we caught most Adrenaline users using relatively simple server-side logic, logged them, and took staff action. Simple admin account lookup commands based on IP, HWID, and similar identifiers. In-game Captcha via https://lineage2.gold/code, protected by Cloudflare, including admin commands for blacklisting based on aggression levels and whitelisting. Additional admin tools such as Auto-Play status checks, Enchanted Hero Weapon live sync, force add/remove clans from castle sieges, item listeners for live item monitoring, and more. A fully rewritten Auto-Play system with support for ExAutoPlaySetting, while still using the Auto-Play UI wheel, featuring: Debuff Efficiency Party Leader Assist Respectful Hunting Healer AI Target Mode Range Mode Summoner buff support Dwarf mechanics Reworked EffectDispelEffects to restore buffs after Cancellation. Raid Bomb item support. Reworked CronZoneSwitcher. Prime Time Raid Respawn Service. Community Board features such as Top rankings and RB/Epic status. Custom systems for Noblesse, Subclasses, support-class rewards, and much more.   Depending on the deal, the project can include: The lineage2.gold domain The website built on the Laravel PHP framework The server’s Discord Client Interface source Server files and extender source The server database (excluding private data such as emails and passwords)   I’m primarily looking for a serious team to continue the project, as it would be a shame to see this work abandoned. This is not cheap. You can DM me with offers. If you’re wondering why I’m doing this: I’ve felt a clear lack of appreciation from the L2 community, and I’m not interested in doing charity work for people who don’t deserve it. I’m simply not someone who tolerates BS. Server Info: https://lineage2.gold/info Server for test: https://lineage2.gold/download Over 110 videos YouTube playlist: https://www.youtube.com/watch?v=HO7BZaxUv2U&list=PLD9WZ0Nj-zstZaYeWxAxTKbX7ia2M_DUu&index=113
  • 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..

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