Jump to content

Monument Statuet Pvp/pk 24H


Recommended Posts

Good afternoon to all of Maxcheaters, I come here to post you the original Statuet Monument, it was removed from L2JDX and do not know who is the credits, make good avail.

 

 

 

Index: config/functions/l2jfrozen.properties
===================================================================
--- config/functions/l2jfrozen.properties	(revisão 1118)
+++ config/functions/l2jfrozen.properties	(cópia de trabalho)
@@ -281,4 +281,22 @@
 ProtectorSkillLevel = 13
 ProtectorSkillTime = 600
 # Npc Protector Message
-ProtectorMessage = Hey You!, Never Kill On This Area, Go Read The Rules!
\ No newline at end of file
+ProtectorMessage = Hey You!, Never Kill On This Area, Go Read The Rules!
+
+
+# -----------------------------------------
+# Monument NPC By TOP PvP and PK  -
+# -----------------------------------------
+#Event created
+#Evento monument statuet ativo
+EnableMonumentStatuetEvent = false
+
+#Data para a troca da estatua
+#Default: 12:00
+RateRefreshStatuet = 06:15
+
+#NOTE: Npc id deve estar presente em npc_to_pc_polymorph
+#Npc que para PVP
+TemplatePVP = 77559
+#Npc para PK
+TemplatePK = 77558
Index: head-src/com/l2jfrozen/Config.java
===================================================================
--- head-src/com/l2jfrozen/Config.java	(revisão 1118)
+++ head-src/com/l2jfrozen/Config.java	(cópia de trabalho)
@@ -2427,6 +2427,10 @@
 	public static String FARM2_CUSTOM_MESSAGE;
 	public static String PVP1_CUSTOM_MESSAGE;
 	public static String PVP2_CUSTOM_MESSAGE;
+	public static boolean EVENT_MONUMENT_STATUET;
+	public static String RATE_HOUR_STATUET_REFRESH;
+	public static int NPC_TEMPLATE_ID_PK;
+	public static int NPC_TEMPLATE_ID_PVP;
 	
 	// ============================================================
 	public static void loadL2JFrozenConfig()
@@ -2445,6 +2449,11 @@
 			SAVE_GMSPAWN_ON_CUSTOM = Boolean.valueOf(L2JFrozenSettings.getProperty("SaveGmSpawnOnCustom", "True"));
 			DELETE_GMSPAWN_ON_CUSTOM = Boolean.valueOf(L2JFrozenSettings.getProperty("DeleteGmSpawnOnCustom", "True"));
 			
+		    EVENT_MONUMENT_STATUET = Boolean.parseBoolean(L2JFrozenSettings.getProperty("EnableMonumentStatuetEvent", "false"));
+		    RATE_HOUR_STATUET_REFRESH = L2JFrozenSettings.getProperty("RateRefreshStatuet", "12:00");
+		    NPC_TEMPLATE_ID_PVP = Integer.parseInt(L2JFrozenSettings.getProperty("TemplatePVP", "77558"));
+		    NPC_TEMPLATE_ID_PK = Integer.parseInt(L2JFrozenSettings.getProperty("TemplatePK", "77559"));
+			
 			ONLINE_PLAYERS_ON_LOGIN = Boolean.valueOf(L2JFrozenSettings.getProperty("OnlineOnLogin", "False"));
 			SHOW_SERVER_VERSION = Boolean.valueOf(L2JFrozenSettings.getProperty("ShowServerVersion", "False"));
 			
Index: head-src/com/l2jfrozen/gameserver/GameServer.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/GameServer.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/GameServer.java	(cópia de trabalho)
@@ -131,6 +131,7 @@
 import com.l2jfrozen.gameserver.model.entity.siege.clanhalls.FortressOfResistance;
 import com.l2jfrozen.gameserver.model.multisell.L2Multisell;
 import com.l2jfrozen.gameserver.model.spawn.AutoSpawn;
+import com.l2jfrozen.gameserver.monumentstatuet.EventMonumentStatuet;
 import com.l2jfrozen.gameserver.network.L2GameClient;
 import com.l2jfrozen.gameserver.network.L2GamePacketHandler;
 import com.l2jfrozen.gameserver.powerpak.PowerPak;
@@ -574,6 +575,14 @@
 		else
 			LOGGER.info("All events are Disabled.");
 		
+	    if (Config.EVENT_MONUMENT_STATUET)
+	    {
+	      Util.printSection("Monument Statuet Event");
+	      EventMonumentStatuet.getInstance().load();
+	      EventMonumentStatuet.getInstance().ConfiguratePereiod();
+	      EventMonumentStatuet.getInstance().spawnStatuets();
+	    }
+		
 		if ((Config.OFFLINE_TRADE_ENABLE || Config.OFFLINE_CRAFT_ENABLE) && Config.RESTORE_OFFLINERS)
 			OfflineTradeTable.restoreOfflineTraders();
 		
Index: head-src/com/l2jfrozen/gameserver/managers/CustomNpcInstanceManager.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/managers/CustomNpcInstanceManager.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/managers/CustomNpcInstanceManager.java	(cópia de trabalho)
@@ -1,322 +1,247 @@
+/*
+ * L2jFrozen Project - www.l2jfrozen.com 
+ * 
+ * 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 com.l2jfrozen.gameserver.managers;
+ 
+import com.l2jfrozen.Config;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.DatabaseUtils;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+import com.l2jfrozen.util.random.Rnd;
+import java.sql.Connection;
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import javolution.util.FastMap;
+import org.apache.log4j.Logger;
+ 
+import com.l2jfrozen.Config;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.DatabaseUtils;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+import com.l2jfrozen.util.random.Rnd;
+
+/**
+ * control for Custom Npcs that look like players.
+ * @version 1.00
+ * @author Darki699
+ */
+ public final class CustomNpcInstanceManager
+ {
+  private static final Logger LOGGER = Logger.getLogger(CustomNpcInstanceManager.class);
+  private static CustomNpcInstanceManager _instance;
+  private FastMap<Integer, customInfo> spawns;
+  private FastMap<Integer, customInfo> templates;
+  
+  public final class customInfo
+  {
+    public String[] stringData = new String[2];
+    public int[] integerData = new int[27];
+    public boolean[] booleanData = new boolean[8];
+    
+    public customInfo() {}
+  }
+  
+  CustomNpcInstanceManager()
+  {
+    load();
+  }
+  
+  public static final CustomNpcInstanceManager getInstance()
+  {
+    if (_instance == null) {
+      _instance = new CustomNpcInstanceManager();
+    }
+    return _instance;
+  }
+  
+  public final void reload()
+  {
+    if (spawns != null) {
+      spawns.clear();
+    }
+    if (templates != null) {
+      templates.clear();
+    }
+    spawns = null;
+    templates = null;
+    
+    load();
+  }
+  
+  private final void load()
+  {
+    if ((spawns == null) || (templates == null))
+    {
+      spawns = new FastMap();
+      templates = new FastMap();
+    }
+    String[] SQL_ITEM_SELECTS = { "SELECT spawn,template,name,title,class_id,female,hair_style,hair_color,face,name_color,title_color, noble,hero,pvp,karma,wpn_enchant,right_hand,left_hand,gloves,chest,legs,feet,hair,hair2, pledge,cw_level,clan_id,ally_id,clan_crest,ally_crest,rnd_class,rnd_appearance,rnd_weapon,rnd_armor,max_rnd_enchant FROM npc_to_pc_polymorph" };
+    
+
+
+
+    Connection con = null;
+    try
+    {
+      int count = 0;
+      con = L2DatabaseFactory.getInstance().getConnection(false);
+      for (String selectQuery : SQL_ITEM_SELECTS)
+      {
+        PreparedStatement statement = con.prepareStatement(selectQuery);
+        ResultSet rset = statement.executeQuery();
+        while (rset.next())
+        {
+          count++;
+          customInfo ci = new customInfo();
+          ci.integerData[26] = rset.getInt("spawn");
+          ci.integerData[25] = rset.getInt("template");
+          try
+          {
+            ci.stringData[0] = rset.getString("name");
+            ci.stringData[1] = rset.getString("title");
+            ci.integerData[7] = rset.getInt("class_id");
+            
+            int PcSex = rset.getInt("female");
+            switch (PcSex)
+            {
+            case 0: 
+              ci.booleanData[3] = false;
+              break;
+            case 1: 
+              ci.booleanData[3] = true;
+              break;
+            default: 
+				ci.booleanData[3] = Rnd.get(100) > 50 ? true : false;
+            }
+            ci.integerData[19] = rset.getInt("hair_style");
+            ci.integerData[20] = rset.getInt("hair_color");
+            ci.integerData[21] = rset.getInt("face");
+            ci.integerData[22] = rset.getInt("name_color");
+            ci.integerData[23] = rset.getInt("title_color");
+            ci.booleanData[1] = rset.getInt("noble") > 0 ? true : false;
+            ci.booleanData[2] = rset.getInt("hero") > 0 ? true : false;
+            ci.booleanData[0] = rset.getInt("pvp") > 0 ? true : false;
+            ci.integerData[1] = rset.getInt("karma");
+            ci.integerData[8] = rset.getInt("wpn_enchant");
+            ci.integerData[11] = rset.getInt("right_hand");
+            ci.integerData[12] = rset.getInt("left_hand");
+            ci.integerData[13] = rset.getInt("gloves");
+            ci.integerData[14] = rset.getInt("chest");
+            ci.integerData[15] = rset.getInt("legs");
+            ci.integerData[16] = rset.getInt("feet");
+            ci.integerData[17] = rset.getInt("hair");
+            ci.integerData[18] = rset.getInt("hair2");
+            ci.integerData[9] = rset.getInt("pledge");
+            ci.integerData[10] = rset.getInt("cw_level");
+            ci.integerData[2] = rset.getInt("clan_id");
+            ci.integerData[3] = rset.getInt("ally_id");
+            ci.integerData[4] = rset.getInt("clan_crest");
+            ci.integerData[5] = rset.getInt("ally_crest");
+            ci.booleanData[4] = rset.getInt("rnd_class") > 0 ? true : false;
+            ci.booleanData[5] = rset.getInt("rnd_appearance") > 0 ? true : false;
+            ci.booleanData[6] = rset.getInt("rnd_weapon") > 0 ? true : false;
+            ci.booleanData[7] = rset.getInt("rnd_armor") > 0 ? true : false;
+            ci.integerData[24] = rset.getInt("max_rnd_enchant");
+            if ((ci.integerData[25] != 0) && (!templates.containsKey(Integer.valueOf(ci.integerData[25])))) {
+              templates.put(Integer.valueOf(ci.integerData[25]), ci);
+            }
+            if ((ci.integerData[25] == 0) && (!spawns.containsKey(Integer.valueOf(ci.integerData[26])))) {
+              spawns.put(Integer.valueOf(ci.integerData[26]), ci);
+            }
+          }
+          catch (Throwable t)
+          {
+            if (Config.ENABLE_ALL_EXCEPTIONS) {
+              t.printStackTrace();
+            }
+            LOGGER.warn("Failed to load Npc Morph data for Object Id: " + ci.integerData[26] + " template: " + ci.integerData[25]);
+          }
+          ci = null;
+        }
+        DatabaseUtils.close(statement);
+        statement = null;
+        DatabaseUtils.close(rset);
+        rset = null;
+      }
+      LOGGER.info("CustomNpcInstanceManager: loaded " + count + " NPC to PC polymorphs.");
+    }
+    catch (Exception e)
+    {
+      if (Config.ENABLE_ALL_EXCEPTIONS) {
+        e.printStackTrace();
+      }
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+  
+  public final boolean isThisL2CustomNpcInstance(int spwnId, int npcId)
+  {
+    if ((spwnId == 0) || (npcId == 0)) {
+      return false;
+    }
+    if (spawns.containsKey(Integer.valueOf(spwnId))) {
+      return true;
+    }
+    if (templates.containsKey(Integer.valueOf(npcId))) {
+      return true;
+    }
+    return false;
+  }
+  
+  public final customInfo getCustomData(int spwnId, int npcId)
+  {
+    if ((spwnId == 0) || (npcId == 0)) {
+      return null;
+    }
+    for (customInfo ci : spawns.values()) {
+      if ((ci != null) && (ci.integerData[26] == spwnId)) {
+        return ci;
+      }
+    }
+    for (customInfo ci : templates.values()) {
+      if ((ci != null) && (ci.integerData[25] == npcId)) {
+        return ci;
+      }
+    }
+    return null;
+  }
+  
+  public final FastMap<Integer, customInfo> getAllTemplates()
+  {
+    return templates;
+  }
+  
+  public final FastMap<Integer, customInfo> getAllSpawns()
+  {
+    return spawns;
+  }
+  
+  public final void updateRemoveInDB(customInfo ciToRemove) {}
+  
+  public final void AddInDB(customInfo ciToAdd)
+  {
+    String Query = "REPLACE INTO npc_to_pc_polymorph VALUES spawn,template,name,title,class_id,female,hair_style,hair_color,face,name_color,title_color, noble,hero,pvp,karma,wpn_enchant,right_hand,left_hand,gloves,chest,legs,feet,hair,hair2, pledge,cw_level,clan_id,ally_id,clan_crest,ally_crest,rnd_class,rnd_appearance,rnd_weapon,rnd_armor,max_rnd_enchant FROM npc_to_pc_polymorph";
+    
+    Connection con = null;
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection(false);
+      PreparedStatement statement = con.prepareStatement(Query);
+      ResultSet rset = statement.executeQuery();
+      
+      DatabaseUtils.close(statement);
+      statement = null;
+      while (rset.next())
+      {
+        customInfo ci = new customInfo();
+        ci.integerData[26] = rset.getInt("spawn");
+        ci.integerData[25] = rset.getInt("template");
+      }
+      DatabaseUtils.close(rset);
+      rset = null;
+      Query = null;
+    }
+    catch (Throwable t)
+    {
+      if (Config.ENABLE_ALL_EXCEPTIONS) {
+        t.printStackTrace();
+      }
+      LOGGER.warn("Could not add Npc Morph info into the DB: ");
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/model/actor/instance/L2CustomNpcInstance.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/model/actor/instance/L2CustomNpcInstance.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/model/actor/instance/L2CustomNpcInstance.java	(cópia de trabalho)
@@ -1,527 +1,347 @@
+/*
+ * L2jFrozen Project - www.l2jfrozen.com 
+ * 
+ * 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 com.l2jfrozen.gameserver.model.actor.instance;
+
+import com.l2jfrozen.gameserver.managers.CustomNpcInstanceManager;
+import com.l2jfrozen.gameserver.managers.CustomNpcInstanceManager.customInfo;
+import com.l2jfrozen.gameserver.model.base.ClassId;
+import com.l2jfrozen.gameserver.model.base.Race;
+import com.l2jfrozen.gameserver.model.spawn.L2Spawn;
+import com.l2jfrozen.gameserver.templates.L2WeaponType;
+import com.l2jfrozen.util.random.Rnd;
+
+/**
+ * This class manages Npc Polymorph into player instances, they look like regular players. This effect will show up on all clients.
+ * @author Darki699
+ */
+ public final class L2CustomNpcInstance
+ {
+  private boolean _allowRandomWeapons = true;
+  private boolean _allowRandomClass = true;
+  private boolean _allowRandomAppearance = true;
+  private String _name;
+  private String _title;
+  private int[] _int;
+  private boolean[] _boolean;
+  private L2NpcInstance _NpcInstance;
+  private ClassId _classId;
+  
+  public L2CustomNpcInstance(L2NpcInstance myNpc)
+  {
+    _NpcInstance = myNpc;
+    if (_NpcInstance == null) {
+      return;
+    }
+    if (_NpcInstance.getSpawn() == null) {
+      return;
+    }
+    initialize();
+  }
+  
+  private final void initialize()
+  {
+    _int = new int[25];
+    
+
+
+
+
+
+    _boolean = new boolean[4];
+    
+
+
+    CustomNpcInstanceManager.customInfo ci = CustomNpcInstanceManager.getInstance().getCustomData(_NpcInstance.getSpawn().getId(), _NpcInstance.getNpcId());
+    if (ci == null)
+    {
+      _NpcInstance.setCustomNpcInstance(null);
+      _NpcInstance = null;
+      return;
+    }
+    _NpcInstance.setCustomNpcInstance(this);
+    
+    setPcInstanceData(ci);
+    if (_allowRandomClass) {
+      chooseRandomClass();
+    }
+    if (_allowRandomAppearance) {
+      chooseRandomAppearance();
+    }
+    if (_allowRandomWeapons) {
+      chooseRandomWeapon();
+    }
+    ci = null;
+  }
+  
+  public final String getName()
+  {
+    return _name == null ? _NpcInstance.getName() : _name;
+  }
+  
+  public final String getTitle()
+  {
+    return _NpcInstance.isChampion() ? "The Champion" + _title : _title == null ? _NpcInstance.getTitle() : _title;
+  }
+  
+  public final int getKarma()
+  {
+    return _int[1] > 0 ? _int[1] : _NpcInstance.getAggroRange();
+  }
+  
+  public final int getClanId()
+  {
+    return _int[2];
+  }
+  
+  public final int getAllyId()
+  {
+    return _int[3];
+  }
+  
+  public final int getClanCrestId()
+  {
+    return _int[4];
+  }
+  
+  public final int getAllyCrestId()
+  {
+    return _int[5];
+  }
+  
+  public final int getRace()
+  {
+    return _int[6];
+  }
+  
+  public final int getClassId()
+  {
+    return _int[7];
+  }
+  
+  public final int getEnchantWeapon()
+  {
+    return _int[8] > 127 ? 127 : (PAPERDOLL_RHAND() == 0) || (getCursedWeaponLevel() != 0) ? 0 : _int[8];
+  }
+  
+  public final int getPledgeClass()
+  {
+    return _NpcInstance.isChampion() ? 8 : _int[9];
+  }
+  
+  public final int getCursedWeaponLevel()
+  {
+    return (PAPERDOLL_RHAND() == 0) || (_int[8] > 0) ? 0 : _int[10];
+  }
+  
+  public final int PAPERDOLL_RHAND()
+  {
+    return _int[11] != 0 ? _int[11] : _NpcInstance.getRightHandItem();
+  }
+  
+  public final int PAPERDOLL_LHAND()
+  {
+    return _int[12] == 0 ? _NpcInstance.getLeftHandItem() : _int[12] > 0 ? _int[12] : 0;
+  }
+  
+  public final int PAPERDOLL_GLOVES()
+  {
+    return _int[13];
+  }
+  
+  public final int PAPERDOLL_CHEST()
+  {
+    return _int[14];
+  }
+  
+  public final int PAPERDOLL_LEGS()
+  {
+    return _int[15];
+  }
+  
+  public final int PAPERDOLL_FEET()
+  {
+    return _int[16];
+  }
+  
+  public final int PAPERDOLL_HAIR()
+  {
+    return _int[17];
+  }
+  
+  public final int PAPERDOLL_HAIR2()
+  {
+    return _int[18];
+  }
+  
+  public final int getHairStyle()
+  {
+    return _int[19];
+  }
+  
+  public final int getHairColor()
+  {
+    return _int[20];
+  }
+  
+  public final int getFace()
+  {
+    return _int[21];
+  }
+  
+  public final int nameColor()
+  {
+    return _int[22] == 0 ? 16777215 : _int[22];
+  }
+  
+  public final int titleColor()
+  {
+    return _int[23] == 0 ? 16777079 : _int[23];
+  }
+  
+  public final boolean getPvpFlag()
+  {
+    return _boolean[0];
+  }
+  
+  public final int getHeading()
+  {
+    return _NpcInstance.getHeading();
+  }
+  
+  public final boolean isNoble()
+  {
+    return _boolean[1];
+  }
+  
+  public final boolean isHero()
+  {
+    return _boolean[2];
+  }
+  
+  public final boolean isFemaleSex()
+  {
+    return _boolean[3];
+  }
+  
+  private final void chooseRandomWeapon()
+  {
+    L2WeaponType wpnType = null;
+    
+    wpnType = Rnd.get(100) > 40 ? L2WeaponType.BOW : L2WeaponType.BOW;
+    
+    wpnType = L2WeaponType.BOW;
+    do
+    {
+      wpnType = L2WeaponType.values()[Rnd.get(L2WeaponType.values().length)];
+    } while ((wpnType == null) || 
+    
+
+
+      (wpnType == L2WeaponType.BOW) || (wpnType == L2WeaponType.BOW));
+    if ((_classId.getRace() == Race.human) || 
+    
+
+
+
+
+      (Rnd.get(100) < 10)) {}
+  }
+  
+  private final void chooseRandomClass()
+  {
+    for (;;)
+    {
+      _classId = ClassId.values()[Rnd.get(ClassId.values().length)];
+      if ((_classId != null) && 
+      
+
+
+        (_classId.getRace() != null) && (_classId.getParent() != null)) {
+        break;
+      }
+    }
+    _int[6] = _classId.getRace().ordinal();
+    _int[7] = _classId.getId();
+  }
+  
+  private final void chooseRandomAppearance()
+  {
+	  _boolean[1] = Rnd.get(100) < 15 ? true : false;
+	  _boolean[3] = Rnd.get(100) < 50 ? true : false;
+	  _int[22] = (_int[23] = 0);
+	  if (Rnd.get(100) < 5) {
+		  _int[22] = 255;
+	  } 
+	  else if (Rnd.get(100) < 5)
+	  {
+		  _int[22] = 65280;
+	  }
+	  if (Rnd.get(100) < 5) {
+		  _int[23] = 255;
+	  }
+	  else if (Rnd.get(100) < 5)
+	  {
+		  _int[23] = 65280;
+	  }
+	  _int[1] = (Rnd.get(100) > 10 ? 50 : Rnd.get(100) > 95 ? 0 : 1000);
+	  _int[19] = (Rnd.get(100) < 34 ? 1 : Rnd.get(100) < 34 ? 0 : 2);
+	  _int[20] = (Rnd.get(100) < 34 ? 1 : Rnd.get(100) < 34 ? 0 : 2);
+	  _int[21] = (Rnd.get(100) < 34 ? 1 : Rnd.get(100) < 34 ? 0 : 2);
+    
+    int pledgeLevel = Rnd.get(100);
+    if (pledgeLevel > 30) {
+      _int[9] = 1;
+    }
+    if (pledgeLevel > 50) {
+      _int[9] = 2;
+    }
+    if (pledgeLevel > 60) {
+      _int[9] = 3;
+    }
+    if (pledgeLevel > 80) {
+      _int[9] = 4;
+    }
+    if (pledgeLevel > 90) {
+      _int[9] = 5;
+    }
+    if (pledgeLevel > 95) {
+      _int[9] = 6;
+    }
+    if (pledgeLevel > 98) {
+      _int[9] = 7;
+    }
+  }
+  
+  public void setPcInstanceData(CustomNpcInstanceManager.customInfo ci)
+  {
+    if (ci == null) {
+      return;
+    }
+    for (int i = 0; i < 25; i++) {
+      _int[i] = ci.integerData[i];
+    }
+    for (int i = 0; i < 4; i++) {
+      _boolean[i] = ci.booleanData[i];
+    }
+    _allowRandomClass = ci.booleanData[4];
+    _allowRandomAppearance = ci.booleanData[5];
+    _allowRandomWeapons = ci.booleanData[6];
+    
+
+    _name = ci.stringData[0];
+    _title = ci.stringData[1];
+    if ((_name != null) && (_name.equals(""))) {
+      _name = null;
+    }
+    if ((_title != null) && (_title.equals(""))) {
+      _title = null;
+    }
+    ClassId[] ids = ClassId.values();
+    if (ids != null) {
+      for (ClassId id : ids) {
+        if (id != null) {
+          if (id.getId() == _int[7])
+          {
+            _classId = id;
+            _int[6] = id.getRace().ordinal();
+            break;
+          }
+        }
+      }
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/model/actor/instance/L2NpcInstance.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/model/actor/instance/L2NpcInstance.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/model/actor/instance/L2NpcInstance.java	(cópia de trabalho)
@@ -76,6 +76,7 @@
 import com.l2jfrozen.gameserver.model.scripts.L2RBManager;
 import com.l2jfrozen.gameserver.model.spawn.L2Spawn;
 import com.l2jfrozen.gameserver.model.zone.type.L2TownZone;
+import com.l2jfrozen.gameserver.monumentstatuet.EventMonumentStatuet;
 import com.l2jfrozen.gameserver.network.L2GameClient;
 import com.l2jfrozen.gameserver.network.SystemMessageId;
 import com.l2jfrozen.gameserver.network.serverpackets.ActionFailed;
@@ -116,6 +117,10 @@
 	
 	/** The interaction distance of the L2NpcInstance(is used as offset in MovetoLocation method). */
 	public static final int INTERACTION_DISTANCE = 150;
+
+	public boolean Monument_Npc_PVP = false;
+
+	public boolean Monument_Npc_PK = false;
 	
 	/** The Polymorph object that manage this L2NpcInstance's morph to a PcInstance... I wrote this line too =P Darki699 */
 	private L2CustomNpcInstance _customNpcInstance;
@@ -870,6 +875,14 @@
 					{
 						VIP.showEndHTML(player, String.valueOf(getObjectId()));
 					}
+			        else if (Monument_Npc_PK)
+			        {
+			            EventMonumentStatuet.getInstance().htmlPKnpc(player);
+			        }
+			        else if (Monument_Npc_PVP)
+			        {
+			            EventMonumentStatuet.getInstance().htmlPVPnpc(player);
+			        }
 					else
 					{
 						// Open a chat window on client with the text of the L2NpcInstance
Index: head-src/com/l2jfrozen/gameserver/monumentstatuet/EventMonumentStatuet.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/monumentstatuet/EventMonumentStatuet.java	(revisão 0)
+++ head-src/com/l2jfrozen/gameserver/monumentstatuet/EventMonumentStatuet.java	(cópia de trabalho)
@@ -0,0 +1,594 @@
+package com.l2jfrozen.gameserver.monumentstatuet;
+
+import java.sql.Connection;
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.util.Calendar;
+import java.util.Map;
+
+import javolution.util.FastMap;
+
+import com.l2jfrozen.Config;
+import com.l2jfrozen.gameserver.datatables.sql.ItemTable;
+import com.l2jfrozen.gameserver.datatables.sql.NpcTable;
+import com.l2jfrozen.gameserver.datatables.sql.SpawnTable;
+import com.l2jfrozen.gameserver.managers.CustomNpcInstanceManager;
+import com.l2jfrozen.gameserver.model.L2World;
+import com.l2jfrozen.gameserver.model.actor.instance.L2PcInstance;
+import com.l2jfrozen.gameserver.model.spawn.L2Spawn;
+import com.l2jfrozen.gameserver.network.serverpackets.MagicSkillUser;
+import com.l2jfrozen.gameserver.templates.L2Item;
+import com.l2jfrozen.gameserver.templates.L2NpcTemplate;
+import com.l2jfrozen.gameserver.thread.ThreadPoolManager;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+
+public class EventMonumentStatuet
+{
+  public static EventMonumentStatuet _instance;
+  public static L2Spawn PK_SPAWN;
+  public static L2Spawn PVP_SPAWN;
+  public boolean inPeriodOk = true;
+  private Map<Integer, int[]> startup_players;
+  private PreparedStatement statement;
+  
+  public EventMonumentStatuet()
+  {
+    startup_players = new FastMap();
+  }
+  
+  public static EventMonumentStatuet getInstance()
+  {
+    if (_instance == null) {
+      _instance = new EventMonumentStatuet();
+    }
+    return _instance;
+  }
+  
+  public void htmlPKnpc(L2PcInstance pl) {}
+  
+  public void htmlPVPnpc(L2PcInstance pl) {}
+  
+  public void spawnStatuets()
+  {
+    spawnNpcPVP();
+    spawnNpcPK();
+  }
+  
+  private static void spawnNpcPVP()
+  {
+    L2NpcTemplate tmpl = NpcTable.getInstance().getTemplate(Config.NPC_TEMPLATE_ID_PVP);
+    try
+    {
+      PVP_SPAWN = new L2Spawn(tmpl);
+      PVP_SPAWN.setLocx(83215);
+      PVP_SPAWN.setLocy(148393);
+      PVP_SPAWN.setLocz(-3373);
+      PVP_SPAWN.setAmount(1);
+      PVP_SPAWN.setRespawnDelay(1);
+      SpawnTable.getInstance().addNewSpawn(PVP_SPAWN, false);
+      PVP_SPAWN.init();
+      PVP_SPAWN.getLastSpawn().getStatus().setCurrentHp(999999999.0D);
+      PVP_SPAWN.getLastSpawn().isAggressive();
+      PVP_SPAWN.getLastSpawn().Monument_Npc_PVP = true;
+      PVP_SPAWN.getLastSpawn().decayMe();
+      PVP_SPAWN.getLastSpawn().spawnMe(PVP_SPAWN.getLastSpawn().getX(), PVP_SPAWN.getLastSpawn().getY(), PVP_SPAWN.getLastSpawn().getZ());
+      
+      PVP_SPAWN.getLastSpawn().broadcastPacket(new MagicSkillUser(PVP_SPAWN.getLastSpawn(), PVP_SPAWN.getLastSpawn(), 1034, 1, 1, 1));
+      
+      System.out.println("[EventMonumentStatuet]:Statue pvp spawned.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]:Fail to spawn statue pvp.");
+    }
+  }
+  
+  private static void spawnNpcPK()
+  {
+    L2NpcTemplate tmpl = NpcTable.getInstance().getTemplate(Config.NPC_TEMPLATE_ID_PK);
+    try
+    {
+      PK_SPAWN = new L2Spawn(tmpl);
+      PK_SPAWN.setLocx(83220);
+      PK_SPAWN.setLocy(147909);
+      PK_SPAWN.setLocz(-3373);
+      PK_SPAWN.setAmount(1);
+      PK_SPAWN.setRespawnDelay(1);
+      SpawnTable.getInstance().addNewSpawn(PK_SPAWN, false);
+      PK_SPAWN.init();
+      PK_SPAWN.getLastSpawn().getStatus().setCurrentHp(999999999.0D);
+      PK_SPAWN.getLastSpawn().isAggressive();
+      PK_SPAWN.getLastSpawn().Monument_Npc_PK = true;
+      PK_SPAWN.getLastSpawn().decayMe();
+      PK_SPAWN.getLastSpawn().spawnMe(PK_SPAWN.getLastSpawn().getX(), PK_SPAWN.getLastSpawn().getY(), PK_SPAWN.getLastSpawn().getZ());
+      
+      PK_SPAWN.getLastSpawn().broadcastPacket(new MagicSkillUser(PK_SPAWN.getLastSpawn(), PK_SPAWN.getLastSpawn(), 1034, 1, 1, 1));
+      
+      System.out.println("[EventMonumentStatuet]:Statue pk spawned.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]:Fail to spawn statue pk.");
+    }
+    finally
+    {
+      tmpl = null;
+    }
+  }
+  
+  public void reloadAllNpc()
+  {
+    unspawnNpcPK();
+    unspawnNpcPVP();
+    
+    PK_SPAWN = null;
+    PVP_SPAWN = null;
+    
+    spawnNpcPK();
+    spawnNpcPVP();
+  }
+  
+  private static void unspawnNpcPK()
+  {
+    if ((PK_SPAWN == null) || (PK_SPAWN.getLastSpawn() == null)) {
+      return;
+    }
+    PK_SPAWN.getLastSpawn().deleteMe();
+    PK_SPAWN.stopRespawn();
+    SpawnTable.getInstance().deleteSpawn(PK_SPAWN, true);
+  }
+  
+  private static void unspawnNpcPVP()
+  {
+    if ((PVP_SPAWN == null) || (PVP_SPAWN.getLastSpawn() == null)) {
+      return;
+    }
+    PVP_SPAWN.getLastSpawn().deleteMe();
+    PVP_SPAWN.stopRespawn();
+    SpawnTable.getInstance().deleteSpawn(PVP_SPAWN, true);
+  }
+  
+  public void onEnterPlayer(L2PcInstance pl)
+  {
+    if ((inPeriodOk) && (startup_players.get(Integer.valueOf(pl.getObjectId())) == null))
+    {
+      int[] stats = { pl.getObjectId(), pl.getPvpKills(), pl.getPkKills() };
+      startup_players.put(Integer.valueOf(pl.getObjectId()), stats);
+      storeInDataInfo(pl);
+    }
+  }
+  
+  public void ConfiguratePereiod()
+  {
+    String hour = Config.RATE_HOUR_STATUET_REFRESH.split(":")[0];
+    String minutes = Config.RATE_HOUR_STATUET_REFRESH.split(":")[1];
+    
+    int h = 0;int m = 0;
+    long timeL = 0L;
+    try
+    {
+      h = Integer.valueOf(hour).intValue();
+      m = Integer.valueOf(minutes).intValue();
+      Calendar currentTime = Calendar.getInstance();
+      Calendar testStartTime = Calendar.getInstance();
+      testStartTime.setLenient(true);
+      
+      testStartTime.set(11, h);
+      testStartTime.set(12, m);
+      testStartTime.set(13, 0);
+      if (testStartTime.getTimeInMillis() < currentTime.getTimeInMillis()) {
+        testStartTime.add(5, 1);
+      }
+      timeL = testStartTime.getTimeInMillis() - currentTime.getTimeInMillis();
+      
+      ThreadPoolManager.getInstance().scheduleGeneral(new refreshStatuet(), timeL);
+      
+      System.out.println("[EventMonumentStatuet]Periodo to refresh statuet: " + testStartTime.getTime());
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]:ConfiguratePereiod()]Fail to load period");
+      e.printStackTrace();
+    }
+  }
+  
+  private void storeInDataInfo(L2PcInstance pl)
+  {
+    Connection con = null;
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement("INSERT INTO monuments_startup (obj_id, pvp, pk) VALUES (?, ? , ?)");
+      statement.setInt(1, pl.getObjectId());
+      statement.setInt(2, pl.getPvpKills());
+      statement.setInt(3, pl.getPkKills());
+      statement.execute();
+      statement.close();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in store!");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+  
+  public void load()
+  {
+    Connection con = null;
+    String SQL = "SELECT obj_id, pvp, pk FROM monuments_startup ORDER BY obj_id";
+    if (startup_players.isEmpty()) {
+      startup_players.clear();
+    }
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement(SQL);
+      
+      ResultSet rs = statement.executeQuery();
+      while (rs.next())
+      {
+        int obj_id = rs.getInt("obj_id");
+        int pvp = rs.getInt("pvp");
+        int pk = rs.getInt("pk");
+        
+        int[] stats = { obj_id, pvp, pk };
+        startup_players.put(Integer.valueOf(obj_id), stats);
+      }
+      statement.close();
+      rs.close();
+      
+      System.out.println("[EventMonumentStatuet]Loaded " + startup_players.size() + " competitors.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in load competitors!");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+  
+  public void StartNewPeriod()
+  {
+    String monuments_startup_del = "TRUNCATE TABLE monuments_startup";
+    
+
+    Connection con = null;
+    statement = null;
+    try
+    {
+      System.out.println("[EventMonumentStatuet]Delete all elements from table monuments_startup.");
+      con = L2DatabaseFactory.getInstance().getConnection();
+      statement = con.prepareStatement(monuments_startup_del);
+      statement.execute();
+      try
+      {
+        statement.close();
+        
+        CloseUtil.close(con);
+        con = null;
+        
+        statement = null;
+        monuments_startup_del = null;
+      }
+      catch (Exception e) {}
+      startup_players.clear();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in delete all elements from table monuments_startup.");
+      e.printStackTrace();
+    }
+    finally
+    {
+      try
+      {
+        statement.close();
+        
+        CloseUtil.close(con);
+        con = null;
+        
+        statement = null;
+        monuments_startup_del = null;
+      }
+      catch (Exception e) {}
+    }
+    System.out.println("[EventMonumentStatuet]Adding all objects online.");
+    int[] stats = new int[3];
+    for (L2PcInstance pl : L2World.getInstance().getAllPlayers())
+    {
+      stats[0] = pl.getObjectId();
+      stats[1] = pl.getPvpKills();
+      stats[2] = pl.getPkKills();
+      
+      startup_players.put(Integer.valueOf(pl.getObjectId()), stats);
+      
+      storeInDataInfo(pl);
+    }
+    System.out.println("[EventMonumentStatuet]Added " + startup_players.size() + " objects online.");
+  }
+  
+  private class refreshStatuet
+    implements Runnable
+  {
+    public refreshStatuet() {}
+    
+    public void run()
+    {
+      EventMonumentStatuet.this.inPeriodOk = false;
+      EventMonumentStatuet.this.CalculateWins();
+      EventMonumentStatuet.this.StartNewPeriod();
+      EventMonumentStatuet.this.inPeriodOk = true;
+    }
+  }
+  
+  public void CalculateWins()
+  {
+    if (startup_players.size() <= 1)
+    {
+      System.out.println("[EventMonumentStatuet]:No participants in event, no statue formed.");
+      return;
+    }
+    Connection con = null;
+    String SQL = "SELECT obj_Id, pvpkills, pkkills FROM characters WHERE";
+    
+    int count = 0;
+    for (int[] a : startup_players.values())
+    {
+      SQL = SQL + (count == 0 ? " obj_Id=" + a[0] : new StringBuilder().append(" or obj_Id=").append(a[0]).toString());
+      
+      count++;
+    }
+    int pvp_maior = 0;int pk_maior = 0;
+    int[] obj_pvp = { 0, 0 };int[] obj_pk = { 0, 0 };
+    System.out.println("[EventMonumentStatuet]:Calculando player wins.");
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement(SQL);
+      
+      ResultSet rs = statement.executeQuery();
+      while (rs.next())
+      {
+        int obj_id = rs.getInt("obj_id");
+        int pvp = rs.getInt("pvpkills");
+        int pk = rs.getInt("pkkills");
+        
+        int[] dados = (int[])startup_players.get(Integer.valueOf(obj_id));
+        
+        int diference_pvp = pvp - dados[1];
+        int diference_pk = pk - dados[2];
+        if (diference_pvp > pvp_maior)
+        {
+          pvp_maior = diference_pvp;
+          obj_pvp[0] = obj_id;
+          obj_pvp[1] = diference_pvp;
+        }
+        if (diference_pk > pk_maior)
+        {
+          pk_maior = diference_pk;
+          obj_pk[0] = obj_id;
+          obj_pk[1] = diference_pk;
+        }
+      }
+      statement.close();
+      rs.close();
+      System.out.println("[EventMonumentStatuet]:Wins a pvp player:" + obj_pvp[0] + " with " + obj_pvp[1] + " differ.");
+      System.out.println("[EventMonumentStatuet]:Wins a pk player:" + obj_pk[0] + " with " + obj_pk[1] + " differ.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in createPvpStatuet!");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+    createStatuet(obj_pvp, obj_pk);
+  }
+  
+  private void createStatuet(int[] dados_pvp, int[] dados_pk)
+  {
+    Connection con = null;
+    
+    Map<Integer, Items> items_mp_pvp = null;
+    Map<Integer, Items> items_mp_pk = null;
+    
+
+
+
+    L2Item item = null;
+    
+    System.out.println("[EventMonumentStatuet]: Creating map items for: " + dados_pvp[0] + " and " + dados_pk[0]);
+    if (dados_pvp[0] != 0)
+    {
+      String SQL = "SELECT item_id, enchant_level FROM items WHERE owner_id=" + dados_pvp[0] + " AND loc='PAPERDOLL'";
+      items_mp_pvp = new FastMap();
+      try
+      {
+        con = L2DatabaseFactory.getInstance().getConnection();
+        PreparedStatement st = con.prepareStatement(SQL);
+        ResultSet rs = st.executeQuery();
+        while (rs.next())
+        {
+          int item_id = rs.getInt("item_id");
+          int enchant_level = rs.getInt("enchant_level");
+          
+          item = ItemTable.getInstance().getTemplate(item_id);
+          if (item != null) {
+            if (item.getType2() == 0) {
+              items_mp_pvp.put(Integer.valueOf(items_mp_pvp.size() + 1), new Weapon(item_id, enchant_level, item.getBodyPart()));
+            } else if (item.getType2() == 2) {
+              items_mp_pvp.put(Integer.valueOf(items_mp_pvp.size() + 1), new Acessory(item_id, item.getBodyPart()));
+            } else if (item.getType2() == 1) {
+              items_mp_pvp.put(Integer.valueOf(items_mp_pvp.size() + 1), new ArmororShield(item_id, item.getBodyPart()));
+            }
+          }
+        }
+        st.close();
+        st = null;
+        rs.close();
+        rs = null;
+        
+        System.out.println("[EventMonumentStatuet]:Map Items pvp created with " + items_mp_pvp.size() + " items.");
+      }
+      catch (Exception e)
+      {
+    	  System.out.println("[EventMonumentStatuet]: Error in createStatuet 1:");
+        e.printStackTrace();
+      }
+      finally
+      {
+        CloseUtil.close(con);
+        con = null;
+      }
+    }
+    if (dados_pk[0] != 0)
+    {
+      items_mp_pk = new FastMap();
+      String SQL = "SELECT item_id, enchant_level FROM items WHERE owner_id=" + dados_pk[0] + " AND loc='PAPERDOLL'";
+      try
+      {
+        con = L2DatabaseFactory.getInstance().getConnection();
+        PreparedStatement st = con.prepareStatement(SQL);
+        ResultSet rs = st.executeQuery();
+        while (rs.next())
+        {
+          int item_id = rs.getInt("item_id");
+          int enchant_level = rs.getInt("enchant_level");
+          
+          item = ItemTable.getInstance().getTemplate(item_id);
+          if (item != null) {
+            if (item.getType2() == 0) {
+              items_mp_pk.put(Integer.valueOf(items_mp_pk.size() + 1), new Weapon(item_id, enchant_level, item.getBodyPart()));
+            } else if (item.getType2() == 2) {
+              items_mp_pk.put(Integer.valueOf(items_mp_pk.size() + 1), new Acessory(item_id, item.getBodyPart()));
+            } else if (item.getType2() == 1) {
+              items_mp_pk.put(Integer.valueOf(items_mp_pk.size() + 1), new ArmororShield(item_id, item.getBodyPart()));
+            }
+          }
+        }
+        st.close();
+        st = null;
+        rs.close();
+        rs = null;
+        
+        System.out.println("[EventMonumentStatuet]:Map Items pk created with " + items_mp_pk.size() + " items.");
+      }
+      catch (Exception e)
+      {
+    	  System.out.println("[EventMonumentStatuet]: Error in createStatuet 2:");
+        e.printStackTrace();
+      }
+      finally
+      {
+        CloseUtil.close(con);
+        con = null;
+      }
+    }
+    if ((items_mp_pvp != null) && (items_mp_pk != null))
+    {
+      System.out.println("[EventMonumentStatuet]:Calling data from the statue new MonumentCreator()");
+      MonumentCreator alpha = new MonumentCreator();
+      if (dados_pvp[0] != 0)
+      {
+        int[] dados_pvp_int = new int[3];
+        dados_pvp_int[0] = dados_pvp[0];
+        dados_pvp_int[1] = 1;
+        dados_pvp_int[2] = dados_pvp[1];
+        
+        alpha.create(dados_pvp_int, items_mp_pvp);
+        
+        alpha = null;
+      }
+      if (dados_pk[0] != 0)
+      {
+        int[] dados_pk_int = new int[3];
+        alpha = new MonumentCreator();
+        dados_pk_int[0] = dados_pk[0];
+        dados_pk_int[1] = 2;
+        dados_pk_int[2] = dados_pk[1];
+        
+        alpha.create(dados_pk_int, items_mp_pk);
+        
+        alpha = null;
+      }
+      CustomNpcInstanceManager.getInstance().reload();
+      
+      reloadAllNpc();
+    }
+  }
+  
+  public class Items
+  {
+    int _item_id;
+    int _slot;
+    
+    public Items(int item_id, int slot)
+    {
+      _item_id = item_id;
+      _slot = slot;
+    }
+    
+    public int getItemId()
+    {
+      return _item_id;
+    }
+    
+    public int getItemSlot()
+    {
+      return _slot;
+    }
+  }
+  
+  public class Weapon
+    extends EventMonumentStatuet.Items
+  {
+    int _enchant;
+    
+    public Weapon(int item_id, int enchant, int slot)
+    {
+      super(item_id, slot);
+      
+      System.out.println("Added weapon slot:" + slot);
+      _enchant = enchant;
+    }
+    
+    public int getItemEnchant()
+    {
+      return _enchant;
+    }
+  }
+  
+  public class ArmororShield
+    extends EventMonumentStatuet.Items
+  {
+    public ArmororShield(int item_id, int slot)
+    {
+      super(item_id, slot);
+    }
+  }
+  
+  public class Acessory
+    extends EventMonumentStatuet.Items
+  {
+    public Acessory(int item_id, int slot)
+    {
+      super(item_id, slot);
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/monumentstatuet/MonumentCreator.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/monumentstatuet/MonumentCreator.java	(revisão 0)
+++ head-src/com/l2jfrozen/gameserver/monumentstatuet/MonumentCreator.java	(cópia de trabalho)
@@ -0,0 +1,170 @@
+package com.l2jfrozen.gameserver.monumentstatuet;
+
+import com.l2jfrozen.Config;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+import java.sql.Connection;
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.util.Map;
+import javolution.util.FastMap;
+
+public class MonumentCreator
+{
+  int _right_hand = 0;
+  int _female = 0;
+  int _hair2 = 0;
+  int[] dados = new int[3];
+  int _class_id = 0;
+  int _hair_style = 0;
+  int _hair_color = 0;
+  int _face = 0;
+  int _hero = 0;
+  int _wpn_enchant = 0;
+  int _feet = 0;
+  int _left_hand = 0;
+  int _gloves = 0;
+  int _chest = 0;
+  int _legs = 0;
+  int _hair = 0;
+  String _name;
+  String _title;
+  FastMap<Integer, EventMonumentStatuet.Items> _items;
+  
+  public void create(int[] obj_id, Map<Integer, EventMonumentStatuet.Items> items)
+  {
+    dados = obj_id;
+    
+    _items = ((FastMap)items);
+    
+    load();
+  }
+  
+  private void load()
+  {
+    Connection con = null;
+    String SQL = "SELECT char_name,face,hairStyle,hairColor,sex,classid FROM characters WHERE obj_Id=" + dados[0];
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      PreparedStatement st = con.prepareStatement(SQL);
+      ResultSet rs = st.executeQuery();
+      while (rs.next())
+      {
+        _name = rs.getString("char_name");
+        _face = rs.getInt("face");
+        _hair_style = rs.getInt("hairStyle");
+        _hair_color = rs.getInt("hairColor");
+        _female = rs.getInt("sex");
+        _class_id = rs.getInt("classid");
+      }
+      st.close();
+      rs.close();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[MonumentCreator]: Error in load SQL FROM characters...");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+    System.out.println("[Form Monument]: Load info char ok...");
+    
+    _title = (dados[2] + " pk's in 24h");
+    for (EventMonumentStatuet.Items item : _items.values())
+    {
+      switch (item.getItemSlot())
+      {
+      case 16384: 
+        _left_hand = item.getItemId();
+        _right_hand = item.getItemId();
+        break;
+      case 128: 
+        _right_hand = item.getItemId();
+        break;
+      case 262144: 
+        _hair = item.getItemId();
+        break;
+      case 65536: 
+        _hair2 = item.getItemId();
+        break;
+      case 1024: 
+        _chest = item.getItemId();
+        break;
+      case 512: 
+        _gloves = item.getItemId();
+        break;
+      case 4096: 
+        _feet = item.getItemId();
+        break;
+      case 64: 
+        _hair = item.getItemId();
+        break;
+      case 32768: 
+        _chest = item.getItemId();
+        break;
+      case 2048: 
+        _legs = item.getItemId();
+      }
+      if ((item instanceof EventMonumentStatuet.Weapon)) {
+        _wpn_enchant = ((EventMonumentStatuet.Weapon)item).getItemEnchant();
+      }
+    }
+    System.out.println("[Form Monument]: Aparence information OK...");
+    
+    putIntoDb();
+    
+    System.out.println("[Form Monument]: Data Saved...");
+  }
+  
+  public void putIntoDb()
+  {
+    Connection con = null;
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement("UPDATE npc_to_pc_polymorph SET name=?,title=?,class_id=?,female=?,hair_style=?,hair_color=?,face=?,hero=?,wpn_enchant=?,right_hand=?,left_hand=?,gloves=?,chest=?,legs=?,feet=?,hair=?,hair2=? WHERE template=" + (dados[1] == 1 ? Config.NPC_TEMPLATE_ID_PVP : Config.NPC_TEMPLATE_ID_PK));
+      
+
+
+
+
+      statement.setString(1, _name);
+      statement.setString(2, _title);
+      statement.setInt(3, _class_id);
+      statement.setInt(4, _female);
+      statement.setInt(5, _hair_style);
+      statement.setInt(6, _hair_color);
+      statement.setInt(7, _face);
+      statement.setInt(8, _hero);
+      statement.setInt(9, _wpn_enchant);
+      statement.setInt(10, _right_hand);
+      statement.setInt(11, _left_hand);
+      
+      statement.setInt(12, _gloves);
+      statement.setInt(13, _chest);
+      statement.setInt(14, _legs);
+      statement.setInt(15, _feet);
+      
+      statement.setInt(16, _hair);
+      statement.setInt(17, _hair2);
+      
+      statement.execute();
+      statement.close();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[MonumentCreator]: Failt to putIntoDb...");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java	(cópia de trabalho)
@@ -71,6 +71,7 @@
 import com.l2jfrozen.gameserver.model.entity.siege.Siege;
 import com.l2jfrozen.gameserver.model.quest.Quest;
 import com.l2jfrozen.gameserver.model.quest.QuestState;
+import com.l2jfrozen.gameserver.monumentstatuet.EventMonumentStatuet;
 import com.l2jfrozen.gameserver.network.Disconnection;
 import com.l2jfrozen.gameserver.network.SystemMessageId;
 import com.l2jfrozen.gameserver.network.serverpackets.ClientSetTime;
@@ -417,6 +418,9 @@
 		if (DM._savePlayers.contains(activeChar.getName()))
 			DM.addDisconnectedPlayer(activeChar);
 		
+	    if (Config.EVENT_MONUMENT_STATUET) {
+	        EventMonumentStatuet.getInstance().onEnterPlayer(activeChar);
+	      }
 		// Means that it's not ok multiBox situation, so logout
 		if (!activeChar.checkMultiBox())
 		{
Index: head-src/com/l2jfrozen/gameserver/network/serverpackets/CustomNpcInfo.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/serverpackets/CustomNpcInfo.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/network/serverpackets/CustomNpcInfo.java	(cópia de trabalho)
@@ -1,153 +1,124 @@
+/*
+ * L2jFrozen Project - www.l2jfrozen.com 
+ * 
+ * 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 com.l2jfrozen.gameserver.network.serverpackets;
+ 
+import com.l2jfrozen.gameserver.datatables.sql.CharTemplateTable;
+import com.l2jfrozen.gameserver.model.actor.instance.L2NpcInstance;
+
+ public class CustomNpcInfo extends L2GameServerPacket
+  {
+  private static final String _S__03_CUSTOMNPCINFO = "[S] 03 CustomNpcInfo [dddddsddd dddddddddddd dddddddd hhhh d hhhhhhhhhhhh d hhhh hhhhhhhhhhhhhhhh dddddd dddddddd ffff ddd s ddddd ccccccc h c d c h ddd cc d ccc ddddddddddd]";
+  private final L2NpcInstance _activeChar;
+  
+  public CustomNpcInfo(L2NpcInstance cha)
+  {
+    _activeChar = cha;
+    _activeChar.setClientX(_activeChar.getPosition().getX());
+    _activeChar.setClientY(_activeChar.getPosition().getY());
+    _activeChar.setClientZ(_activeChar.getPosition().getZ());
+  }
+  
+  protected final void writeImpl()
+  {
+    writeC(3);
+    writeD(_activeChar.getX());
+    writeD(_activeChar.getY());
+    writeD(_activeChar.getZ());
+    writeD(_activeChar.getHeading());
+    writeD(_activeChar.getObjectId());
+    writeS(_activeChar.getCustomNpcInstance().getName());
+    writeD(_activeChar.getCustomNpcInstance().getRace());
+    writeD(_activeChar.getCustomNpcInstance().isFemaleSex() ? 1 : 0);
+    writeD(_activeChar.getCustomNpcInstance().getClassId());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR());
+    writeD(0);
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_RHAND());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_LHAND());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_GLOVES());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_CHEST());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_LEGS());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_FEET());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_RHAND());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR2());
+    write('H', 0, 24);
+    writeD(_activeChar.getCustomNpcInstance().getPvpFlag() ? 1 : 0);
+    writeD(_activeChar.getCustomNpcInstance().getKarma());
+    writeD(_activeChar.getMAtkSpd());
+    writeD(_activeChar.getPAtkSpd());
+    writeD(_activeChar.getCustomNpcInstance().getPvpFlag() ? 1 : 0);
+    writeD(_activeChar.getCustomNpcInstance().getKarma());
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed() / 2);
+    writeD(_activeChar.getRunSpeed() / 3);
+    writeD(_activeChar.getRunSpeed() / 3);
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed());
+    writeF(_activeChar.getStat().getMovementSpeedMultiplier());
+    writeF(_activeChar.getStat().getAttackSpeedMultiplier());
+    writeF(CharTemplateTable.getInstance().getTemplate(_activeChar.getCustomNpcInstance().getClassId()).getCollisionRadius());
+    writeF(CharTemplateTable.getInstance().getTemplate(_activeChar.getCustomNpcInstance().getClassId()).getCollisionHeight());
+    writeD(_activeChar.getCustomNpcInstance().getHairStyle());
+    writeD(_activeChar.getCustomNpcInstance().getHairColor());
+    writeD(_activeChar.getCustomNpcInstance().getFace());
+    writeS(_activeChar.getCustomNpcInstance().getTitle());
+    writeD(_activeChar.getCustomNpcInstance().getClanId());
+    writeD(_activeChar.getCustomNpcInstance().getClanCrestId());
+    writeD(_activeChar.getCustomNpcInstance().getAllyId());
+    writeD(_activeChar.getCustomNpcInstance().getAllyCrestId());
+    writeD(0);
+    writeC(1);
+    writeC(_activeChar.isRunning() ? 1 : 0);
+    writeC(_activeChar.isInCombat() ? 1 : 0);
+    writeC(_activeChar.isAlikeDead() ? 1 : 0);
+    write('C', 0, 3);
+    writeH(0);
+    writeC(0);
+    writeD(_activeChar.getAbnormalEffect());
+    writeC(0);
+    writeH(0);
+    writeD(_activeChar.getCustomNpcInstance().getClassId());
+    writeD(_activeChar.getMaxCp());
+    writeD((int)_activeChar.getStatus().getCurrentCp());
+    writeC(_activeChar.getCustomNpcInstance().getEnchantWeapon());
+    writeC(0);
+    writeD(0);
+    writeC(_activeChar.getCustomNpcInstance().isNoble() ? 1 : 0);
+    writeC(_activeChar.getCustomNpcInstance().isHero() ? 1 : 0);
+    writeC(0);
+    write('D', 0, 3);
+    writeD(_activeChar.getCustomNpcInstance().nameColor());
+    writeD(0);
+    writeD(_activeChar.getCustomNpcInstance().getPledgeClass());
+    writeD(0);
+    writeD(_activeChar.getCustomNpcInstance().titleColor());
+    writeD(0);
+  }
+  
+  public String getType()
+  {
+    return "[S] 03 CustomNpcInfo [dddddsddd dddddddddddd dddddddd hhhh d hhhhhhhhhhhh d hhhh hhhhhhhhhhhhhhhh dddddd dddddddd ffff ddd s ddddd ccccccc h c d c h ddd cc d ccc ddddddddddd]";
+  }
+  
+  private final void write(char type, int value, int times)
+  {
+    for (int i = 0; i < times; i++) {
+      switch (type)
+      {
+      case 'C': 
+        writeC(value);
+        break;
+      case 'D': 
+        writeD(value);
+        break;
+      case 'F': 
+        writeF(value);
+        break;
+      case 'H': 
+        writeH(value);
+      }
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/network/serverpackets/NpcInfoPoly.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/serverpackets/NpcInfoPoly.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/network/serverpackets/NpcInfoPoly.java	(cópia de trabalho)
+package com.l2jfrozen.gameserver.network.serverpackets;
+
+import com.l2jfrozen.gameserver.datatables.sql.NpcTable;
+import com.l2jfrozen.gameserver.model.L2Character;
+import com.l2jfrozen.gameserver.model.L2Object;
+import com.l2jfrozen.gameserver.model.actor.instance.L2ItemInstance;
+import com.l2jfrozen.gameserver.templates.L2NpcTemplate;
+
+public class NpcInfoPoly extends L2GameServerPacket
+{
+  private static final String _S__22_NPCINFO = "[S] 16 NpcInfo";
+  private L2Character _activeChar;
+  private final L2Object _obj;
+  private int _x;
+  private int _y;
+  private int _z;
+  private int _heading;
+  private final int _npcId;
+  private boolean _isAttackable;
+  private final boolean _isSummoned;
+  private boolean _isRunning;
+  private boolean _isInCombat;
+  private boolean _isAlikeDead;
+  private int _mAtkSpd;
+  private int _pAtkSpd;
+  private int _runSpd;
+  private int _walkSpd;
+  private int _swimRunSpd;
+  private int _swimWalkSpd;
+  private int _flRunSpd;
+  private int _flWalkSpd;
+  private int _flyRunSpd;
+  private int _flyWalkSpd;
+ private int _rhand;
+  private int _lhand;
+  private String _name;
+  private String _title;
+  private int _abnormalEffect;
+  L2NpcTemplate _template;
+  private final int _collisionRadius;
+  private final int _collisionHeight;
+ 
+  public NpcInfoPoly(L2Object obj, L2Character attacker)
+  {
+    _obj = obj;
+    _npcId = obj.getPoly().getPolyId();
+    _template = NpcTable.getInstance().getTemplate(_npcId);
+    _isAttackable = true;
+    _rhand = 0;
+    _lhand = 0;
+    _isSummoned = false;
+    _collisionRadius = _template.collisionRadius;
+    _collisionHeight = _template.collisionHeight;
+    if ((_obj instanceof L2Character))
+    {
+      _activeChar = ((L2Character)obj);
+      _isAttackable = obj.isAutoAttackable(attacker);
+      _rhand = _template.rhand;
+      _lhand = _template.lhand;
+    }
+    if ((_obj instanceof L2ItemInstance))
+    {
+      _x = _obj.getX();
+      _y = _obj.getY();
+      _z = _obj.getZ();
+      _heading = 0;
+      _mAtkSpd = 100;
+      _pAtkSpd = 100;
+      _runSpd = 120;
+      _walkSpd = 80;
+      _swimRunSpd = (_flRunSpd = _flyRunSpd = _runSpd);
+      _swimWalkSpd = (_flWalkSpd = _flyWalkSpd = _walkSpd);
+      _isRunning = (_isInCombat = _isAlikeDead = false);
+     _name = "item";
+      _title = "polymorphed";
+      _abnormalEffect = 0;
+    }
+    else
+    {
+      _x = _activeChar.getX();
+      _y = _activeChar.getY();
+      _z = _activeChar.getZ();
+      _heading = _activeChar.getHeading();
+      _mAtkSpd = _activeChar.getMAtkSpd();
+      _pAtkSpd = _activeChar.getPAtkSpd();
+      _runSpd = _activeChar.getRunSpeed();
+      _walkSpd = _activeChar.getWalkSpeed();
+      _swimRunSpd = (_flRunSpd = _flyRunSpd = _runSpd);
+      _swimWalkSpd = (_flWalkSpd = _flyWalkSpd = _walkSpd);
+      _isRunning = _activeChar.isRunning();
+      _isInCombat = _activeChar.isInCombat();
+      _isAlikeDead = _activeChar.isAlikeDead();
+      _name = _activeChar.getName();
+      _title = _activeChar.getTitle();
+      _abnormalEffect = _activeChar.getAbnormalEffect();
+    }
+  }
+  
+  protected final void writeImpl()
+  {
+    writeC(22);
+    writeD(_obj.getObjectId());
+    writeD(_npcId + 1000000);
+    writeD(_isAttackable ? 1 : 0);
+    writeD(_x);
+    writeD(_y);
+    writeD(_z);
+    writeD(_heading);
+    writeD(0);
+    writeD(_mAtkSpd);
+    writeD(_pAtkSpd);
+    writeD(_runSpd);
+    writeD(_walkSpd);
+    writeD(_swimRunSpd);
+    writeD(_swimWalkSpd);
+    writeD(_flRunSpd);
+    writeD(_flWalkSpd);
+    writeD(_flyRunSpd);
+    writeD(_flyWalkSpd);
+    writeF(1.0D);
+    writeF(1.0D);
+    writeF(_collisionRadius);
+    writeF(_collisionHeight);
+    writeD(_rhand);
+    writeD(0);
+    writeD(_lhand);
+    writeC(1);
+    writeC(_isRunning ? 1 : 0);
+    writeC(_isInCombat ? 1 : 0);
+    writeC(_isAlikeDead ? 1 : 0);
+    writeC(_isSummoned ? 2 : 0);
+    writeS(_name);
+    writeS(_title);
+    writeD(0);
+    writeD(0);
+    writeD(0);
+    
+    writeH(_abnormalEffect);
+    writeH(0);
+    writeD(0);
+    writeD(0);
+    writeD(0);
+    writeD(0);
+    writeC(0);
+  }
+  
+  public String getType()
+  {
+    return "[S] 16 NpcInfo";
+  }
+}

 

 

 

 

RW5oPX7.jpg

 

Thanks for providing the rev: Screenshot
Credit removal and adaptation: Tayran.Cannabis
Removing Source: L2JDX

Edited by le memer master
Link to comment
Share on other sites

  • 3 months later...
+    System.out.println("[Form Monument]: Load info char ok...");
+    
+    _title = (dados[2] + " pk's in 24h");
+    for (EventMonumentStatuet.Items item : _items.values())
+    {
+      switch (item.getItemSlot())
+      {
+      case 16384: 

there is a problem with the npc PvP, because only appears PK. If I'm right here lacks a line TITLE PVP?It is someone who can fix this error?

Link to comment
Share on other sites

  • 9 months later...

Great. Any similar for example for heros, best players...?? I search also for Gracia Final and HI5.

 

Regards!!

You have a base here with a little knowledge can be done..
Link to comment
Share on other sites

  • 4 months later...

Good afternoon to all of Maxcheaters, I come here to post you the original Statuet Monument, it was removed from L2JDX and do not know who is the credits, make good avail.

 

 

 

Index: config/functions/l2jfrozen.properties
===================================================================
--- config/functions/l2jfrozen.properties	(revisão 1118)
+++ config/functions/l2jfrozen.properties	(cópia de trabalho)
@@ -281,4 +281,22 @@
 ProtectorSkillLevel = 13
 ProtectorSkillTime = 600
 # Npc Protector Message
-ProtectorMessage = Hey You!, Never Kill On This Area, Go Read The Rules!
\ No newline at end of file
+ProtectorMessage = Hey You!, Never Kill On This Area, Go Read The Rules!
+
+
+# -----------------------------------------
+# Monument NPC By TOP PvP and PK  -
+# -----------------------------------------
+#Event created
+#Evento monument statuet ativo
+EnableMonumentStatuetEvent = false
+
+#Data para a troca da estatua
+#Default: 12:00
+RateRefreshStatuet = 06:15
+
+#NOTE: Npc id deve estar presente em npc_to_pc_polymorph
+#Npc que para PVP
+TemplatePVP = 77559
+#Npc para PK
+TemplatePK = 77558
Index: head-src/com/l2jfrozen/Config.java
===================================================================
--- head-src/com/l2jfrozen/Config.java	(revisão 1118)
+++ head-src/com/l2jfrozen/Config.java	(cópia de trabalho)
@@ -2427,6 +2427,10 @@
 	public static String FARM2_CUSTOM_MESSAGE;
 	public static String PVP1_CUSTOM_MESSAGE;
 	public static String PVP2_CUSTOM_MESSAGE;
+	public static boolean EVENT_MONUMENT_STATUET;
+	public static String RATE_HOUR_STATUET_REFRESH;
+	public static int NPC_TEMPLATE_ID_PK;
+	public static int NPC_TEMPLATE_ID_PVP;
 	
 	// ============================================================
 	public static void loadL2JFrozenConfig()
@@ -2445,6 +2449,11 @@
 			SAVE_GMSPAWN_ON_CUSTOM = Boolean.valueOf(L2JFrozenSettings.getProperty("SaveGmSpawnOnCustom", "True"));
 			DELETE_GMSPAWN_ON_CUSTOM = Boolean.valueOf(L2JFrozenSettings.getProperty("DeleteGmSpawnOnCustom", "True"));
 			
+		    EVENT_MONUMENT_STATUET = Boolean.parseBoolean(L2JFrozenSettings.getProperty("EnableMonumentStatuetEvent", "false"));
+		    RATE_HOUR_STATUET_REFRESH = L2JFrozenSettings.getProperty("RateRefreshStatuet", "12:00");
+		    NPC_TEMPLATE_ID_PVP = Integer.parseInt(L2JFrozenSettings.getProperty("TemplatePVP", "77558"));
+		    NPC_TEMPLATE_ID_PK = Integer.parseInt(L2JFrozenSettings.getProperty("TemplatePK", "77559"));
+			
 			ONLINE_PLAYERS_ON_LOGIN = Boolean.valueOf(L2JFrozenSettings.getProperty("OnlineOnLogin", "False"));
 			SHOW_SERVER_VERSION = Boolean.valueOf(L2JFrozenSettings.getProperty("ShowServerVersion", "False"));
 			
Index: head-src/com/l2jfrozen/gameserver/GameServer.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/GameServer.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/GameServer.java	(cópia de trabalho)
@@ -131,6 +131,7 @@
 import com.l2jfrozen.gameserver.model.entity.siege.clanhalls.FortressOfResistance;
 import com.l2jfrozen.gameserver.model.multisell.L2Multisell;
 import com.l2jfrozen.gameserver.model.spawn.AutoSpawn;
+import com.l2jfrozen.gameserver.monumentstatuet.EventMonumentStatuet;
 import com.l2jfrozen.gameserver.network.L2GameClient;
 import com.l2jfrozen.gameserver.network.L2GamePacketHandler;
 import com.l2jfrozen.gameserver.powerpak.PowerPak;
@@ -574,6 +575,14 @@
 		else
 			LOGGER.info("All events are Disabled.");
 		
+	    if (Config.EVENT_MONUMENT_STATUET)
+	    {
+	      Util.printSection("Monument Statuet Event");
+	      EventMonumentStatuet.getInstance().load();
+	      EventMonumentStatuet.getInstance().ConfiguratePereiod();
+	      EventMonumentStatuet.getInstance().spawnStatuets();
+	    }
+		
 		if ((Config.OFFLINE_TRADE_ENABLE || Config.OFFLINE_CRAFT_ENABLE) && Config.RESTORE_OFFLINERS)
 			OfflineTradeTable.restoreOfflineTraders();
 		
Index: head-src/com/l2jfrozen/gameserver/managers/CustomNpcInstanceManager.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/managers/CustomNpcInstanceManager.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/managers/CustomNpcInstanceManager.java	(cópia de trabalho)
@@ -1,322 +1,247 @@
+/*
+ * L2jFrozen Project - www.l2jfrozen.com 
+ * 
+ * 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 com.l2jfrozen.gameserver.managers;
+ 
+import com.l2jfrozen.Config;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.DatabaseUtils;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+import com.l2jfrozen.util.random.Rnd;
+import java.sql.Connection;
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import javolution.util.FastMap;
+import org.apache.log4j.Logger;
+ 
+import com.l2jfrozen.Config;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.DatabaseUtils;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+import com.l2jfrozen.util.random.Rnd;
+
+/**
+ * control for Custom Npcs that look like players.
+ * @version 1.00
+ * @author Darki699
+ */
+ public final class CustomNpcInstanceManager
+ {
+  private static final Logger LOGGER = Logger.getLogger(CustomNpcInstanceManager.class);
+  private static CustomNpcInstanceManager _instance;
+  private FastMap<Integer, customInfo> spawns;
+  private FastMap<Integer, customInfo> templates;
+  
+  public final class customInfo
+  {
+    public String[] stringData = new String[2];
+    public int[] integerData = new int[27];
+    public boolean[] booleanData = new boolean[8];
+    
+    public customInfo() {}
+  }
+  
+  CustomNpcInstanceManager()
+  {
+    load();
+  }
+  
+  public static final CustomNpcInstanceManager getInstance()
+  {
+    if (_instance == null) {
+      _instance = new CustomNpcInstanceManager();
+    }
+    return _instance;
+  }
+  
+  public final void reload()
+  {
+    if (spawns != null) {
+      spawns.clear();
+    }
+    if (templates != null) {
+      templates.clear();
+    }
+    spawns = null;
+    templates = null;
+    
+    load();
+  }
+  
+  private final void load()
+  {
+    if ((spawns == null) || (templates == null))
+    {
+      spawns = new FastMap();
+      templates = new FastMap();
+    }
+    String[] SQL_ITEM_SELECTS = { "SELECT spawn,template,name,title,class_id,female,hair_style,hair_color,face,name_color,title_color, noble,hero,pvp,karma,wpn_enchant,right_hand,left_hand,gloves,chest,legs,feet,hair,hair2, pledge,cw_level,clan_id,ally_id,clan_crest,ally_crest,rnd_class,rnd_appearance,rnd_weapon,rnd_armor,max_rnd_enchant FROM npc_to_pc_polymorph" };
+    
+
+
+
+    Connection con = null;
+    try
+    {
+      int count = 0;
+      con = L2DatabaseFactory.getInstance().getConnection(false);
+      for (String selectQuery : SQL_ITEM_SELECTS)
+      {
+        PreparedStatement statement = con.prepareStatement(selectQuery);
+        ResultSet rset = statement.executeQuery();
+        while (rset.next())
+        {
+          count++;
+          customInfo ci = new customInfo();
+          ci.integerData[26] = rset.getInt("spawn");
+          ci.integerData[25] = rset.getInt("template");
+          try
+          {
+            ci.stringData[0] = rset.getString("name");
+            ci.stringData[1] = rset.getString("title");
+            ci.integerData[7] = rset.getInt("class_id");
+            
+            int PcSex = rset.getInt("female");
+            switch (PcSex)
+            {
+            case 0: 
+              ci.booleanData[3] = false;
+              break;
+            case 1: 
+              ci.booleanData[3] = true;
+              break;
+            default: 
+				ci.booleanData[3] = Rnd.get(100) > 50 ? true : false;
+            }
+            ci.integerData[19] = rset.getInt("hair_style");
+            ci.integerData[20] = rset.getInt("hair_color");
+            ci.integerData[21] = rset.getInt("face");
+            ci.integerData[22] = rset.getInt("name_color");
+            ci.integerData[23] = rset.getInt("title_color");
+            ci.booleanData[1] = rset.getInt("noble") > 0 ? true : false;
+            ci.booleanData[2] = rset.getInt("hero") > 0 ? true : false;
+            ci.booleanData[0] = rset.getInt("pvp") > 0 ? true : false;
+            ci.integerData[1] = rset.getInt("karma");
+            ci.integerData[8] = rset.getInt("wpn_enchant");
+            ci.integerData[11] = rset.getInt("right_hand");
+            ci.integerData[12] = rset.getInt("left_hand");
+            ci.integerData[13] = rset.getInt("gloves");
+            ci.integerData[14] = rset.getInt("chest");
+            ci.integerData[15] = rset.getInt("legs");
+            ci.integerData[16] = rset.getInt("feet");
+            ci.integerData[17] = rset.getInt("hair");
+            ci.integerData[18] = rset.getInt("hair2");
+            ci.integerData[9] = rset.getInt("pledge");
+            ci.integerData[10] = rset.getInt("cw_level");
+            ci.integerData[2] = rset.getInt("clan_id");
+            ci.integerData[3] = rset.getInt("ally_id");
+            ci.integerData[4] = rset.getInt("clan_crest");
+            ci.integerData[5] = rset.getInt("ally_crest");
+            ci.booleanData[4] = rset.getInt("rnd_class") > 0 ? true : false;
+            ci.booleanData[5] = rset.getInt("rnd_appearance") > 0 ? true : false;
+            ci.booleanData[6] = rset.getInt("rnd_weapon") > 0 ? true : false;
+            ci.booleanData[7] = rset.getInt("rnd_armor") > 0 ? true : false;
+            ci.integerData[24] = rset.getInt("max_rnd_enchant");
+            if ((ci.integerData[25] != 0) && (!templates.containsKey(Integer.valueOf(ci.integerData[25])))) {
+              templates.put(Integer.valueOf(ci.integerData[25]), ci);
+            }
+            if ((ci.integerData[25] == 0) && (!spawns.containsKey(Integer.valueOf(ci.integerData[26])))) {
+              spawns.put(Integer.valueOf(ci.integerData[26]), ci);
+            }
+          }
+          catch (Throwable t)
+          {
+            if (Config.ENABLE_ALL_EXCEPTIONS) {
+              t.printStackTrace();
+            }
+            LOGGER.warn("Failed to load Npc Morph data for Object Id: " + ci.integerData[26] + " template: " + ci.integerData[25]);
+          }
+          ci = null;
+        }
+        DatabaseUtils.close(statement);
+        statement = null;
+        DatabaseUtils.close(rset);
+        rset = null;
+      }
+      LOGGER.info("CustomNpcInstanceManager: loaded " + count + " NPC to PC polymorphs.");
+    }
+    catch (Exception e)
+    {
+      if (Config.ENABLE_ALL_EXCEPTIONS) {
+        e.printStackTrace();
+      }
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+  
+  public final boolean isThisL2CustomNpcInstance(int spwnId, int npcId)
+  {
+    if ((spwnId == 0) || (npcId == 0)) {
+      return false;
+    }
+    if (spawns.containsKey(Integer.valueOf(spwnId))) {
+      return true;
+    }
+    if (templates.containsKey(Integer.valueOf(npcId))) {
+      return true;
+    }
+    return false;
+  }
+  
+  public final customInfo getCustomData(int spwnId, int npcId)
+  {
+    if ((spwnId == 0) || (npcId == 0)) {
+      return null;
+    }
+    for (customInfo ci : spawns.values()) {
+      if ((ci != null) && (ci.integerData[26] == spwnId)) {
+        return ci;
+      }
+    }
+    for (customInfo ci : templates.values()) {
+      if ((ci != null) && (ci.integerData[25] == npcId)) {
+        return ci;
+      }
+    }
+    return null;
+  }
+  
+  public final FastMap<Integer, customInfo> getAllTemplates()
+  {
+    return templates;
+  }
+  
+  public final FastMap<Integer, customInfo> getAllSpawns()
+  {
+    return spawns;
+  }
+  
+  public final void updateRemoveInDB(customInfo ciToRemove) {}
+  
+  public final void AddInDB(customInfo ciToAdd)
+  {
+    String Query = "REPLACE INTO npc_to_pc_polymorph VALUES spawn,template,name,title,class_id,female,hair_style,hair_color,face,name_color,title_color, noble,hero,pvp,karma,wpn_enchant,right_hand,left_hand,gloves,chest,legs,feet,hair,hair2, pledge,cw_level,clan_id,ally_id,clan_crest,ally_crest,rnd_class,rnd_appearance,rnd_weapon,rnd_armor,max_rnd_enchant FROM npc_to_pc_polymorph";
+    
+    Connection con = null;
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection(false);
+      PreparedStatement statement = con.prepareStatement(Query);
+      ResultSet rset = statement.executeQuery();
+      
+      DatabaseUtils.close(statement);
+      statement = null;
+      while (rset.next())
+      {
+        customInfo ci = new customInfo();
+        ci.integerData[26] = rset.getInt("spawn");
+        ci.integerData[25] = rset.getInt("template");
+      }
+      DatabaseUtils.close(rset);
+      rset = null;
+      Query = null;
+    }
+    catch (Throwable t)
+    {
+      if (Config.ENABLE_ALL_EXCEPTIONS) {
+        t.printStackTrace();
+      }
+      LOGGER.warn("Could not add Npc Morph info into the DB: ");
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/model/actor/instance/L2CustomNpcInstance.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/model/actor/instance/L2CustomNpcInstance.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/model/actor/instance/L2CustomNpcInstance.java	(cópia de trabalho)
@@ -1,527 +1,347 @@
+/*
+ * L2jFrozen Project - www.l2jfrozen.com 
+ * 
+ * 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 com.l2jfrozen.gameserver.model.actor.instance;
+
+import com.l2jfrozen.gameserver.managers.CustomNpcInstanceManager;
+import com.l2jfrozen.gameserver.managers.CustomNpcInstanceManager.customInfo;
+import com.l2jfrozen.gameserver.model.base.ClassId;
+import com.l2jfrozen.gameserver.model.base.Race;
+import com.l2jfrozen.gameserver.model.spawn.L2Spawn;
+import com.l2jfrozen.gameserver.templates.L2WeaponType;
+import com.l2jfrozen.util.random.Rnd;
+
+/**
+ * This class manages Npc Polymorph into player instances, they look like regular players. This effect will show up on all clients.
+ * @author Darki699
+ */
+ public final class L2CustomNpcInstance
+ {
+  private boolean _allowRandomWeapons = true;
+  private boolean _allowRandomClass = true;
+  private boolean _allowRandomAppearance = true;
+  private String _name;
+  private String _title;
+  private int[] _int;
+  private boolean[] _boolean;
+  private L2NpcInstance _NpcInstance;
+  private ClassId _classId;
+  
+  public L2CustomNpcInstance(L2NpcInstance myNpc)
+  {
+    _NpcInstance = myNpc;
+    if (_NpcInstance == null) {
+      return;
+    }
+    if (_NpcInstance.getSpawn() == null) {
+      return;
+    }
+    initialize();
+  }
+  
+  private final void initialize()
+  {
+    _int = new int[25];
+    
+
+
+
+
+
+    _boolean = new boolean[4];
+    
+
+
+    CustomNpcInstanceManager.customInfo ci = CustomNpcInstanceManager.getInstance().getCustomData(_NpcInstance.getSpawn().getId(), _NpcInstance.getNpcId());
+    if (ci == null)
+    {
+      _NpcInstance.setCustomNpcInstance(null);
+      _NpcInstance = null;
+      return;
+    }
+    _NpcInstance.setCustomNpcInstance(this);
+    
+    setPcInstanceData(ci);
+    if (_allowRandomClass) {
+      chooseRandomClass();
+    }
+    if (_allowRandomAppearance) {
+      chooseRandomAppearance();
+    }
+    if (_allowRandomWeapons) {
+      chooseRandomWeapon();
+    }
+    ci = null;
+  }
+  
+  public final String getName()
+  {
+    return _name == null ? _NpcInstance.getName() : _name;
+  }
+  
+  public final String getTitle()
+  {
+    return _NpcInstance.isChampion() ? "The Champion" + _title : _title == null ? _NpcInstance.getTitle() : _title;
+  }
+  
+  public final int getKarma()
+  {
+    return _int[1] > 0 ? _int[1] : _NpcInstance.getAggroRange();
+  }
+  
+  public final int getClanId()
+  {
+    return _int[2];
+  }
+  
+  public final int getAllyId()
+  {
+    return _int[3];
+  }
+  
+  public final int getClanCrestId()
+  {
+    return _int[4];
+  }
+  
+  public final int getAllyCrestId()
+  {
+    return _int[5];
+  }
+  
+  public final int getRace()
+  {
+    return _int[6];
+  }
+  
+  public final int getClassId()
+  {
+    return _int[7];
+  }
+  
+  public final int getEnchantWeapon()
+  {
+    return _int[8] > 127 ? 127 : (PAPERDOLL_RHAND() == 0) || (getCursedWeaponLevel() != 0) ? 0 : _int[8];
+  }
+  
+  public final int getPledgeClass()
+  {
+    return _NpcInstance.isChampion() ? 8 : _int[9];
+  }
+  
+  public final int getCursedWeaponLevel()
+  {
+    return (PAPERDOLL_RHAND() == 0) || (_int[8] > 0) ? 0 : _int[10];
+  }
+  
+  public final int PAPERDOLL_RHAND()
+  {
+    return _int[11] != 0 ? _int[11] : _NpcInstance.getRightHandItem();
+  }
+  
+  public final int PAPERDOLL_LHAND()
+  {
+    return _int[12] == 0 ? _NpcInstance.getLeftHandItem() : _int[12] > 0 ? _int[12] : 0;
+  }
+  
+  public final int PAPERDOLL_GLOVES()
+  {
+    return _int[13];
+  }
+  
+  public final int PAPERDOLL_CHEST()
+  {
+    return _int[14];
+  }
+  
+  public final int PAPERDOLL_LEGS()
+  {
+    return _int[15];
+  }
+  
+  public final int PAPERDOLL_FEET()
+  {
+    return _int[16];
+  }
+  
+  public final int PAPERDOLL_HAIR()
+  {
+    return _int[17];
+  }
+  
+  public final int PAPERDOLL_HAIR2()
+  {
+    return _int[18];
+  }
+  
+  public final int getHairStyle()
+  {
+    return _int[19];
+  }
+  
+  public final int getHairColor()
+  {
+    return _int[20];
+  }
+  
+  public final int getFace()
+  {
+    return _int[21];
+  }
+  
+  public final int nameColor()
+  {
+    return _int[22] == 0 ? 16777215 : _int[22];
+  }
+  
+  public final int titleColor()
+  {
+    return _int[23] == 0 ? 16777079 : _int[23];
+  }
+  
+  public final boolean getPvpFlag()
+  {
+    return _boolean[0];
+  }
+  
+  public final int getHeading()
+  {
+    return _NpcInstance.getHeading();
+  }
+  
+  public final boolean isNoble()
+  {
+    return _boolean[1];
+  }
+  
+  public final boolean isHero()
+  {
+    return _boolean[2];
+  }
+  
+  public final boolean isFemaleSex()
+  {
+    return _boolean[3];
+  }
+  
+  private final void chooseRandomWeapon()
+  {
+    L2WeaponType wpnType = null;
+    
+    wpnType = Rnd.get(100) > 40 ? L2WeaponType.BOW : L2WeaponType.BOW;
+    
+    wpnType = L2WeaponType.BOW;
+    do
+    {
+      wpnType = L2WeaponType.values()[Rnd.get(L2WeaponType.values().length)];
+    } while ((wpnType == null) || 
+    
+
+
+      (wpnType == L2WeaponType.BOW) || (wpnType == L2WeaponType.BOW));
+    if ((_classId.getRace() == Race.human) || 
+    
+
+
+
+
+      (Rnd.get(100) < 10)) {}
+  }
+  
+  private final void chooseRandomClass()
+  {
+    for (;;)
+    {
+      _classId = ClassId.values()[Rnd.get(ClassId.values().length)];
+      if ((_classId != null) && 
+      
+
+
+        (_classId.getRace() != null) && (_classId.getParent() != null)) {
+        break;
+      }
+    }
+    _int[6] = _classId.getRace().ordinal();
+    _int[7] = _classId.getId();
+  }
+  
+  private final void chooseRandomAppearance()
+  {
+	  _boolean[1] = Rnd.get(100) < 15 ? true : false;
+	  _boolean[3] = Rnd.get(100) < 50 ? true : false;
+	  _int[22] = (_int[23] = 0);
+	  if (Rnd.get(100) < 5) {
+		  _int[22] = 255;
+	  } 
+	  else if (Rnd.get(100) < 5)
+	  {
+		  _int[22] = 65280;
+	  }
+	  if (Rnd.get(100) < 5) {
+		  _int[23] = 255;
+	  }
+	  else if (Rnd.get(100) < 5)
+	  {
+		  _int[23] = 65280;
+	  }
+	  _int[1] = (Rnd.get(100) > 10 ? 50 : Rnd.get(100) > 95 ? 0 : 1000);
+	  _int[19] = (Rnd.get(100) < 34 ? 1 : Rnd.get(100) < 34 ? 0 : 2);
+	  _int[20] = (Rnd.get(100) < 34 ? 1 : Rnd.get(100) < 34 ? 0 : 2);
+	  _int[21] = (Rnd.get(100) < 34 ? 1 : Rnd.get(100) < 34 ? 0 : 2);
+    
+    int pledgeLevel = Rnd.get(100);
+    if (pledgeLevel > 30) {
+      _int[9] = 1;
+    }
+    if (pledgeLevel > 50) {
+      _int[9] = 2;
+    }
+    if (pledgeLevel > 60) {
+      _int[9] = 3;
+    }
+    if (pledgeLevel > 80) {
+      _int[9] = 4;
+    }
+    if (pledgeLevel > 90) {
+      _int[9] = 5;
+    }
+    if (pledgeLevel > 95) {
+      _int[9] = 6;
+    }
+    if (pledgeLevel > 98) {
+      _int[9] = 7;
+    }
+  }
+  
+  public void setPcInstanceData(CustomNpcInstanceManager.customInfo ci)
+  {
+    if (ci == null) {
+      return;
+    }
+    for (int i = 0; i < 25; i++) {
+      _int[i] = ci.integerData[i];
+    }
+    for (int i = 0; i < 4; i++) {
+      _boolean[i] = ci.booleanData[i];
+    }
+    _allowRandomClass = ci.booleanData[4];
+    _allowRandomAppearance = ci.booleanData[5];
+    _allowRandomWeapons = ci.booleanData[6];
+    
+
+    _name = ci.stringData[0];
+    _title = ci.stringData[1];
+    if ((_name != null) && (_name.equals(""))) {
+      _name = null;
+    }
+    if ((_title != null) && (_title.equals(""))) {
+      _title = null;
+    }
+    ClassId[] ids = ClassId.values();
+    if (ids != null) {
+      for (ClassId id : ids) {
+        if (id != null) {
+          if (id.getId() == _int[7])
+          {
+            _classId = id;
+            _int[6] = id.getRace().ordinal();
+            break;
+          }
+        }
+      }
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/model/actor/instance/L2NpcInstance.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/model/actor/instance/L2NpcInstance.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/model/actor/instance/L2NpcInstance.java	(cópia de trabalho)
@@ -76,6 +76,7 @@
 import com.l2jfrozen.gameserver.model.scripts.L2RBManager;
 import com.l2jfrozen.gameserver.model.spawn.L2Spawn;
 import com.l2jfrozen.gameserver.model.zone.type.L2TownZone;
+import com.l2jfrozen.gameserver.monumentstatuet.EventMonumentStatuet;
 import com.l2jfrozen.gameserver.network.L2GameClient;
 import com.l2jfrozen.gameserver.network.SystemMessageId;
 import com.l2jfrozen.gameserver.network.serverpackets.ActionFailed;
@@ -116,6 +117,10 @@
 	
 	/** The interaction distance of the L2NpcInstance(is used as offset in MovetoLocation method). */
 	public static final int INTERACTION_DISTANCE = 150;
+
+	public boolean Monument_Npc_PVP = false;
+
+	public boolean Monument_Npc_PK = false;
 	
 	/** The Polymorph object that manage this L2NpcInstance's morph to a PcInstance... I wrote this line too =P Darki699 */
 	private L2CustomNpcInstance _customNpcInstance;
@@ -870,6 +875,14 @@
 					{
 						VIP.showEndHTML(player, String.valueOf(getObjectId()));
 					}
+			        else if (Monument_Npc_PK)
+			        {
+			            EventMonumentStatuet.getInstance().htmlPKnpc(player);
+			        }
+			        else if (Monument_Npc_PVP)
+			        {
+			            EventMonumentStatuet.getInstance().htmlPVPnpc(player);
+			        }
 					else
 					{
 						// Open a chat window on client with the text of the L2NpcInstance
Index: head-src/com/l2jfrozen/gameserver/monumentstatuet/EventMonumentStatuet.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/monumentstatuet/EventMonumentStatuet.java	(revisão 0)
+++ head-src/com/l2jfrozen/gameserver/monumentstatuet/EventMonumentStatuet.java	(cópia de trabalho)
@@ -0,0 +1,594 @@
+package com.l2jfrozen.gameserver.monumentstatuet;
+
+import java.sql.Connection;
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.util.Calendar;
+import java.util.Map;
+
+import javolution.util.FastMap;
+
+import com.l2jfrozen.Config;
+import com.l2jfrozen.gameserver.datatables.sql.ItemTable;
+import com.l2jfrozen.gameserver.datatables.sql.NpcTable;
+import com.l2jfrozen.gameserver.datatables.sql.SpawnTable;
+import com.l2jfrozen.gameserver.managers.CustomNpcInstanceManager;
+import com.l2jfrozen.gameserver.model.L2World;
+import com.l2jfrozen.gameserver.model.actor.instance.L2PcInstance;
+import com.l2jfrozen.gameserver.model.spawn.L2Spawn;
+import com.l2jfrozen.gameserver.network.serverpackets.MagicSkillUser;
+import com.l2jfrozen.gameserver.templates.L2Item;
+import com.l2jfrozen.gameserver.templates.L2NpcTemplate;
+import com.l2jfrozen.gameserver.thread.ThreadPoolManager;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+
+public class EventMonumentStatuet
+{
+  public static EventMonumentStatuet _instance;
+  public static L2Spawn PK_SPAWN;
+  public static L2Spawn PVP_SPAWN;
+  public boolean inPeriodOk = true;
+  private Map<Integer, int[]> startup_players;
+  private PreparedStatement statement;
+  
+  public EventMonumentStatuet()
+  {
+    startup_players = new FastMap();
+  }
+  
+  public static EventMonumentStatuet getInstance()
+  {
+    if (_instance == null) {
+      _instance = new EventMonumentStatuet();
+    }
+    return _instance;
+  }
+  
+  public void htmlPKnpc(L2PcInstance pl) {}
+  
+  public void htmlPVPnpc(L2PcInstance pl) {}
+  
+  public void spawnStatuets()
+  {
+    spawnNpcPVP();
+    spawnNpcPK();
+  }
+  
+  private static void spawnNpcPVP()
+  {
+    L2NpcTemplate tmpl = NpcTable.getInstance().getTemplate(Config.NPC_TEMPLATE_ID_PVP);
+    try
+    {
+      PVP_SPAWN = new L2Spawn(tmpl);
+      PVP_SPAWN.setLocx(83215);
+      PVP_SPAWN.setLocy(148393);
+      PVP_SPAWN.setLocz(-3373);
+      PVP_SPAWN.setAmount(1);
+      PVP_SPAWN.setRespawnDelay(1);
+      SpawnTable.getInstance().addNewSpawn(PVP_SPAWN, false);
+      PVP_SPAWN.init();
+      PVP_SPAWN.getLastSpawn().getStatus().setCurrentHp(999999999.0D);
+      PVP_SPAWN.getLastSpawn().isAggressive();
+      PVP_SPAWN.getLastSpawn().Monument_Npc_PVP = true;
+      PVP_SPAWN.getLastSpawn().decayMe();
+      PVP_SPAWN.getLastSpawn().spawnMe(PVP_SPAWN.getLastSpawn().getX(), PVP_SPAWN.getLastSpawn().getY(), PVP_SPAWN.getLastSpawn().getZ());
+      
+      PVP_SPAWN.getLastSpawn().broadcastPacket(new MagicSkillUser(PVP_SPAWN.getLastSpawn(), PVP_SPAWN.getLastSpawn(), 1034, 1, 1, 1));
+      
+      System.out.println("[EventMonumentStatuet]:Statue pvp spawned.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]:Fail to spawn statue pvp.");
+    }
+  }
+  
+  private static void spawnNpcPK()
+  {
+    L2NpcTemplate tmpl = NpcTable.getInstance().getTemplate(Config.NPC_TEMPLATE_ID_PK);
+    try
+    {
+      PK_SPAWN = new L2Spawn(tmpl);
+      PK_SPAWN.setLocx(83220);
+      PK_SPAWN.setLocy(147909);
+      PK_SPAWN.setLocz(-3373);
+      PK_SPAWN.setAmount(1);
+      PK_SPAWN.setRespawnDelay(1);
+      SpawnTable.getInstance().addNewSpawn(PK_SPAWN, false);
+      PK_SPAWN.init();
+      PK_SPAWN.getLastSpawn().getStatus().setCurrentHp(999999999.0D);
+      PK_SPAWN.getLastSpawn().isAggressive();
+      PK_SPAWN.getLastSpawn().Monument_Npc_PK = true;
+      PK_SPAWN.getLastSpawn().decayMe();
+      PK_SPAWN.getLastSpawn().spawnMe(PK_SPAWN.getLastSpawn().getX(), PK_SPAWN.getLastSpawn().getY(), PK_SPAWN.getLastSpawn().getZ());
+      
+      PK_SPAWN.getLastSpawn().broadcastPacket(new MagicSkillUser(PK_SPAWN.getLastSpawn(), PK_SPAWN.getLastSpawn(), 1034, 1, 1, 1));
+      
+      System.out.println("[EventMonumentStatuet]:Statue pk spawned.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]:Fail to spawn statue pk.");
+    }
+    finally
+    {
+      tmpl = null;
+    }
+  }
+  
+  public void reloadAllNpc()
+  {
+    unspawnNpcPK();
+    unspawnNpcPVP();
+    
+    PK_SPAWN = null;
+    PVP_SPAWN = null;
+    
+    spawnNpcPK();
+    spawnNpcPVP();
+  }
+  
+  private static void unspawnNpcPK()
+  {
+    if ((PK_SPAWN == null) || (PK_SPAWN.getLastSpawn() == null)) {
+      return;
+    }
+    PK_SPAWN.getLastSpawn().deleteMe();
+    PK_SPAWN.stopRespawn();
+    SpawnTable.getInstance().deleteSpawn(PK_SPAWN, true);
+  }
+  
+  private static void unspawnNpcPVP()
+  {
+    if ((PVP_SPAWN == null) || (PVP_SPAWN.getLastSpawn() == null)) {
+      return;
+    }
+    PVP_SPAWN.getLastSpawn().deleteMe();
+    PVP_SPAWN.stopRespawn();
+    SpawnTable.getInstance().deleteSpawn(PVP_SPAWN, true);
+  }
+  
+  public void onEnterPlayer(L2PcInstance pl)
+  {
+    if ((inPeriodOk) && (startup_players.get(Integer.valueOf(pl.getObjectId())) == null))
+    {
+      int[] stats = { pl.getObjectId(), pl.getPvpKills(), pl.getPkKills() };
+      startup_players.put(Integer.valueOf(pl.getObjectId()), stats);
+      storeInDataInfo(pl);
+    }
+  }
+  
+  public void ConfiguratePereiod()
+  {
+    String hour = Config.RATE_HOUR_STATUET_REFRESH.split(":")[0];
+    String minutes = Config.RATE_HOUR_STATUET_REFRESH.split(":")[1];
+    
+    int h = 0;int m = 0;
+    long timeL = 0L;
+    try
+    {
+      h = Integer.valueOf(hour).intValue();
+      m = Integer.valueOf(minutes).intValue();
+      Calendar currentTime = Calendar.getInstance();
+      Calendar testStartTime = Calendar.getInstance();
+      testStartTime.setLenient(true);
+      
+      testStartTime.set(11, h);
+      testStartTime.set(12, m);
+      testStartTime.set(13, 0);
+      if (testStartTime.getTimeInMillis() < currentTime.getTimeInMillis()) {
+        testStartTime.add(5, 1);
+      }
+      timeL = testStartTime.getTimeInMillis() - currentTime.getTimeInMillis();
+      
+      ThreadPoolManager.getInstance().scheduleGeneral(new refreshStatuet(), timeL);
+      
+      System.out.println("[EventMonumentStatuet]Periodo to refresh statuet: " + testStartTime.getTime());
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]:ConfiguratePereiod()]Fail to load period");
+      e.printStackTrace();
+    }
+  }
+  
+  private void storeInDataInfo(L2PcInstance pl)
+  {
+    Connection con = null;
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement("INSERT INTO monuments_startup (obj_id, pvp, pk) VALUES (?, ? , ?)");
+      statement.setInt(1, pl.getObjectId());
+      statement.setInt(2, pl.getPvpKills());
+      statement.setInt(3, pl.getPkKills());
+      statement.execute();
+      statement.close();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in store!");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+  
+  public void load()
+  {
+    Connection con = null;
+    String SQL = "SELECT obj_id, pvp, pk FROM monuments_startup ORDER BY obj_id";
+    if (startup_players.isEmpty()) {
+      startup_players.clear();
+    }
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement(SQL);
+      
+      ResultSet rs = statement.executeQuery();
+      while (rs.next())
+      {
+        int obj_id = rs.getInt("obj_id");
+        int pvp = rs.getInt("pvp");
+        int pk = rs.getInt("pk");
+        
+        int[] stats = { obj_id, pvp, pk };
+        startup_players.put(Integer.valueOf(obj_id), stats);
+      }
+      statement.close();
+      rs.close();
+      
+      System.out.println("[EventMonumentStatuet]Loaded " + startup_players.size() + " competitors.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in load competitors!");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+  
+  public void StartNewPeriod()
+  {
+    String monuments_startup_del = "TRUNCATE TABLE monuments_startup";
+    
+
+    Connection con = null;
+    statement = null;
+    try
+    {
+      System.out.println("[EventMonumentStatuet]Delete all elements from table monuments_startup.");
+      con = L2DatabaseFactory.getInstance().getConnection();
+      statement = con.prepareStatement(monuments_startup_del);
+      statement.execute();
+      try
+      {
+        statement.close();
+        
+        CloseUtil.close(con);
+        con = null;
+        
+        statement = null;
+        monuments_startup_del = null;
+      }
+      catch (Exception e) {}
+      startup_players.clear();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in delete all elements from table monuments_startup.");
+      e.printStackTrace();
+    }
+    finally
+    {
+      try
+      {
+        statement.close();
+        
+        CloseUtil.close(con);
+        con = null;
+        
+        statement = null;
+        monuments_startup_del = null;
+      }
+      catch (Exception e) {}
+    }
+    System.out.println("[EventMonumentStatuet]Adding all objects online.");
+    int[] stats = new int[3];
+    for (L2PcInstance pl : L2World.getInstance().getAllPlayers())
+    {
+      stats[0] = pl.getObjectId();
+      stats[1] = pl.getPvpKills();
+      stats[2] = pl.getPkKills();
+      
+      startup_players.put(Integer.valueOf(pl.getObjectId()), stats);
+      
+      storeInDataInfo(pl);
+    }
+    System.out.println("[EventMonumentStatuet]Added " + startup_players.size() + " objects online.");
+  }
+  
+  private class refreshStatuet
+    implements Runnable
+  {
+    public refreshStatuet() {}
+    
+    public void run()
+    {
+      EventMonumentStatuet.this.inPeriodOk = false;
+      EventMonumentStatuet.this.CalculateWins();
+      EventMonumentStatuet.this.StartNewPeriod();
+      EventMonumentStatuet.this.inPeriodOk = true;
+    }
+  }
+  
+  public void CalculateWins()
+  {
+    if (startup_players.size() <= 1)
+    {
+      System.out.println("[EventMonumentStatuet]:No participants in event, no statue formed.");
+      return;
+    }
+    Connection con = null;
+    String SQL = "SELECT obj_Id, pvpkills, pkkills FROM characters WHERE";
+    
+    int count = 0;
+    for (int[] a : startup_players.values())
+    {
+      SQL = SQL + (count == 0 ? " obj_Id=" + a[0] : new StringBuilder().append(" or obj_Id=").append(a[0]).toString());
+      
+      count++;
+    }
+    int pvp_maior = 0;int pk_maior = 0;
+    int[] obj_pvp = { 0, 0 };int[] obj_pk = { 0, 0 };
+    System.out.println("[EventMonumentStatuet]:Calculando player wins.");
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement(SQL);
+      
+      ResultSet rs = statement.executeQuery();
+      while (rs.next())
+      {
+        int obj_id = rs.getInt("obj_id");
+        int pvp = rs.getInt("pvpkills");
+        int pk = rs.getInt("pkkills");
+        
+        int[] dados = (int[])startup_players.get(Integer.valueOf(obj_id));
+        
+        int diference_pvp = pvp - dados[1];
+        int diference_pk = pk - dados[2];
+        if (diference_pvp > pvp_maior)
+        {
+          pvp_maior = diference_pvp;
+          obj_pvp[0] = obj_id;
+          obj_pvp[1] = diference_pvp;
+        }
+        if (diference_pk > pk_maior)
+        {
+          pk_maior = diference_pk;
+          obj_pk[0] = obj_id;
+          obj_pk[1] = diference_pk;
+        }
+      }
+      statement.close();
+      rs.close();
+      System.out.println("[EventMonumentStatuet]:Wins a pvp player:" + obj_pvp[0] + " with " + obj_pvp[1] + " differ.");
+      System.out.println("[EventMonumentStatuet]:Wins a pk player:" + obj_pk[0] + " with " + obj_pk[1] + " differ.");
+    }
+    catch (Exception e)
+    {
+      System.out.println("[EventMonumentStatuet]Error in createPvpStatuet!");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+    createStatuet(obj_pvp, obj_pk);
+  }
+  
+  private void createStatuet(int[] dados_pvp, int[] dados_pk)
+  {
+    Connection con = null;
+    
+    Map<Integer, Items> items_mp_pvp = null;
+    Map<Integer, Items> items_mp_pk = null;
+    
+
+
+
+    L2Item item = null;
+    
+    System.out.println("[EventMonumentStatuet]: Creating map items for: " + dados_pvp[0] + " and " + dados_pk[0]);
+    if (dados_pvp[0] != 0)
+    {
+      String SQL = "SELECT item_id, enchant_level FROM items WHERE owner_id=" + dados_pvp[0] + " AND loc='PAPERDOLL'";
+      items_mp_pvp = new FastMap();
+      try
+      {
+        con = L2DatabaseFactory.getInstance().getConnection();
+        PreparedStatement st = con.prepareStatement(SQL);
+        ResultSet rs = st.executeQuery();
+        while (rs.next())
+        {
+          int item_id = rs.getInt("item_id");
+          int enchant_level = rs.getInt("enchant_level");
+          
+          item = ItemTable.getInstance().getTemplate(item_id);
+          if (item != null) {
+            if (item.getType2() == 0) {
+              items_mp_pvp.put(Integer.valueOf(items_mp_pvp.size() + 1), new Weapon(item_id, enchant_level, item.getBodyPart()));
+            } else if (item.getType2() == 2) {
+              items_mp_pvp.put(Integer.valueOf(items_mp_pvp.size() + 1), new Acessory(item_id, item.getBodyPart()));
+            } else if (item.getType2() == 1) {
+              items_mp_pvp.put(Integer.valueOf(items_mp_pvp.size() + 1), new ArmororShield(item_id, item.getBodyPart()));
+            }
+          }
+        }
+        st.close();
+        st = null;
+        rs.close();
+        rs = null;
+        
+        System.out.println("[EventMonumentStatuet]:Map Items pvp created with " + items_mp_pvp.size() + " items.");
+      }
+      catch (Exception e)
+      {
+    	  System.out.println("[EventMonumentStatuet]: Error in createStatuet 1:");
+        e.printStackTrace();
+      }
+      finally
+      {
+        CloseUtil.close(con);
+        con = null;
+      }
+    }
+    if (dados_pk[0] != 0)
+    {
+      items_mp_pk = new FastMap();
+      String SQL = "SELECT item_id, enchant_level FROM items WHERE owner_id=" + dados_pk[0] + " AND loc='PAPERDOLL'";
+      try
+      {
+        con = L2DatabaseFactory.getInstance().getConnection();
+        PreparedStatement st = con.prepareStatement(SQL);
+        ResultSet rs = st.executeQuery();
+        while (rs.next())
+        {
+          int item_id = rs.getInt("item_id");
+          int enchant_level = rs.getInt("enchant_level");
+          
+          item = ItemTable.getInstance().getTemplate(item_id);
+          if (item != null) {
+            if (item.getType2() == 0) {
+              items_mp_pk.put(Integer.valueOf(items_mp_pk.size() + 1), new Weapon(item_id, enchant_level, item.getBodyPart()));
+            } else if (item.getType2() == 2) {
+              items_mp_pk.put(Integer.valueOf(items_mp_pk.size() + 1), new Acessory(item_id, item.getBodyPart()));
+            } else if (item.getType2() == 1) {
+              items_mp_pk.put(Integer.valueOf(items_mp_pk.size() + 1), new ArmororShield(item_id, item.getBodyPart()));
+            }
+          }
+        }
+        st.close();
+        st = null;
+        rs.close();
+        rs = null;
+        
+        System.out.println("[EventMonumentStatuet]:Map Items pk created with " + items_mp_pk.size() + " items.");
+      }
+      catch (Exception e)
+      {
+    	  System.out.println("[EventMonumentStatuet]: Error in createStatuet 2:");
+        e.printStackTrace();
+      }
+      finally
+      {
+        CloseUtil.close(con);
+        con = null;
+      }
+    }
+    if ((items_mp_pvp != null) && (items_mp_pk != null))
+    {
+      System.out.println("[EventMonumentStatuet]:Calling data from the statue new MonumentCreator()");
+      MonumentCreator alpha = new MonumentCreator();
+      if (dados_pvp[0] != 0)
+      {
+        int[] dados_pvp_int = new int[3];
+        dados_pvp_int[0] = dados_pvp[0];
+        dados_pvp_int[1] = 1;
+        dados_pvp_int[2] = dados_pvp[1];
+        
+        alpha.create(dados_pvp_int, items_mp_pvp);
+        
+        alpha = null;
+      }
+      if (dados_pk[0] != 0)
+      {
+        int[] dados_pk_int = new int[3];
+        alpha = new MonumentCreator();
+        dados_pk_int[0] = dados_pk[0];
+        dados_pk_int[1] = 2;
+        dados_pk_int[2] = dados_pk[1];
+        
+        alpha.create(dados_pk_int, items_mp_pk);
+        
+        alpha = null;
+      }
+      CustomNpcInstanceManager.getInstance().reload();
+      
+      reloadAllNpc();
+    }
+  }
+  
+  public class Items
+  {
+    int _item_id;
+    int _slot;
+    
+    public Items(int item_id, int slot)
+    {
+      _item_id = item_id;
+      _slot = slot;
+    }
+    
+    public int getItemId()
+    {
+      return _item_id;
+    }
+    
+    public int getItemSlot()
+    {
+      return _slot;
+    }
+  }
+  
+  public class Weapon
+    extends EventMonumentStatuet.Items
+  {
+    int _enchant;
+    
+    public Weapon(int item_id, int enchant, int slot)
+    {
+      super(item_id, slot);
+      
+      System.out.println("Added weapon slot:" + slot);
+      _enchant = enchant;
+    }
+    
+    public int getItemEnchant()
+    {
+      return _enchant;
+    }
+  }
+  
+  public class ArmororShield
+    extends EventMonumentStatuet.Items
+  {
+    public ArmororShield(int item_id, int slot)
+    {
+      super(item_id, slot);
+    }
+  }
+  
+  public class Acessory
+    extends EventMonumentStatuet.Items
+  {
+    public Acessory(int item_id, int slot)
+    {
+      super(item_id, slot);
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/monumentstatuet/MonumentCreator.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/monumentstatuet/MonumentCreator.java	(revisão 0)
+++ head-src/com/l2jfrozen/gameserver/monumentstatuet/MonumentCreator.java	(cópia de trabalho)
@@ -0,0 +1,170 @@
+package com.l2jfrozen.gameserver.monumentstatuet;
+
+import com.l2jfrozen.Config;
+import com.l2jfrozen.util.CloseUtil;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+import java.sql.Connection;
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.util.Map;
+import javolution.util.FastMap;
+
+public class MonumentCreator
+{
+  int _right_hand = 0;
+  int _female = 0;
+  int _hair2 = 0;
+  int[] dados = new int[3];
+  int _class_id = 0;
+  int _hair_style = 0;
+  int _hair_color = 0;
+  int _face = 0;
+  int _hero = 0;
+  int _wpn_enchant = 0;
+  int _feet = 0;
+  int _left_hand = 0;
+  int _gloves = 0;
+  int _chest = 0;
+  int _legs = 0;
+  int _hair = 0;
+  String _name;
+  String _title;
+  FastMap<Integer, EventMonumentStatuet.Items> _items;
+  
+  public void create(int[] obj_id, Map<Integer, EventMonumentStatuet.Items> items)
+  {
+    dados = obj_id;
+    
+    _items = ((FastMap)items);
+    
+    load();
+  }
+  
+  private void load()
+  {
+    Connection con = null;
+    String SQL = "SELECT char_name,face,hairStyle,hairColor,sex,classid FROM characters WHERE obj_Id=" + dados[0];
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      PreparedStatement st = con.prepareStatement(SQL);
+      ResultSet rs = st.executeQuery();
+      while (rs.next())
+      {
+        _name = rs.getString("char_name");
+        _face = rs.getInt("face");
+        _hair_style = rs.getInt("hairStyle");
+        _hair_color = rs.getInt("hairColor");
+        _female = rs.getInt("sex");
+        _class_id = rs.getInt("classid");
+      }
+      st.close();
+      rs.close();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[MonumentCreator]: Error in load SQL FROM characters...");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+    System.out.println("[Form Monument]: Load info char ok...");
+    
+    _title = (dados[2] + " pk's in 24h");
+    for (EventMonumentStatuet.Items item : _items.values())
+    {
+      switch (item.getItemSlot())
+      {
+      case 16384: 
+        _left_hand = item.getItemId();
+        _right_hand = item.getItemId();
+        break;
+      case 128: 
+        _right_hand = item.getItemId();
+        break;
+      case 262144: 
+        _hair = item.getItemId();
+        break;
+      case 65536: 
+        _hair2 = item.getItemId();
+        break;
+      case 1024: 
+        _chest = item.getItemId();
+        break;
+      case 512: 
+        _gloves = item.getItemId();
+        break;
+      case 4096: 
+        _feet = item.getItemId();
+        break;
+      case 64: 
+        _hair = item.getItemId();
+        break;
+      case 32768: 
+        _chest = item.getItemId();
+        break;
+      case 2048: 
+        _legs = item.getItemId();
+      }
+      if ((item instanceof EventMonumentStatuet.Weapon)) {
+        _wpn_enchant = ((EventMonumentStatuet.Weapon)item).getItemEnchant();
+      }
+    }
+    System.out.println("[Form Monument]: Aparence information OK...");
+    
+    putIntoDb();
+    
+    System.out.println("[Form Monument]: Data Saved...");
+  }
+  
+  public void putIntoDb()
+  {
+    Connection con = null;
+    try
+    {
+      con = L2DatabaseFactory.getInstance().getConnection();
+      
+      PreparedStatement statement = con.prepareStatement("UPDATE npc_to_pc_polymorph SET name=?,title=?,class_id=?,female=?,hair_style=?,hair_color=?,face=?,hero=?,wpn_enchant=?,right_hand=?,left_hand=?,gloves=?,chest=?,legs=?,feet=?,hair=?,hair2=? WHERE template=" + (dados[1] == 1 ? Config.NPC_TEMPLATE_ID_PVP : Config.NPC_TEMPLATE_ID_PK));
+      
+
+
+
+
+      statement.setString(1, _name);
+      statement.setString(2, _title);
+      statement.setInt(3, _class_id);
+      statement.setInt(4, _female);
+      statement.setInt(5, _hair_style);
+      statement.setInt(6, _hair_color);
+      statement.setInt(7, _face);
+      statement.setInt(8, _hero);
+      statement.setInt(9, _wpn_enchant);
+      statement.setInt(10, _right_hand);
+      statement.setInt(11, _left_hand);
+      
+      statement.setInt(12, _gloves);
+      statement.setInt(13, _chest);
+      statement.setInt(14, _legs);
+      statement.setInt(15, _feet);
+      
+      statement.setInt(16, _hair);
+      statement.setInt(17, _hair2);
+      
+      statement.execute();
+      statement.close();
+    }
+    catch (Exception e)
+    {
+      System.out.println("[MonumentCreator]: Failt to putIntoDb...");
+      e.printStackTrace();
+    }
+    finally
+    {
+      CloseUtil.close(con);
+      con = null;
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java	(cópia de trabalho)
@@ -71,6 +71,7 @@
 import com.l2jfrozen.gameserver.model.entity.siege.Siege;
 import com.l2jfrozen.gameserver.model.quest.Quest;
 import com.l2jfrozen.gameserver.model.quest.QuestState;
+import com.l2jfrozen.gameserver.monumentstatuet.EventMonumentStatuet;
 import com.l2jfrozen.gameserver.network.Disconnection;
 import com.l2jfrozen.gameserver.network.SystemMessageId;
 import com.l2jfrozen.gameserver.network.serverpackets.ClientSetTime;
@@ -417,6 +418,9 @@
 		if (DM._savePlayers.contains(activeChar.getName()))
 			DM.addDisconnectedPlayer(activeChar);
 		
+	    if (Config.EVENT_MONUMENT_STATUET) {
+	        EventMonumentStatuet.getInstance().onEnterPlayer(activeChar);
+	      }
 		// Means that it's not ok multiBox situation, so logout
 		if (!activeChar.checkMultiBox())
 		{
Index: head-src/com/l2jfrozen/gameserver/network/serverpackets/CustomNpcInfo.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/serverpackets/CustomNpcInfo.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/network/serverpackets/CustomNpcInfo.java	(cópia de trabalho)
@@ -1,153 +1,124 @@
+/*
+ * L2jFrozen Project - www.l2jfrozen.com 
+ * 
+ * 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 com.l2jfrozen.gameserver.network.serverpackets;
+ 
+import com.l2jfrozen.gameserver.datatables.sql.CharTemplateTable;
+import com.l2jfrozen.gameserver.model.actor.instance.L2NpcInstance;
+
+ public class CustomNpcInfo extends L2GameServerPacket
+  {
+  private static final String _S__03_CUSTOMNPCINFO = "[S] 03 CustomNpcInfo [dddddsddd dddddddddddd dddddddd hhhh d hhhhhhhhhhhh d hhhh hhhhhhhhhhhhhhhh dddddd dddddddd ffff ddd s ddddd ccccccc h c d c h ddd cc d ccc ddddddddddd]";
+  private final L2NpcInstance _activeChar;
+  
+  public CustomNpcInfo(L2NpcInstance cha)
+  {
+    _activeChar = cha;
+    _activeChar.setClientX(_activeChar.getPosition().getX());
+    _activeChar.setClientY(_activeChar.getPosition().getY());
+    _activeChar.setClientZ(_activeChar.getPosition().getZ());
+  }
+  
+  protected final void writeImpl()
+  {
+    writeC(3);
+    writeD(_activeChar.getX());
+    writeD(_activeChar.getY());
+    writeD(_activeChar.getZ());
+    writeD(_activeChar.getHeading());
+    writeD(_activeChar.getObjectId());
+    writeS(_activeChar.getCustomNpcInstance().getName());
+    writeD(_activeChar.getCustomNpcInstance().getRace());
+    writeD(_activeChar.getCustomNpcInstance().isFemaleSex() ? 1 : 0);
+    writeD(_activeChar.getCustomNpcInstance().getClassId());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR());
+    writeD(0);
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_RHAND());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_LHAND());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_GLOVES());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_CHEST());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_LEGS());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_FEET());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_RHAND());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR());
+    writeD(_activeChar.getCustomNpcInstance().PAPERDOLL_HAIR2());
+    write('H', 0, 24);
+    writeD(_activeChar.getCustomNpcInstance().getPvpFlag() ? 1 : 0);
+    writeD(_activeChar.getCustomNpcInstance().getKarma());
+    writeD(_activeChar.getMAtkSpd());
+    writeD(_activeChar.getPAtkSpd());
+    writeD(_activeChar.getCustomNpcInstance().getPvpFlag() ? 1 : 0);
+    writeD(_activeChar.getCustomNpcInstance().getKarma());
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed() / 2);
+    writeD(_activeChar.getRunSpeed() / 3);
+    writeD(_activeChar.getRunSpeed() / 3);
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed());
+    writeD(_activeChar.getRunSpeed());
+    writeF(_activeChar.getStat().getMovementSpeedMultiplier());
+    writeF(_activeChar.getStat().getAttackSpeedMultiplier());
+    writeF(CharTemplateTable.getInstance().getTemplate(_activeChar.getCustomNpcInstance().getClassId()).getCollisionRadius());
+    writeF(CharTemplateTable.getInstance().getTemplate(_activeChar.getCustomNpcInstance().getClassId()).getCollisionHeight());
+    writeD(_activeChar.getCustomNpcInstance().getHairStyle());
+    writeD(_activeChar.getCustomNpcInstance().getHairColor());
+    writeD(_activeChar.getCustomNpcInstance().getFace());
+    writeS(_activeChar.getCustomNpcInstance().getTitle());
+    writeD(_activeChar.getCustomNpcInstance().getClanId());
+    writeD(_activeChar.getCustomNpcInstance().getClanCrestId());
+    writeD(_activeChar.getCustomNpcInstance().getAllyId());
+    writeD(_activeChar.getCustomNpcInstance().getAllyCrestId());
+    writeD(0);
+    writeC(1);
+    writeC(_activeChar.isRunning() ? 1 : 0);
+    writeC(_activeChar.isInCombat() ? 1 : 0);
+    writeC(_activeChar.isAlikeDead() ? 1 : 0);
+    write('C', 0, 3);
+    writeH(0);
+    writeC(0);
+    writeD(_activeChar.getAbnormalEffect());
+    writeC(0);
+    writeH(0);
+    writeD(_activeChar.getCustomNpcInstance().getClassId());
+    writeD(_activeChar.getMaxCp());
+    writeD((int)_activeChar.getStatus().getCurrentCp());
+    writeC(_activeChar.getCustomNpcInstance().getEnchantWeapon());
+    writeC(0);
+    writeD(0);
+    writeC(_activeChar.getCustomNpcInstance().isNoble() ? 1 : 0);
+    writeC(_activeChar.getCustomNpcInstance().isHero() ? 1 : 0);
+    writeC(0);
+    write('D', 0, 3);
+    writeD(_activeChar.getCustomNpcInstance().nameColor());
+    writeD(0);
+    writeD(_activeChar.getCustomNpcInstance().getPledgeClass());
+    writeD(0);
+    writeD(_activeChar.getCustomNpcInstance().titleColor());
+    writeD(0);
+  }
+  
+  public String getType()
+  {
+    return "[S] 03 CustomNpcInfo [dddddsddd dddddddddddd dddddddd hhhh d hhhhhhhhhhhh d hhhh hhhhhhhhhhhhhhhh dddddd dddddddd ffff ddd s ddddd ccccccc h c d c h ddd cc d ccc ddddddddddd]";
+  }
+  
+  private final void write(char type, int value, int times)
+  {
+    for (int i = 0; i < times; i++) {
+      switch (type)
+      {
+      case 'C': 
+        writeC(value);
+        break;
+      case 'D': 
+        writeD(value);
+        break;
+      case 'F': 
+        writeF(value);
+        break;
+      case 'H': 
+        writeH(value);
+      }
+    }
+  }
+}
Index: head-src/com/l2jfrozen/gameserver/network/serverpackets/NpcInfoPoly.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/serverpackets/NpcInfoPoly.java	(revisão 1118)
+++ head-src/com/l2jfrozen/gameserver/network/serverpackets/NpcInfoPoly.java	(cópia de trabalho)
+package com.l2jfrozen.gameserver.network.serverpackets;
+
+import com.l2jfrozen.gameserver.datatables.sql.NpcTable;
+import com.l2jfrozen.gameserver.model.L2Character;
+import com.l2jfrozen.gameserver.model.L2Object;
+import com.l2jfrozen.gameserver.model.actor.instance.L2ItemInstance;
+import com.l2jfrozen.gameserver.templates.L2NpcTemplate;
+
+public class NpcInfoPoly extends L2GameServerPacket
+{
+  private static final String _S__22_NPCINFO = "[S] 16 NpcInfo";
+  private L2Character _activeChar;
+  private final L2Object _obj;
+  private int _x;
+  private int _y;
+  private int _z;
+  private int _heading;
+  private final int _npcId;
+  private boolean _isAttackable;
+  private final boolean _isSummoned;
+  private boolean _isRunning;
+  private boolean _isInCombat;
+  private boolean _isAlikeDead;
+  private int _mAtkSpd;
+  private int _pAtkSpd;
+  private int _runSpd;
+  private int _walkSpd;
+  private int _swimRunSpd;
+  private int _swimWalkSpd;
+  private int _flRunSpd;
+  private int _flWalkSpd;
+  private int _flyRunSpd;
+  private int _flyWalkSpd;
+ private int _rhand;
+  private int _lhand;
+  private String _name;
+  private String _title;
+  private int _abnormalEffect;
+  L2NpcTemplate _template;
+  private final int _collisionRadius;
+  private final int _collisionHeight;
+ 
+  public NpcInfoPoly(L2Object obj, L2Character attacker)
+  {
+    _obj = obj;
+    _npcId = obj.getPoly().getPolyId();
+    _template = NpcTable.getInstance().getTemplate(_npcId);
+    _isAttackable = true;
+    _rhand = 0;
+    _lhand = 0;
+    _isSummoned = false;
+    _collisionRadius = _template.collisionRadius;
+    _collisionHeight = _template.collisionHeight;
+    if ((_obj instanceof L2Character))
+    {
+      _activeChar = ((L2Character)obj);
+      _isAttackable = obj.isAutoAttackable(attacker);
+      _rhand = _template.rhand;
+      _lhand = _template.lhand;
+    }
+    if ((_obj instanceof L2ItemInstance))
+    {
+      _x = _obj.getX();
+      _y = _obj.getY();
+      _z = _obj.getZ();
+      _heading = 0;
+      _mAtkSpd = 100;
+      _pAtkSpd = 100;
+      _runSpd = 120;
+      _walkSpd = 80;
+      _swimRunSpd = (_flRunSpd = _flyRunSpd = _runSpd);
+      _swimWalkSpd = (_flWalkSpd = _flyWalkSpd = _walkSpd);
+      _isRunning = (_isInCombat = _isAlikeDead = false);
+     _name = "item";
+      _title = "polymorphed";
+      _abnormalEffect = 0;
+    }
+    else
+    {
+      _x = _activeChar.getX();
+      _y = _activeChar.getY();
+      _z = _activeChar.getZ();
+      _heading = _activeChar.getHeading();
+      _mAtkSpd = _activeChar.getMAtkSpd();
+      _pAtkSpd = _activeChar.getPAtkSpd();
+      _runSpd = _activeChar.getRunSpeed();
+      _walkSpd = _activeChar.getWalkSpeed();
+      _swimRunSpd = (_flRunSpd = _flyRunSpd = _runSpd);
+      _swimWalkSpd = (_flWalkSpd = _flyWalkSpd = _walkSpd);
+      _isRunning = _activeChar.isRunning();
+      _isInCombat = _activeChar.isInCombat();
+      _isAlikeDead = _activeChar.isAlikeDead();
+      _name = _activeChar.getName();
+      _title = _activeChar.getTitle();
+      _abnormalEffect = _activeChar.getAbnormalEffect();
+    }
+  }
+  
+  protected final void writeImpl()
+  {
+    writeC(22);
+    writeD(_obj.getObjectId());
+    writeD(_npcId + 1000000);
+    writeD(_isAttackable ? 1 : 0);
+    writeD(_x);
+    writeD(_y);
+    writeD(_z);
+    writeD(_heading);
+    writeD(0);
+    writeD(_mAtkSpd);
+    writeD(_pAtkSpd);
+    writeD(_runSpd);
+    writeD(_walkSpd);
+    writeD(_swimRunSpd);
+    writeD(_swimWalkSpd);
+    writeD(_flRunSpd);
+    writeD(_flWalkSpd);
+    writeD(_flyRunSpd);
+    writeD(_flyWalkSpd);
+    writeF(1.0D);
+    writeF(1.0D);
+    writeF(_collisionRadius);
+    writeF(_collisionHeight);
+    writeD(_rhand);
+    writeD(0);
+    writeD(_lhand);
+    writeC(1);
+    writeC(_isRunning ? 1 : 0);
+    writeC(_isInCombat ? 1 : 0);
+    writeC(_isAlikeDead ? 1 : 0);
+    writeC(_isSummoned ? 2 : 0);
+    writeS(_name);
+    writeS(_title);
+    writeD(0);
+    writeD(0);
+    writeD(0);
+    
+    writeH(_abnormalEffect);
+    writeH(0);
+    writeD(0);
+    writeD(0);
+    writeD(0);
+    writeD(0);
+    writeC(0);
+  }
+  
+  public String getType()
+  {
+    return "[S] 16 NpcInfo";
+  }
+}

 

 

 

 

RW5oPX7.jpg

 

Thanks for providing the rev: Screenshot

Credit removal and adaptation: Tayran.Cannabis

Removing Source: L2JDX

 

i have got spawn error with caracters its working normaly good but only erro its spawn caraters...someone help me ???

Edited by kingmert
Link to comment
Share on other sites

  • 2 weeks later...
  • 7 months later...
1 hour ago, PaRaNoiC* said:

copy paste one sql

change name npc id and tempalte id + type

Not npc SQL :facepalm: coded misses tables code related. 

Link to comment
Share on other sites

  • 2 weeks later...
  • 3 years later...
7 minutes ago, KERB said:

Alguien pudp solucionar lo de los pjs desnudos?

Do you realise you're in a forum in EU and you need to write ENGLISH?

You latino have no respect at all.

 

PS. Congratulations for undig an almost 4 years old topic.

Edited by L2-Evanthe
Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

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

    • - lost love spells caster in, Amsterdam,Brazil,London,Kuwait .Egypt, Atlanta, Latvia, Lithuania, Sweden۞۩ஜ???? +256704892479  Results are 100% s=ure and guaranteed, spell casting specialist, , black magic death spells that work overnight or by accident. I Cast these strongest black magic revenge death spells that work fast overnight to kill ex-lover, husband, wife girlfriend Enemies overnight Https://nativelovespellscaster.com or she is in a far location, I guarantee you to have your results you are looking for immediately. Just make sure before you contact me you are committed and you want what you are looking for (Victim Death) because my death spell work fast overnight after casting the spells that work, guaranteed black magic love spells, guaranteed voodoo spells, spell to make someone sick and die, revenge spells that work instantly, real witches for hire, revenge spells on an ex- lover, how to put a Black magic death spells on ex-lover, Revenge instant death spells on toxic uncles powerful instant death spells online instant spell that work fast in USA, UK, Kuwait, Germany, Asian, Europe, Philippines, Canada, South Africa, Italy, Peru, India, Iran, Gambia. Sweden, Australia, Nigeria, Spain, Ghana, California, Greece. Death spell on someone, death spells that Death Revenge Spell on wicked friends, Voodoo Death Spells to kill Enemies Black Magic Spells To Harm Someone, Black magic death spells on ex-lover, Revenge instant death spells on toxic uncles powerful instant death spells online instant spell that work fast in USA, UK, Kuwait, Germany, Asian, Europe, Philippines, Canada, revenge spells, most powerful death spell, spell to die in your sleep, successful death spell, most powerful voodoo spell caster, voodoo spell casters in new Orleans, voodoo love spells reviews, proven authentic voodoo spell casters, most powerful voodoo priest in world, black magic tricks to destroy enemy. Results are 100% sure and guaranteed whatapp or cal, Europe, Philippines, Canada, South Africa, Italy, Peru, India, Iran, Gambia. spells, guaranteed voodoo spells, spell to make someone sick and die, revenge spells that work instantly, real witches for hire, revenge spells on an ex- lover, how to put a spell on someone who hurts you, spell to make someone sick, voodoo spells to hurt someone, spells to curse someone, powerful revenge spells, most powerful death spell, spell to die in your sleep, successful death spell, most powerful voodoo spell caster, voodoo spell casters in new Orleans, voodoo love spells reviews, proven authentic voodoo spell casters, most powerful voodoo priest in world, black magic tricks to destroy enemy. Results are 100% sure and guaranteed whatapp or call  ஜ۩۞۩ஜ ??? + 256704892479ஜ۩۞۩ஜ ??Https://nativelovespellscaster.com
    • Hello, my discord is : misanthropic1085           I am selling Frintezza Aq Baium     Reborn origins x1    
    • L2Topzone has a lower traffic ranking than every other website! We spent over 160 Euro for listing server and banner and we've got only 4 download conversions!  Proof: https://prnt.sc/YeJudEKFov1m
    • Any WTS code global chat for this? 
    • Hi, I see what you mean, but I do it differently.   I don't want some features from Hi5 in my project, so I gradually add Ai, zones, items, etc... manually.   And again I want some features from Classic.   So I'm continuing the Classic storyline up to High Five.   My project runs on the client's Prelude of War.   I will release the first public test version soon, which will still be without some "hi5" stuff, because first I need to test for example Fortress Siege, pets and some instances/quests. In the future, I also want to "unlock" new locations from the GoD story.   And what I like most about Classic is that you don't have SA in weapons and it goes back to the roots of Lineage 2. Also you can connect to my discord and talk about with me.
  • Topics

×
×
  • Create New...