CharTemplateTable.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. /*
  2. * Copyright (C) 2004-2013 L2J Server
  3. *
  4. * This file is part of L2J Server.
  5. *
  6. * L2J Server is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * L2J Server is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. package com.l2jserver.gameserver.datatables;
  20. import java.sql.Connection;
  21. import java.sql.ResultSet;
  22. import java.sql.SQLException;
  23. import java.sql.Statement;
  24. import java.util.HashMap;
  25. import java.util.Map;
  26. import java.util.logging.Level;
  27. import java.util.logging.Logger;
  28. import com.l2jserver.L2DatabaseFactory;
  29. import com.l2jserver.gameserver.model.StatsSet;
  30. import com.l2jserver.gameserver.model.actor.templates.L2PcTemplate;
  31. import com.l2jserver.gameserver.model.base.ClassId;
  32. /**
  33. * This will be reworked Soon(tm).
  34. * @author Unknown, Forsaiken, Zoey76
  35. */
  36. public final class CharTemplateTable
  37. {
  38. private static final Logger _log = Logger.getLogger(CharTemplateTable.class.getName());
  39. private static final Map<ClassId, L2PcTemplate> _charTemplates = new HashMap<>();
  40. protected CharTemplateTable()
  41. {
  42. try (Connection con = L2DatabaseFactory.getInstance().getConnection();
  43. Statement s = con.createStatement();
  44. ResultSet rset = s.executeQuery("SELECT * FROM char_templates, lvlupgain WHERE char_templates.classId = lvlupgain.classId ORDER BY char_templates.ClassId"))
  45. {
  46. StatsSet set;
  47. int cId;
  48. while (rset.next())
  49. {
  50. set = new StatsSet();
  51. cId = rset.getInt("ClassId");
  52. set.set("classId", cId);
  53. set.set("className", rset.getString("className"));
  54. set.set("raceId", rset.getInt("raceId"));
  55. set.set("baseSTR", rset.getInt("STR"));
  56. set.set("baseCON", rset.getInt("CON"));
  57. set.set("baseDEX", rset.getInt("DEX"));
  58. set.set("baseINT", rset.getInt("_INT"));
  59. set.set("baseWIT", rset.getInt("WIT"));
  60. set.set("baseMEN", rset.getInt("MEN"));
  61. set.set("baseHpMax", rset.getFloat("defaultHpBase"));
  62. set.set("lvlHpAdd", rset.getFloat("defaultHpAdd"));
  63. set.set("lvlHpMod", rset.getFloat("defaultHpMod"));
  64. set.set("baseMpMax", rset.getFloat("defaultMpBase"));
  65. set.set("baseCpMax", rset.getFloat("defaultCpBase"));
  66. set.set("lvlCpAdd", rset.getFloat("defaultCpAdd"));
  67. set.set("lvlCpMod", rset.getFloat("defaultCpMod"));
  68. set.set("lvlMpAdd", rset.getFloat("defaultMpAdd"));
  69. set.set("lvlMpMod", rset.getFloat("defaultMpMod"));
  70. set.set("baseHpReg", 2);
  71. set.set("baseMpReg", 0.9);
  72. set.set("basePAtk", rset.getInt("p_atk"));
  73. set.set("basePDef", rset.getInt("p_def"));
  74. set.set("baseMAtk", rset.getInt("m_atk"));
  75. set.set("baseMDef", rset.getInt("m_def"));
  76. set.set("classBaseLevel", rset.getInt("class_lvl"));
  77. set.set("baseRunSpd", rset.getInt("move_spd"));
  78. set.set("baseWalkSpd", 0);
  79. set.set("baseShldDef", 0);
  80. set.set("baseShldRate", 0);
  81. set.set("baseAtkRange", 40);
  82. set.set("spawnX", rset.getInt("x"));
  83. set.set("spawnY", rset.getInt("y"));
  84. set.set("spawnZ", rset.getInt("z"));
  85. set.set("collision_radius", rset.getDouble("m_col_r"));
  86. set.set("collision_height", rset.getDouble("m_col_h"));
  87. set.set("collision_radius_female", rset.getDouble("f_col_r"));
  88. set.set("collision_height_female", rset.getDouble("f_col_h"));
  89. final L2PcTemplate ct = new L2PcTemplate(set);
  90. _charTemplates.put(ClassId.getClassId(cId), ct);
  91. }
  92. _log.info(getClass().getSimpleName() + ": Loaded " + _charTemplates.size() + " Character Templates.");
  93. }
  94. catch (SQLException e)
  95. {
  96. _log.log(Level.SEVERE, getClass().getSimpleName() + ": Failed loading char templates", e);
  97. }
  98. }
  99. public L2PcTemplate getTemplate(final ClassId classId)
  100. {
  101. return _charTemplates.get(classId);
  102. }
  103. public L2PcTemplate getTemplate(final int classId)
  104. {
  105. return _charTemplates.get(ClassId.getClassId(classId));
  106. }
  107. public static final CharTemplateTable getInstance()
  108. {
  109. return SingletonHolder._instance;
  110. }
  111. private static class SingletonHolder
  112. {
  113. protected static final CharTemplateTable _instance = new CharTemplateTable();
  114. }
  115. }