Jump to content

Question

12 answers to this question

Recommended Posts

  • 0
Posted (edited)

if you are using aCis:

 

pastebin

 

log with your gm and spawn fences , they will be stored to db.

(in case of delete some of them use //listfence and click the fence you want)

Edited by melron
  • Upvote 1
  • 0
Posted
27 minutes ago, Xenokage said:

how am i supposed to add a fence to a zone ? i use //spawnfence 2 2000 2000 but after restart it dissapears , anyway to save ?

You can save them in xml with a code...

  • 0
Posted (edited)
5 minutes ago, Reborn12 said:

You can save them in xml with a code...

can u be specific on wich xml i have to add the location values ? 

would it be on the zone xml like this ? 

<spawnfence 2 2000 2000 X="-119418" Y="-225003" Z="-3327" /> ????

Edited by Xenokage
  • 0
Posted
On 9/7/2018 at 2:19 PM, Reborn12 said:

You can save them in xml with a code...

Tell me the day SQL replaced with XML to store somethin cause im sure i was SLEEPING

  • 0
Posted
2 minutes ago, Kara` said:

Tell me the day SQL replaced with XML to store somethin cause im sure i was SLEEPING

 

νοτ σθρε ιφ ρεταρδεδ ορ...;

  • 0
Posted
22 minutes ago, xxdem said:

 

νοτ σθρε ιφ ρεταρδεδ ορ...;

[GR] ονε ηθνδρετ περψεντ ρεταρδεδ [/GR]

  • 0
Posted

crappy code but still u can see example:

fencetable.java

package com.l2jfrozen.gameserver.datatables;

import java.util.ArrayList;
import java.util.Collection;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import com.l2jfrozen.gameserver.model.L2Object;
import com.l2jfrozen.gameserver.model.actor.instance.L2FenceInstance;
import java.util.logging.Logger;
import com.l2jfrozen.util.database.L2DatabaseFactory;
import com.l2jfrozen.gameserver.idfactory.IdFactory;
import com.l2jfrozen.util.CloseUtil;

public class FenceTable
{
protected static Logger _log = Logger.getLogger(FenceTable.class.getName());

public static void fencedelsql(int type,int locx,int locy,int locz,int width,int length){
		Connection con;
		try 
		{
			con = L2DatabaseFactory.getInstance().getConnection();
			PreparedStatement statement = con.prepareStatement("DELETE FROM `fences` WHERE `type`='"+type+"' AND `locx`='"+locx+"' AND `locy`='"+locy+"' AND `locz`='"+locz+"' AND `width`='"+width+"' AND `length`='"+length+"'");
			statement.execute();
            statement.close(); 	
			CloseUtil.close(con);			
			   }
			    catch (Exception e)
               {
                       e.printStackTrace();
               }
}
public static void fencetogame(){
						  int g=0;
		Connection con = null;
		try 
		{
			con = L2DatabaseFactory.getInstance().getConnection();
                       ResultSet rset;
                       PreparedStatement statement = con.prepareStatement("SELECT * FROM `fences` WHERE 1");
                       rset = statement.executeQuery();
					  int type;
                      int width;
					  int length;
					  int height;
					  int locx;
					  int locy;
					  int locz;
					  String name;
                       while (rset.next())
                       {
						   g++;
						   type = rset.getInt("type");
						   width = rset.getInt("width");
						   length = rset.getInt("length");
						   height = rset.getInt("height");
						   locx = rset.getInt("locx");
						   locy = rset.getInt("locy");
						   locz = rset.getInt("locz");
						   name = rset.getString("name");


						// spawn fence
				for (int i = 0;i < height;i++)
				{
					L2FenceInstance fence = new L2FenceInstance(IdFactory.getInstance().getNextId(), type, width, length, locz, locy, name);
					fence.spawnMe(locx, locy, locz);
					addFence(fence);
				}
                        // spawn fence						
                       }
			   }
			    catch (Exception e)
               {
                       e.printStackTrace();
               }		finally
		{
			CloseUtil.close(con);
		}
			   _log.warning("Loaded "+g+" fences to world.");
}

 public static ArrayList<L2FenceInstance> fences = new ArrayList<>();
 
 public static void addFence(L2FenceInstance fence)
 {
     fences.add(fence);
 }

 public static ArrayList<L2FenceInstance> getAllFences()
 {
     return fences;
 }
 
 public static void removeFence(L2FenceInstance fence)
 {
     if (fences.contains(fence))
         fences.remove(fence);
 }
 
 public static boolean canSeeTarget(L2Object source, int x, int y)
 {
     Collection<L2Object> objects = source.getKnownList().getKnownObjects().values();
     
     for (L2Object obj : objects)
     {
         if (obj instanceof L2FenceInstance)
         {
             L2FenceInstance fence = (L2FenceInstance) obj;
             
             if (fence.isBetween(source.getX(), source.getY(), x, y))
                 return false;
         }
     }
     
     return true;
 }
 
 public static boolean canSeeTarget(int x, int y, int tx, int ty)
 {
     for (L2FenceInstance fence : fences)
     {
         if (fence.isBetween(x, y, tx, ty))
             return false;
     }
     
     return true;
 }
}

gameserver java

FenceTable.fencetogame();

admin command:

		else if (command.startsWith("admin_spawnfence"))
		{
			StringTokenizer st = new StringTokenizer(command, " ");
			try
			{
				st.nextToken();
				int type = Integer.parseInt(st.nextToken());
				int width = Integer.parseInt(st.nextToken());
				int length = Integer.parseInt(st.nextToken());
				int height = 1;
				String name = "";
				if (st.hasMoreTokens())
					height = Math.min(Integer.parseInt(st.nextToken()), 3);
				if (st.hasMoreTokens())
				name = st.nextToken();
				
				for (int i = 0;i < height;i++)
				{
					L2FenceInstance fence = new L2FenceInstance(IdFactory.getInstance().getNextId(), type, width, length, activeChar.getX(), activeChar.getY(), name);
					fence.spawnMe(activeChar.getX(), activeChar.getY(), activeChar.getZ());
					FenceTable.addFence(fence);
					fence.fencetosql(type,activeChar.getX(),activeChar.getY(),activeChar.getZ(),width,length, height,name);
				}
			}
			catch (Exception e)
			{
				activeChar.sendMessage("Usage: //spawnfence <type> <width> <length> [<height>]");
			}
		}
		else if (command.startsWith("admin_deletefence"))
		{
			StringTokenizer st = new StringTokenizer(command, " ");
			st.nextToken();
			int idas = Integer.parseInt(st.nextToken());
			for (L2FenceInstance fencex : FenceTable.getAllFences()) {
					if(fencex.getObjectId()==idas) {
					FenceTable.fencedelsql(fencex.getType(),fencex.getX(),fencex.getY(),fencex.getZ(),fencex.getWidth(),fencex.getLength());
					L2WorldRegion region = fencex.getWorldRegion();
					fencex.decayMe();
					region.removeVisibleObject(fencex);
					fencex.getKnownList().removeAllKnownObjects();
					L2World.getInstance().removeObject(fencex);
					FenceTable.removeFence(fencex);
					activeChar.sendMessage("Deleted fence " + fencex.getObjectId());
					listFences(activeChar);
					}
				}
		}
		else if (command.startsWith("admin_listfence"))
			listFences(activeChar);
                                              ....
    private static void listFences(L2PcInstance activeChar)
	{
		NpcHtmlMessage html = new NpcHtmlMessage(0);
		StringBuilder sb = new StringBuilder();
		
		sb.append("<html><body>Total Fences: " + FenceTable.getAllFences().size() + "<br><br>");
		for (L2FenceInstance fence : FenceTable.getAllFences())
			sb.append("<a action=\"bypass admin_deletefence " + fence.getObjectId() + " 1\">Fence: "+fence.getNamex()+" " + fence.getObjectId() + " [" + fence.getX() + " " + fence.getY() + " " + fence.getZ() + "]</a><br>");
		sb.append("</body></html>");
		
		html.setHtml(sb.toString());
		activeChar.sendPacket(html);
	}

 

  • Upvote 1
  • 0
Posted
On 10/14/2018 at 3:53 AM, melron said:

if you are using aCis:

 

pastebin

 

log with your gm and spawn fences , they will be stored to db.

(in case of delete some of them use //listfence and click the fence you want)

Thank you , Helpful as always :)) 
can lock ! 

Guest
This topic is now closed to further replies.


  • Posts

    • From Salvation onwards I think you need a patched nwindow.dll that allows such modifications, try to see if you get what you need here: https://drive.google.com/drive/u/1/folders/1LLbQFGf8KlR-O0Iv5umfF-pwZgrDh9bd
    • hello everyone! I am wanting to save the files (Ini. - Data - ) of the EP5 Client: Salvation... But they generate the error "corrupt files"... I tried several versions of L2FileEditor without good results. I need help! Thank you!
    • Opening December 6th at 19:00 (GMT +3)! Open Beta Test from November 30th!   https://l2soe.com/   🌟 Introducing L2 Saga of Eternia: A Revolution in Lineage 2 High Five! 🌟   Dear Lineage 2 enthusiasts, Prepare to witness the future of private servers! L2 Saga of Eternia is not just another High Five project—it’s a game-changing experience designed to compete with the giants of the Lineage 2 private server scene. Built for the community, by the community, we’re here to raise the bar in quality, innovation, and longevity. What Sets Us Apart? 💎 No Wipes, Ever Say goodbye to the fear of losing your progress. Our server is built to last and will never close. Stability and consistency are our promises to you. ⚔️ Weekly New Content Our dedicated development team ensures fresh challenges, events, and updates every week. From custom quests to exclusive features, there will always be something exciting to explore. 💰 No Pay-to-Win Skill and strategy matter most here. Enjoy a balanced gameplay environment where your achievements come from effort, not your wallet. 🌍 A Massive Community With 2000+ players expected, join a vibrant and active community of like-minded adventurers ready to conquer the world of Aden. 🏆 Fair and Competitive Gameplay Our systems are designed to promote healthy competition while avoiding abusive mechanics and exploits. 🔧 Professional Development From advanced bug fixes to carefully curated content, we pride ourselves on smooth performance, no lag, and unparalleled server quality. Key Features Chronicle: High Five with unique interface Rate: Dynamic x10 rates Class Balance: Carefully fine-tuned for a fair experience PvP Focused: PvP Ranking & aura display effect for 3 Top PvPers every week Custom Events: Seasonal and permanent events to keep you engaged Additional Features:   Custom Endgame Content: Introduce unique dungeons, raids, or zones unavailable in other servers. Player-Driven Economy: Implement a strong market system and avoid overinflated drops or rewards. Epic Siege Battles: Announce special large-scale sieges and PvP events. Incentives for Streamers and Clans: Attract influencers and big clans to boost server publicity. Roadmap Transparency: Share a public roadmap of planned updates to build trust and excitemen   Here you can read all the features: https://l2soe.com/features   Video preview: Join the Revolution! This is your chance to be part of something legendary. L2 Saga of Eternia is not just a server; it’s a movement to redefine what Lineage 2 can be. Whether you’re a seasoned veteran or a newcomer to the world of Aden, we invite you to experience Lineage 2 at its finest.   Official Launch Date: December 6th 2024 Website: https://l2soe.com/ Facebook: https://www.facebook.com/l2soe Discord: https://discord.com/invite/l2eternia   Let’s build the ultimate Lineage 2 experience together. See you in-game! 🎮
    • That's like a tutorial on how to run l2 on MacOS Xd but good job for the investigation. 
  • Topics

×
×
  • Create New...