Profession Starter Clothing: Added UniformBoxService and ItemDatabase, updated radials and CharacterCreationService

This commit is contained in:
dennise1975
2016-03-03 20:59:59 -06:00
parent 067526a616
commit c9afd33e7c
6 changed files with 193 additions and 2 deletions

View File

@@ -0,0 +1,7 @@
function getOptions(options) {
options.add(new RadialOption(RadialItem.ITEM_USE));
options.add(new RadialOption(RadialItem.EXAMINE));
}
function handleSelection(player, target, selection) {
}

View File

@@ -4,4 +4,5 @@ object/tangible/terminal/shared_terminal_bank.iff terminal/bank
object/tangible/terminal/shared_terminal_bazaar.iff terminal/bazaar
object/tangible/terminal/shared_terminal_travel.iff terminal/travel
object/tangible/travel/ticket_collector/shared_ticket_collector.iff terminal/ticket_collector
object/tangible/travel/travel_ticket/base/shared_base_travel_ticket.iff terminal/ticket
object/tangible/travel/travel_ticket/base/shared_base_travel_ticket.iff terminal/ticket
object/tangible/npe/shared_npe_uniform_box.iff object/usable

View File

@@ -0,0 +1,52 @@
package resources.server_info;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import resources.client_info.ClientFactory;
public class ItemDatabase implements AutoCloseable{
private static final String GET_IFF_TEMPLATE_SQL = "SELECT iff_template FROM master_item where item_name = ?";
private RelationalServerData database;
private PreparedStatement getIffTemplateStatement;
public ItemDatabase() {
database = RelationalServerFactory.getServerData("items/master_item.db", "master_item");
if (database == null)
throw new main.ProjectSWG.CoreException("Database master_item failed to load");
getIffTemplateStatement = database.prepareStatement(GET_IFF_TEMPLATE_SQL);
}
@Override
public void close() throws Exception {
try {
getIffTemplateStatement.close();
} catch (SQLException e) {
e.printStackTrace();
}
database.close();
}
public String getIffTemplate(String item_name){
synchronized (getIffTemplateStatement) {
try{
getIffTemplateStatement.setString(1, item_name);
try (ResultSet set = getIffTemplateStatement.executeQuery()) {
if (set.next()){
return ClientFactory.formatToSharedFile(set.getString(set.findColumn("iff_template")));
}
}
}catch (SQLException e) {
e.printStackTrace();
}
}
return "";
}
}

View File

@@ -40,6 +40,7 @@ import services.CoreManager;
import services.chat.ChatManager;
import services.galaxy.travel.TravelService;
import services.objects.ObjectManager;
import services.objects.UniformBoxService;
import services.player.PlayerManager;
public class GalacticManager extends Manager {
@@ -49,6 +50,7 @@ public class GalacticManager extends Manager {
private final GameManager gameManager;
private final ChatManager chatManager;
private final TravelService travelService;
private final UniformBoxService uniformBox;
private final Map<Long, Intent> prevIntentMap;
public GalacticManager() {
@@ -57,6 +59,7 @@ public class GalacticManager extends Manager {
gameManager = new GameManager();
chatManager = new ChatManager();
travelService = new TravelService(objectManager);
uniformBox = new UniformBoxService(objectManager);
prevIntentMap = new Hashtable<>();
addChildService(objectManager);
@@ -64,6 +67,7 @@ public class GalacticManager extends Manager {
addChildService(gameManager);
addChildService(chatManager);
addChildService(travelService);
addChildService(uniformBox);
registerForIntent(InboundPacketIntent.TYPE);
registerForIntent(ConnectionOpenedIntent.TYPE);

View File

@@ -0,0 +1,124 @@
package services.objects;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Collection;
import intents.radial.RadialSelectionIntent;
import resources.control.Intent;
import resources.control.Service;
import resources.objects.SWGObject;
import resources.objects.creature.CreatureObject;
import resources.objects.player.PlayerObject;
import resources.player.Player;
import resources.server_info.ItemDatabase;
import resources.server_info.RelationalServerData;
import resources.server_info.RelationalServerFactory;
public class UniformBoxService extends Service {
//TODO: Display loot box
private final String uniformBoxTemplate = "object/tangible/npe/shared_npe_uniform_box.iff";
private static final String GET_UNIFORMBOX_SQL = "SELECT * FROM npe_uniformbox where profession = ? AND race = ? AND (gender = ? OR gender = 3)";
private final ObjectManager objectManager;
private RelationalServerData uniformBoxDatabase;
private PreparedStatement getUniformBoxStatement;
public UniformBoxService(ObjectManager objectManager){
this.objectManager = objectManager;
uniformBoxDatabase = RelationalServerFactory.getServerData("player/npe_uniformbox.db", "npe_uniformbox");
if (uniformBoxDatabase == null)
throw new main.ProjectSWG.CoreException("Unable to load npe_uniformbox.sdb file for UniformBoxService");
getUniformBoxStatement = uniformBoxDatabase.prepareStatement(GET_UNIFORMBOX_SQL);
registerForIntent(RadialSelectionIntent.TYPE);
}
@Override
public void onIntentReceived(Intent i) {
if ((((RadialSelectionIntent) i).getTarget().getTemplate()).equals(uniformBoxTemplate)){
processUseUniformBox(((RadialSelectionIntent) i).getPlayer());
}
}
private void processUseUniformBox(Player player){
CreatureObject creature = player.getCreatureObject();
PlayerObject playerObj = creature.getPlayerObject();
SWGObject ghost = player.getCreatureObject();
SWGObject inventory = ghost.getSlottedObject("inventory");
String profession = playerObj.getProfession().substring(0, playerObj.getProfession().lastIndexOf("_"));
String race = creature.getRace().toString().substring(0, creature.getRace().toString().indexOf("_")).toLowerCase();
String gender = creature.getRace().toString().substring(creature.getRace().toString().lastIndexOf("_") + 1).toLowerCase();
destroyUniformBox(creature);
handleCreateItems(inventory, gender, profession, race);
}
private void handleCreateItems(SWGObject inventory, String playerGender, String profession, String race) {
String gender = getGenderValue(playerGender);
try {
getUniformBoxStatement.setString(1, profession);
getUniformBoxStatement.setString(2, race);
getUniformBoxStatement.setString(3, gender);
try (ResultSet set = getUniformBoxStatement.executeQuery()) {
if (set.next()){
for (int i = 4; i <= 13; i++){
if (!set.getObject(i).toString().isEmpty()){
SWGObject item = objectManager.createObject(getItemIffTemplate(set.getObject(i).toString()));
item.moveToContainer(inventory);
}
}
}
}
} catch (SQLException e) {
e.printStackTrace();
}
}
private String getGenderValue(String gender){
switch (gender) {
case "male":
return "1";
case "female":
return "2";
}
return null;
}
private String getItemIffTemplate(String item_name){
String template = "";
try (ItemDatabase db = new ItemDatabase()){
template = db.getIffTemplate(item_name);
} catch (Exception e) {
e.printStackTrace();
}
return template;
}
private void destroyUniformBox(CreatureObject creature){
Collection<SWGObject> items = creature.getItemsByTemplate("inventory", uniformBoxTemplate);
for (SWGObject item : items){
if (item.getTemplate().equals(uniformBoxTemplate)){
objectManager.destroyObject(item);
}
}
}
}

View File

@@ -420,7 +420,10 @@ public class CharacterCreationService extends Service {
item.moveToContainer(player, player);
player.addEquipment(item);
}
SWGObject inventory = player.getSlottedObject("inventory");
SWGObject item = objManager.createObject("object/tangible/npe/shared_npe_uniform_box.iff");
inventory.addObject(item);
}
private void loadProfTemplates() {