CharTemplateTable.java 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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.PreparedStatement;
  18. import java.sql.ResultSet;
  19. import java.sql.SQLException;
  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. Connection con = null;
  39. try
  40. {
  41. con = L2DatabaseFactory.getInstance().getConnection();
  42. final PreparedStatement statement = con.prepareStatement("SELECT * FROM char_templates, lvlupgain WHERE char_templates.classId = lvlupgain.classId ORDER BY char_templates.ClassId");
  43. final ResultSet rset = statement.executeQuery();
  44. StatsSet set;
  45. int cId;
  46. while (rset.next())
  47. {
  48. set = new StatsSet();
  49. cId = rset.getInt("ClassId");
  50. set.set("classId", cId);
  51. set.set("className", rset.getString("className"));
  52. set.set("raceId", rset.getInt("raceId"));
  53. set.set("baseSTR", rset.getInt("STR"));
  54. set.set("baseCON", rset.getInt("CON"));
  55. set.set("baseDEX", rset.getInt("DEX"));
  56. set.set("baseINT", rset.getInt("_INT"));
  57. set.set("baseWIT", rset.getInt("WIT"));
  58. set.set("baseMEN", rset.getInt("MEN"));
  59. set.set("baseHpMax", rset.getFloat("defaultHpBase"));
  60. set.set("lvlHpAdd", rset.getFloat("defaultHpAdd"));
  61. set.set("lvlHpMod", rset.getFloat("defaultHpMod"));
  62. set.set("baseMpMax", rset.getFloat("defaultMpBase"));
  63. set.set("baseCpMax", rset.getFloat("defaultCpBase"));
  64. set.set("lvlCpAdd", rset.getFloat("defaultCpAdd"));
  65. set.set("lvlCpMod", rset.getFloat("defaultCpMod"));
  66. set.set("lvlMpAdd", rset.getFloat("defaultMpAdd"));
  67. set.set("lvlMpMod", rset.getFloat("defaultMpMod"));
  68. set.set("baseHpReg", 1.5);
  69. set.set("baseMpReg", 0.9);
  70. set.set("basePAtk", rset.getInt("p_atk"));
  71. set.set("basePDef", /* classId.isMage()? 77 : 129 */rset.getInt("p_def"));
  72. set.set("baseMAtk", rset.getInt("m_atk"));
  73. set.set("baseMDef", rset.getInt("char_templates.m_def"));
  74. set.set("classBaseLevel", rset.getInt("class_lvl"));
  75. set.set("basePAtkSpd", rset.getInt("p_spd"));
  76. set.set("baseMAtkSpd", /* classId.isMage()? 166 : 333 */rset.getInt("char_templates.m_spd"));
  77. set.set("baseCritRate", rset.getInt("char_templates.critical") / 10);
  78. set.set("baseRunSpd", rset.getInt("move_spd"));
  79. set.set("baseWalkSpd", 0);
  80. set.set("baseShldDef", 0);
  81. set.set("baseShldRate", 0);
  82. set.set("baseAtkRange", 40);
  83. set.set("spawnX", rset.getInt("x"));
  84. set.set("spawnY", rset.getInt("y"));
  85. set.set("spawnZ", rset.getInt("z"));
  86. set.set("collision_radius", rset.getDouble("m_col_r"));
  87. set.set("collision_height", rset.getDouble("m_col_h"));
  88. set.set("collision_radius_female", rset.getDouble("f_col_r"));
  89. set.set("collision_height_female", rset.getDouble("f_col_h"));
  90. final L2PcTemplate ct = new L2PcTemplate(set, InitialEquipmentData.getInstance().getEquipmentList(cId));
  91. _charTemplates.put(ClassId.getClassId(cId), ct);
  92. }
  93. rset.close();
  94. statement.close();
  95. _log.info("CharTemplateTable: Loaded " + _charTemplates.size() + " Character Templates.");
  96. }
  97. catch (SQLException e)
  98. {
  99. _log.log(Level.SEVERE, "Failed loading char templates", e);
  100. }
  101. finally
  102. {
  103. L2DatabaseFactory.close(con);
  104. }
  105. }
  106. public L2PcTemplate getTemplate(final ClassId classId)
  107. {
  108. return _charTemplates.get(classId);
  109. }
  110. public L2PcTemplate getTemplate(final int classId)
  111. {
  112. return _charTemplates.get(ClassId.getClassId(classId));
  113. }
  114. public static final CharTemplateTable getInstance()
  115. {
  116. return SingletonHolder._instance;
  117. }
  118. private static class SingletonHolder
  119. {
  120. protected static final CharTemplateTable _instance = new CharTemplateTable();
  121. }
  122. }