CharTemplateTable.java 4.4 KB

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