Deprecated old QuestData, updated all references to use the new QuestData structure

Refactored pets, all pet logic decoupled from the UI. This should make adding/changing pets much easier.
This commit is contained in:
jendave
2011-08-06 17:29:03 +00:00
parent 26a2cf7757
commit e9594c88b9
43 changed files with 10801 additions and 11545 deletions

28
.gitattributes vendored
View File

@@ -7256,7 +7256,7 @@ src/forge/GUI_DeckAnalysis.java -text svneol=native#text/plain
src/forge/GUI_Filter.java -text svneol=native#text/plain
src/forge/GUI_ImportPicture.java -text svneol=native#text/plain
src/forge/GUI_Quest_Filter.java -text svneol=native#text/plain
src/forge/GameAction.java -text svneol=native#text/plain
src/forge/GameAction.java svneol=native#text/plain
src/forge/GameActionUtil.java -text svneol=native#text/plain
src/forge/GameInfo.java -text svneol=native#text/plain
src/forge/Generate2ColorDeck.java -text svneol=native#text/plain
@@ -7268,7 +7268,7 @@ src/forge/GenerateSealedDeck.java svneol=native#text/plain
src/forge/GenerateThemeDeck.java -text svneol=native#text/plain
src/forge/GuiDisplay.java svneol=native#text/plain
src/forge/GuiDisplay2.java svneol=native#text/plain
src/forge/GuiDisplay3.java -text svneol=native#text/plain
src/forge/GuiDisplay3.java svneol=native#text/plain
src/forge/GuiDisplay4.java svneol=native#text/plain
src/forge/GuiDisplayUtil.java svneol=native#text/plain
src/forge/GuiInput.java svneol=native#text/plain
@@ -7281,23 +7281,23 @@ src/forge/Gui_DownloadPictures.java svneol=native#text/plain
src/forge/Gui_DownloadPictures_LQ.java -text svneol=native#text/plain
src/forge/Gui_DownloadPrices.java -text svneol=native#text/plain
src/forge/Gui_DownloadSetPictures_LQ.java -text svneol=native#text/plain
src/forge/Gui_ElixirShop.java -text svneol=native#text/plain
src/forge/Gui_Gear.java -text svneol=native#text/plain
src/forge/Gui_Library.java -text svneol=native#text/plain
src/forge/Gui_ElixirShop.java svneol=native#text/plain
src/forge/Gui_Gear.java svneol=native#text/plain
src/forge/Gui_Library.java svneol=native#text/plain
src/forge/Gui_MultipleBlockers.java svneol=native#text/plain
src/forge/Gui_NewGame.java svneol=native#text/plain
src/forge/Gui_PetShop.java -text svneol=native#text/plain
src/forge/Gui_PlantShop.java -text svneol=native#text/plain
src/forge/Gui_PetShop.java svneol=native#text/plain
src/forge/Gui_PlantShop.java svneol=native#text/plain
src/forge/Gui_Quest.java svneol=native#text/plain
src/forge/Gui_QuestOptions.java svneol=native#text/plain
src/forge/Gui_Quest_Assignments.java svneol=native#text/plain
src/forge/Gui_Quest_DeckEditor.java -text svneol=native#text/plain
src/forge/Gui_Quest_DeckEditor_Menu.java -text svneol=native#text/plain
src/forge/Gui_Quest_DeckEditor.java svneol=native#text/plain
src/forge/Gui_Quest_DeckEditor_Menu.java svneol=native#text/plain
src/forge/Gui_Quest_Deck_Info.java svneol=native#text/plain
src/forge/Gui_SealedDeck.java svneol=native#text/plain
src/forge/Gui_SetEditor.java svneol=native#text/plain
src/forge/Gui_Shops.java -text svneol=native#text/plain
src/forge/Gui_Treasury.java -text svneol=native#text/plain
src/forge/Gui_Treasury.java svneol=native#text/plain
src/forge/Gui_Welcome.java svneol=native#text/plain
src/forge/Gui_WinLose.java svneol=native#text/plain
src/forge/HandSizeOp.java -text svneol=native#text/plain
@@ -7350,15 +7350,15 @@ src/forge/PrintCardNames.java svneol=native#text/plain
src/forge/PrintCardPictures.java svneol=native#text/plain
src/forge/QuestData.java svneol=native#text/plain
src/forge/QuestData_BoosterPack.java svneol=native#text/plain
src/forge/QuestData_Prefs.java -text svneol=native#text/plain
src/forge/QuestData_Prefs.java svneol=native#text/plain
src/forge/QuestData_State.java svneol=native#text/plain
src/forge/QuestUtil.java -text svneol=native#text/plain
src/forge/QuestUtil.java svneol=native#text/plain
src/forge/Quest_Assignment.java -text svneol=native#text/plain
src/forge/ReadBoosterPack.java svneol=native#text/plain
src/forge/ReadCard.java svneol=native#text/plain
src/forge/ReadDraftBoosterPack.java -text svneol=native#text/plain
src/forge/ReadPriceList.java -text svneol=native#text/plain
src/forge/ReadQuest_Assignment.java -text svneol=native#text/plain
src/forge/ReadQuest_Assignment.java svneol=native#text/plain
src/forge/Run.java svneol=native#text/plain
src/forge/RunTest.java svneol=native#text/plain
src/forge/SetInfo.java -text svneol=native#text/plain
@@ -7428,8 +7428,8 @@ src/forge/quest/data/QuestUtil.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetAbstract.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetBird.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetCrocodile.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetFactory.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetHound.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetManager.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetPlant.java svneol=native#text/plain
src/forge/quest/data/pet/QuestPetWolf.java svneol=native#text/plain
src/forge/quest/gui/QuestAbstractPanel.java svneol=native#text/plain

View File

@@ -19,6 +19,8 @@ import java.util.Map.Entry;
*
* @author Clemens Koza
*/
@SuppressWarnings({"deprecation"})
@Deprecated
public class QuestData_State implements Serializable {
private static final long serialVersionUID = 7007940230351051937L;

View File

@@ -1,13 +1,13 @@
package forge;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
public class AllZone implements NewConstants {
//only for testing, should read decks from local directory
@@ -16,7 +16,7 @@ public class AllZone implements NewConstants {
public static final Player HumanPlayer = new HumanPlayer("Human");
public static final Player ComputerPlayer = new AIPlayer("Computer");
public static QuestData QuestData = null;
public static forge.quest.data.QuestData QuestData = null;
public static Quest_Assignment QuestAssignment = null;
public static final NameChanger NameChanger = new NameChanger();

View File

@@ -2,12 +2,13 @@
package forge;
import forge.quest.data.QuestMatchState;
import javax.swing.*;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import javax.swing.ImageIcon;
public interface Constant {
public static final String ProgramName = "Forge - http://cardforge.org";
@@ -17,7 +18,7 @@ public interface Constant {
public static final Deck[] HumanDeck = new Deck[1];
public static final Deck[] ComputerDeck = new Deck[1];
public static final String[] GameType = new String[1];
public static final WinLose WinLose = new WinLose();
public static final QuestMatchState matchState = new QuestMatchState();
public static final boolean[] Smooth = new boolean[1];
public static final boolean[] Mill = new boolean[1];
public static final boolean[] DevMode = new boolean[1]; // one for normal mode one for quest mode

View File

@@ -2,20 +2,13 @@
package forge;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Comparator;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Random;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import forge.gui.GuiUtils;
import forge.properties.ForgeProps;
import forge.properties.NewConstants.LANG.GameAction.GAMEACTION_TEXT;
import javax.swing.*;
import java.util.*;
public class GameAction {
public void resetActivationsPerTurn(){
@@ -418,15 +411,15 @@ public class GameAction {
Player computer = AllZone.ComputerPlayer;
Player human = AllZone.HumanPlayer;
int gameWon = Constant.Runtime.WinLose.getWin();
int gameWon = Constant.Runtime.matchState.getWin();
if (human.hasWon()){ // Winning Conditions can be worth more than losing conditions
// Human wins
humanWins = true;
if (human.getAltWin()){
Constant.Runtime.WinLose.setWinMethod(gameWon, human.getWinCondition());
Constant.Runtime.matchState.setWinMethod(gameWon, human.getWinCondition());
}
Constant.Runtime.WinLose.addWin();
Constant.Runtime.matchState.addWin();
}
else if (computer.hasLost()){
@@ -434,9 +427,9 @@ public class GameAction {
humanWins = true;
if (computer.getAltLose()){
Constant.Runtime.WinLose.setWinMethod(gameWon, computer.getLoseCondition());
Constant.Runtime.matchState.setWinMethod(gameWon, computer.getLoseCondition());
}
Constant.Runtime.WinLose.addWin();
Constant.Runtime.matchState.addWin();
}
@@ -448,7 +441,7 @@ public class GameAction {
// Computer wins
computerWins = true;
Constant.Runtime.WinLose.addLose();
Constant.Runtime.matchState.addLose();
}
return humanWins || computerWins;
@@ -2250,7 +2243,7 @@ public class GameAction {
AllZone.HumanPlayer.setLife(humanLife, null);
if (qa != null){
computer.addAll(QuestUtil.getComputerCreatures(AllZone.QuestData, AllZone.QuestAssignment).toArray());
computer.addAll(forge.quest.data.QuestUtil.getComputerCreatures(AllZone.QuestData, AllZone.QuestAssignment).toArray());
}
for (Card c : human)
@@ -2418,7 +2411,7 @@ public class GameAction {
}
// Only cut/coin toss if it's the first game of the match
if (Constant.Runtime.WinLose.countWinLose() == 0)
if (Constant.Runtime.matchState.countWinLose() == 0)
{
// New code to determine who goes first. Delete this if it doesn't work properly
if(Start_Cut)
@@ -2426,7 +2419,7 @@ public class GameAction {
else
seeWhoPlaysFirst_CoinToss();
}
else if (Constant.Runtime.WinLose.didWinRecently()) // if player won last, AI starts
else if (Constant.Runtime.matchState.didWinRecently()) // if player won last, AI starts
computerStartsGame();
for(int i = 0; i < 7; i++) {

View File

@@ -2,24 +2,6 @@
package forge;
import java.awt.BorderLayout;
import java.awt.Frame;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseMotionAdapter;
import java.util.Observable;
import java.util.Observer;
import javax.swing.JCheckBoxMenuItem;
import javax.swing.JLabel;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JPanel;
import javax.swing.JSeparator;
import forge.gui.GuiUtils;
import forge.gui.game.CardDetailPanel;
import forge.gui.game.CardPanel;
@@ -27,6 +9,13 @@ import forge.gui.game.CardPicturePanel;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import java.awt.BorderLayout;
import java.awt.Frame;
import java.awt.event.*;
import java.util.Observable;
import java.util.Observer;
public class GuiDisplay2 extends javax.swing.JFrame implements CardContainer, Display, NewConstants {
private static final long serialVersionUID = 8974795337536720207L;
@@ -109,7 +98,7 @@ public class GuiDisplay2 extends javax.swing.JFrame implements CardContainer, Di
concedeGame.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent actionEvent) {
dispose();
Constant.Runtime.WinLose.addLose();
Constant.Runtime.matchState.addLose();
new Gui_WinLose();
}
});
@@ -796,7 +785,7 @@ public class GuiDisplay2 extends javax.swing.JFrame implements CardContainer, Di
private void exitForm(java.awt.event.WindowEvent evt)//GEN-FIRST:event_exitForm
{
dispose();
Constant.Runtime.WinLose.addLose();
Constant.Runtime.matchState.addLose();
new Gui_WinLose();
}//GEN-LAST:event_exitForm

View File

@@ -2,63 +2,6 @@
package forge;
import static org.jdesktop.swingx.MultiSplitLayout.parseModel;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.Font;
import java.awt.Frame;
import java.awt.GridLayout;
import java.awt.Insets;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseMotionAdapter;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.beans.XMLDecoder;
import java.beans.XMLEncoder;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Observable;
import java.util.Observer;
import javax.swing.Action;
import javax.swing.BorderFactory;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JCheckBoxMenuItem;
import javax.swing.JDialog;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JSeparator;
import javax.swing.JTextArea;
import javax.swing.ScrollPaneConstants;
import javax.swing.SwingConstants;
import javax.swing.border.Border;
import javax.swing.border.EmptyBorder;
import javax.swing.border.EtchedBorder;
import javax.swing.border.TitledBorder;
import org.jdesktop.swingx.JXMultiSplitPane;
import org.jdesktop.swingx.MultiSplitLayout.Node;
import forge.error.ErrorViewer;
import forge.gui.ForgeAction;
import forge.gui.GuiUtils;
@@ -68,6 +11,24 @@ import forge.gui.game.CardPicturePanel;
import forge.properties.ForgePreferences;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import org.jdesktop.swingx.JXMultiSplitPane;
import org.jdesktop.swingx.MultiSplitLayout.Node;
import javax.swing.*;
import javax.swing.border.Border;
import javax.swing.border.EmptyBorder;
import javax.swing.border.EtchedBorder;
import javax.swing.border.TitledBorder;
import java.awt.*;
import java.awt.Color;
import java.awt.event.*;
import java.beans.XMLDecoder;
import java.beans.XMLEncoder;
import java.io.*;
import java.util.Observable;
import java.util.Observer;
import static org.jdesktop.swingx.MultiSplitLayout.parseModel;
public class GuiDisplay3 extends JFrame implements CardContainer, Display, NewConstants, NewConstants.GUI.GuiDisplay, NewConstants.LANG.GuiDisplay {
private static final long serialVersionUID = 4519302185194841060L;
@@ -1007,15 +968,15 @@ public class GuiDisplay3 extends JFrame implements CardContainer, Display, NewCo
private void concede() {
savePrefs();
dispose();
Constant.Runtime.WinLose.addLose();
Constant.Runtime.matchState.addLose();
if (!Constant.Quest.fantasyQuest[0])
new Gui_WinLose();
else {
//new Gui_WinLose(Constant.Quest.humanList[0], Constant.Quest.computerList[0],Constant.Quest.humanLife[0], Constant.Quest.computerLife[0]);
CardList humanList = QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
CardList computerList = QuestUtil.getComputerCreatures(AllZone.QuestData, AllZone.QuestAssignment);
CardList humanList = forge.quest.data.QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
CardList computerList = forge.quest.data.QuestUtil.getComputerCreatures(AllZone.QuestData, AllZone.QuestAssignment);
int humanLife = QuestUtil.getLife(AllZone.QuestData);
int humanLife = AllZone.QuestData.getLife();
int computerLife = 20;
if (AllZone.QuestAssignment!=null)

View File

@@ -1,68 +1,6 @@
package forge;
import static org.jdesktop.swingx.MultiSplitLayout.parseModel;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.FlowLayout;
import java.awt.Font;
import java.awt.Frame;
import java.awt.GridLayout;
import java.awt.Insets;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseMotionAdapter;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.beans.XMLDecoder;
import java.beans.XMLEncoder;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Observable;
import java.util.Observer;
import javax.swing.Action;
import javax.swing.BorderFactory;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JCheckBoxMenuItem;
import javax.swing.JDialog;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JLayeredPane;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JSeparator;
import javax.swing.JTextArea;
import javax.swing.ScrollPaneConstants;
import javax.swing.SwingConstants;
import javax.swing.SwingUtilities;
import javax.swing.border.Border;
import javax.swing.border.EmptyBorder;
import javax.swing.border.EtchedBorder;
import javax.swing.border.TitledBorder;
import org.jdesktop.swingx.JXMultiSplitPane;
import org.jdesktop.swingx.MultiSplitLayout.Node;
import arcane.ui.HandArea;
import arcane.ui.PlayArea;
import arcane.ui.ViewPanel;
@@ -75,6 +13,24 @@ import forge.gui.game.CardPanel;
import forge.properties.ForgePreferences;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import org.jdesktop.swingx.JXMultiSplitPane;
import org.jdesktop.swingx.MultiSplitLayout.Node;
import javax.swing.*;
import javax.swing.border.Border;
import javax.swing.border.EmptyBorder;
import javax.swing.border.EtchedBorder;
import javax.swing.border.TitledBorder;
import java.awt.*;
import java.awt.Color;
import java.awt.event.*;
import java.beans.XMLDecoder;
import java.beans.XMLEncoder;
import java.io.*;
import java.util.*;
import java.util.List;
import static org.jdesktop.swingx.MultiSplitLayout.parseModel;
public class GuiDisplay4 extends JFrame implements CardContainer, Display, NewConstants, NewConstants.GUI.GuiDisplay, NewConstants.LANG.GuiDisplay {
@@ -995,15 +951,15 @@ public class GuiDisplay4 extends JFrame implements CardContainer, Display, NewCo
private void concede() {
savePrefs();
dispose();
Constant.Runtime.WinLose.addLose();
Constant.Runtime.matchState.addLose();
if (!Constant.Quest.fantasyQuest[0])
new Gui_WinLose();
else {
//new Gui_WinLose(Constant.Quest.humanList[0], Constant.Quest.computerList[0],Constant.Quest.humanLife[0], Constant.Quest.computerLife[0]);
CardList humanList = QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
CardList computerList = QuestUtil.getComputerCreatures(AllZone.QuestData, AllZone.QuestAssignment);
CardList humanList = forge.quest.data.QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
CardList computerList = forge.quest.data.QuestUtil.getComputerCreatures(AllZone.QuestData, AllZone.QuestAssignment);
int humanLife = QuestUtil.getLife(AllZone.QuestData);
int humanLife = AllZone.QuestData.getLife();
int computerLife = 20;
if (AllZone.QuestAssignment!=null)

View File

@@ -2,45 +2,26 @@
package forge;
import java.awt.Color;
import java.awt.Component;
import java.awt.Container;
import java.awt.Dimension;
import java.awt.GridLayout;
import java.awt.Image;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.text.DecimalFormat;
import java.text.NumberFormat;
import java.util.ArrayList;
import java.util.Map;
import java.util.Random;
import forge.error.ErrorViewer;
import forge.gui.game.CardDetailPanel;
import forge.gui.game.CardPicturePanel;
import forge.properties.NewConstants;
import javax.swing.BorderFactory;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.SwingUtilities;
import javax.swing.*;
import javax.swing.border.Border;
import javax.swing.border.EtchedBorder;
import javax.swing.border.TitledBorder;
import javax.swing.event.MouseInputListener;
import javax.swing.table.DefaultTableCellRenderer;
import javax.swing.table.TableCellRenderer;
import forge.error.ErrorViewer;
import forge.gui.game.CardDetailPanel;
import forge.gui.game.CardPicturePanel;
import forge.properties.NewConstants;
import java.awt.Color;
import java.awt.*;
import java.awt.event.*;
import java.text.DecimalFormat;
import java.text.NumberFormat;
import java.util.ArrayList;
import java.util.Map;
import java.util.Random;
public class Gui_CardShop extends JFrame implements CardContainer, DeckDisplay, NewConstants {
@@ -84,7 +65,7 @@ public class Gui_CardShop extends JFrame implements CardContainer, DeckDisplay,
private CardPicturePanel picture = new CardPicturePanel(null);
private JPanel glassPane;
private QuestData questData;
private forge.quest.data.QuestData questData;
@Override
public void setTitle(String message) {
super.setTitle(message);
@@ -281,49 +262,57 @@ public class Gui_CardShop extends JFrame implements CardContainer, DeckDisplay,
}
else //grab existing shopList
{
ArrayList<String> shopList = questData.getShopList();
java.util.List<String> shopList = questData.getShopList();
shop = new CardList();
for(int i = 0; i < shopList.size(); i++) {
Card c = AllZone.CardFactory.getCard(shopList.get(i).toString(), null);
c.setRarity(pack.getRarity(c.getName()));
if (map.containsKey(c.getName()))
c.setValue(map.get(c.getName()));
else //card is not on pricelist
{
System.out.println("Card " + c.getName() + " is not in the price list.");
if (c.getRarity().equals("Common"))
c.setValue(10);
else if (c.getRarity().equals("Uncommon"))
c.setValue(50);
else if (c.getRarity().equals("Rare"))
c.setValue(200);
}
for (String aShopList : shopList) {
Card c = AllZone.CardFactory.getCard(aShopList, null);
c.setRarity(pack.getRarity(c.getName()));
if (map.containsKey(c.getName())) {
c.setValue(map.get(c.getName()));
}
else //card is not on pricelist
{
System.out.println("Card " + c.getName() + " is not in the price list.");
if (c.getRarity().equals("Common")) {
c.setValue(10);
}
else if (c.getRarity().equals("Uncommon")) {
c.setValue(50);
}
else if (c.getRarity().equals("Rare")) {
c.setValue(200);
}
}
shop.add(c);
}
shop.add(c);
}
}
ArrayList<String> list = questData.getCardpool();
java.util.List<String> list = questData.getCardpool();
CardList owned = new CardList();
for(int i = 0; i < list.size(); i++) {
Card c = AllZone.CardFactory.getCard(list.get(i).toString(), null);
for (String aList : list) {
Card c = AllZone.CardFactory.getCard(aList, null);
c.setRarity(pack.getRarity(c.getName()));
if (map.containsKey(c.getName()))
c.setValue(map.get(c.getName()));
if (map.containsKey(c.getName())) {
c.setValue(map.get(c.getName()));
}
else //card is not on pricelist
{
System.out.println("Card " + c.getName() + " is not in the price list.");
if (c.getRarity().equals("Common"))
c.setValue(10);
else if (c.getRarity().equals("Uncommon"))
c.setValue(50);
else if (c.getRarity().equals("Rare"))
c.setValue(200);
System.out.println("Card " + c.getName() + " is not in the price list.");
if (c.getRarity().equals("Common")) {
c.setValue(10);
}
else if (c.getRarity().equals("Uncommon")) {
c.setValue(50);
}
else if (c.getRarity().equals("Rare")) {
c.setValue(200);
}
}
owned.add(c);
owned.add(c);
}
customMenu.populateShop(shop, owned);
@@ -402,7 +391,7 @@ public class Gui_CardShop extends JFrame implements CardContainer, DeckDisplay,
if (multi > 0.6)
multi = 0.6;
if (questData.getMode().equals(QuestData.FANTASY))
if (questData.getMode().equals(forge.quest.data.QuestData.FANTASY))
{
if (questData.getEstatesLevel()==1)
multi+=0.01;
@@ -443,7 +432,7 @@ public class Gui_CardShop extends JFrame implements CardContainer, DeckDisplay,
// setExtendedState(Frame.MAXIMIZED_BOTH);
}//setupAndDisplay()
public Gui_CardShop(QuestData qd) {
public Gui_CardShop(forge.quest.data.QuestData qd) {
questData = qd;
try {
jbInit();
@@ -625,7 +614,7 @@ public class Gui_CardShop extends JFrame implements CardContainer, DeckDisplay,
creditsLabel.setText("Total credits: " + questData.getCredits());
//remove sold cards from all decks:
ArrayList<String> deckNames = questData.getDeckNames();
java.util.List<String> deckNames = questData.getDeckNames();
for (String deckName:deckNames)
{
Deck deck = questData.getDeck(deckName);
@@ -633,7 +622,7 @@ public class Gui_CardShop extends JFrame implements CardContainer, DeckDisplay,
{
//count occurences:
int cardPoolCount = 0;
ArrayList<String> cpList = questData.getCards();
java.util.List<String> cpList = questData.getCards();
while(cpList.contains(c.getName()))
{
cpList.remove(cpList.indexOf(c.getName()));

View File

@@ -1,5 +1,10 @@
package forge;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Rectangle;
@@ -7,16 +12,6 @@ import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;
import java.io.File;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
public class Gui_ElixirShop extends JFrame implements NewConstants{
private static final long serialVersionUID = 2409591658245091210L;
@@ -36,7 +31,7 @@ public class Gui_ElixirShop extends JFrame implements NewConstants{
private JButton buyPotionButton = new JButton();
private JButton quitButton = new JButton();
private QuestData questData = AllZone.QuestData;
private forge.quest.data.QuestData questData = AllZone.QuestData;
public Gui_ElixirShop(JFrame parent) {
try {
@@ -193,7 +188,7 @@ public class Gui_ElixirShop extends JFrame implements NewConstants{
void buyPotionButton_actionPerformed(ActionEvent e) throws Exception {
questData.subtractCredits(getPrice());
questData.addLife(1);
QuestData.saveData(questData);
questData.saveData();
jbInit();
}
@@ -206,7 +201,7 @@ public class Gui_ElixirShop extends JFrame implements NewConstants{
}
void quitButton_actionPerformed(ActionEvent e) {
QuestData.saveData(questData);
questData.saveData();
//new Gui_Shops();
shopsGUI.setVisible(true);

View File

@@ -1,5 +1,10 @@
package forge;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Rectangle;
@@ -7,16 +12,6 @@ import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;
import java.io.File;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
public class Gui_Gear extends JFrame implements NewConstants{
private static final long serialVersionUID = -2124386606846472829L;
@@ -36,7 +31,7 @@ public class Gui_Gear extends JFrame implements NewConstants{
private JButton gearButton = new JButton();
private JButton quitButton = new JButton();
private QuestData questData = AllZone.QuestData;
private forge.quest.data.QuestData questData = AllZone.QuestData;
public Gui_Gear(JFrame parent) {
try {
@@ -194,7 +189,7 @@ public class Gui_Gear extends JFrame implements NewConstants{
{
questData.addGearLevel(1);
}
QuestData.saveData(questData);
questData.saveData();
jbInit();
}
@@ -207,7 +202,7 @@ public class Gui_Gear extends JFrame implements NewConstants{
}
void quitButton_actionPerformed(ActionEvent e) {
QuestData.saveData(questData);
questData.saveData();
//new Gui_Shops();
shopsGUI.setVisible(true);

View File

@@ -1,5 +1,10 @@
package forge;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Rectangle;
@@ -7,16 +12,6 @@ import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;
import java.io.File;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
public class Gui_Library extends JFrame implements NewConstants{
private static final long serialVersionUID = 2409591658245091210L;
@@ -36,7 +31,7 @@ public class Gui_Library extends JFrame implements NewConstants{
private JButton sleightOfHandButton= new JButton();
private JButton quitButton = new JButton();
private QuestData questData = AllZone.QuestData;
private forge.quest.data.QuestData questData = AllZone.QuestData;
public Gui_Library(JFrame parent) {
try {
@@ -182,7 +177,7 @@ public class Gui_Library extends JFrame implements NewConstants{
{
questData.addSleightOfHandLevel(1);
}
QuestData.saveData(questData);
questData.saveData();
jbInit();
}
@@ -195,7 +190,7 @@ public class Gui_Library extends JFrame implements NewConstants{
}
void quitButton_actionPerformed(ActionEvent e) {
QuestData.saveData(questData);
questData.saveData();
//new Gui_Shops();
shopsGUI.setVisible(true);

View File

@@ -1,5 +1,24 @@
package forge;
import arcane.ui.util.ManaSymbols;
import arcane.util.MultiplexOutputStream;
import com.esotericsoftware.minlog.Log;
import forge.error.ErrorViewer;
import forge.error.ExceptionHandler;
import forge.gui.GuiUtils;
import forge.gui.ListChooser;
import forge.properties.ForgePreferences;
import forge.properties.ForgePreferences.CardSizeType;
import forge.properties.ForgePreferences.StackOffsetType;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import forge.properties.NewConstants.LANG.Gui_NewGame.MENU_BAR.MENU;
import forge.properties.NewConstants.LANG.Gui_NewGame.MENU_BAR.OPTIONS;
import net.miginfocom.swing.MigLayout;
import javax.swing.*;
import javax.swing.UIManager.LookAndFeelInfo;
import javax.swing.border.TitledBorder;
import java.awt.Color;
import java.awt.Component;
import java.awt.Font;
@@ -8,59 +27,8 @@ import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.io.PrintStream;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Random;
import javax.swing.AbstractAction;
import javax.swing.Action;
import javax.swing.BorderFactory;
import javax.swing.ButtonGroup;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JCheckBoxMenuItem;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JRadioButton;
import javax.swing.JTextArea;
import javax.swing.SwingConstants;
import javax.swing.SwingUtilities;
import javax.swing.UIManager;
import javax.swing.UIManager.LookAndFeelInfo;
import javax.swing.border.TitledBorder;
import net.miginfocom.swing.MigLayout;
import arcane.ui.util.ManaSymbols;
import arcane.util.MultiplexOutputStream;
import com.esotericsoftware.minlog.Log;
import forge.error.ErrorViewer;
import forge.error.ExceptionHandler;
import forge.gui.GuiUtils;
import forge.gui.ListChooser;
import forge.properties.ForgePreferences;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import forge.properties.ForgePreferences.CardSizeType;
import forge.properties.ForgePreferences.StackOffsetType;
import forge.properties.NewConstants.LANG.Gui_NewGame.MENU_BAR.MENU;
import forge.properties.NewConstants.LANG.Gui_NewGame.MENU_BAR.OPTIONS;
import java.io.*;
import java.util.*;
/*CHOPPIC*/
@@ -193,7 +161,7 @@ public class Gui_NewGame extends JFrame implements NewConstants, NewConstants.LA
AllZone.QuestData = null;
allDecks = getDecks();
Constant.Runtime.WinLose.reset();
Constant.Runtime.matchState.reset();
if(Constant.Runtime.width[0] == 0) Constant.Runtime.width[0] = 70;

View File

@@ -1,5 +1,10 @@
package forge;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Rectangle;
@@ -7,40 +12,30 @@ import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;
import java.io.File;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
public class Gui_PetShop extends JFrame implements NewConstants {
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
private static final long serialVersionUID = -2910767196498677881L;
private JFrame shopsGUI;
private JLabel titleLabel = new JLabel();
public class Gui_PetShop extends JFrame implements NewConstants{
private JLabel petDescLabel = new JLabel();
private JLabel petStatsLabel = new JLabel();
private JLabel petPriceLabel = new JLabel();
private JLabel petIconLabel = new JLabel();
private static final long serialVersionUID = -2910767196498677881L;
private JFrame shopsGUI;
private JLabel titleLabel = new JLabel();
private JLabel creditsLabel = new JLabel();
private JLabel petDescLabel = new JLabel();
private JLabel petStatsLabel = new JLabel();
private JLabel petPriceLabel = new JLabel();
private JLabel petIconLabel = new JLabel();
private ImageIcon petIcon = new ImageIcon();
private JLabel creditsLabel = new JLabel();
private JButton buyPetButton = new JButton();
private JButton quitButton = new JButton();
private ImageIcon petIcon = new ImageIcon();
private JButton buyPetButton = new JButton();
private JButton quitButton = new JButton();
private QuestData questData = AllZone.QuestData;
private forge.quest.data.QuestData questData = AllZone.QuestData;
public Gui_PetShop(JFrame parent) {
try {
jbInit();
} catch(Exception ex) {
} catch (Exception ex) {
ErrorViewer.showError(ex);
}
@@ -62,332 +57,356 @@ public class Gui_PetShop extends JFrame implements NewConstants{
//only do this ONCE:
private void setup() {
//String fileName = "LeafIconSmall.png";
//ImageIcon icon = getIcon(fileName);
buyPetButton.setBounds(new Rectangle(10, 297, 120, 50));
//String fileName = "LeafIconSmall.png";
//ImageIcon icon = getIcon(fileName);
buyPetButton.setBounds(new Rectangle(10, 297, 120, 50));
buyPetButton.addActionListener(new java.awt.event.ActionListener() {
buyPetButton.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(ActionEvent e) {
try {
buyPetButton_actionPerformed(e);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
buyPetButton_actionPerformed(e);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
});
}//setup();
private String getDesc()
{
StringBuilder sb = new StringBuilder();
sb.append("<html>");
if (questData.getWolfPetLevel() == 0)
{
sb.append("This ferocious animal may have been raised<br> in captivity, but it has been trained to kill.<br>");
sb.append("Eats goblins for breakfast.<br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 1/2<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
}
else if (questData.getWolfPetLevel() == 1)
{
sb.append("Improve the toughness of your wolf.<br>");
sb.append("<u><b>Level 2</b></u>: 1/2<br>");
sb.append("<u><b>Next Level</b></u>: 2/2<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
}
else if (questData.getWolfPetLevel() == 2)
{
sb.append("Improve the attack power of your wolf.<br>");
sb.append("<u><b>Level 3</b></u>: 2/2<br>");
sb.append("<u><b>Next Level</b></u>: Flanking<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
}
else if (questData.getWolfPetLevel() == 3)
{
sb.append("Gives Flanking to your wolf.<br>");
sb.append("<u><b>Level 4</b></u>: 2/2 Flanking<br>");
}
else if (questData.getWolfPetLevel() >= 4)
{
//sb.append("Wolf Level Maxed out.<br>");
private String getDesc() {
StringBuilder sb = new StringBuilder();
sb.append("<html>");
if (questData.getPetManager().getPet("Wolf").getLevel() == 0) {
sb.append(
"This ferocious animal may have been raised<br> in captivity, but it has been trained to kill.<br>");
sb.append("Eats goblins for breakfast.<br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 1/2<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 1) {
sb.append("Improve the toughness of your wolf.<br>");
sb.append("<u><b>Level 2</b></u>: 1/2<br>");
sb.append("<u><b>Next Level</b></u>: 2/2<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 2) {
sb.append("Improve the attack power of your wolf.<br>");
sb.append("<u><b>Level 3</b></u>: 2/2<br>");
sb.append("<u><b>Next Level</b></u>: Flanking<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 3) {
sb.append("Gives Flanking to your wolf.<br>");
sb.append("<u><b>Level 4</b></u>: 2/2 Flanking<br>");
}
else if (questData.getPetManager().getPet("Wolf").getLevel() >= 4) {
//sb.append("Wolf Level Maxed out.<br>");
if (questData.getCrocPetLevel() == 0)
{
sb.append("With its razor sharp teeth, this swamp-dwelling monster is extremely dangerous.");
sb.append("Crikey mate!<br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1<br>");
sb.append("<u><b>Can learn</b></u>: Swampwalk");
}
else if (questData.getCrocPetLevel() == 1)
{
sb.append("Improve the attack power of your croc.<br>");
sb.append("<u><b>Level 2</b></u>: 2/1<br>");
sb.append("<u><b>Next Level</b></u>: 3/1<br>");
sb.append("<u><b>Can learn</b></u>: Swampwalk");
}
else if (questData.getCrocPetLevel() == 2)
{
sb.append("Improve the attack power of your croc.<br>");
sb.append("<u><b>Level 3</b></u>: 3/1<br>");
sb.append("<u><b>Next Level</b></u>: 3/1 Swampwalk<br>");
}
else if (questData.getCrocPetLevel() == 3)
{
sb.append("Gives Swampwalk to your croc.<br>");
sb.append("<u><b>Level 4</b></u>: 3/1 Swampwalk<br>");
}
/*
else if (questData.getCrocPetLevel() >= 4)
{
sb.append("Croc Level Maxed out.<br>");
}
*/
if (questData.getPetManager().getPet("Crocodile").getLevel() == 0) {
sb.append("With its razor sharp teeth, this swamp-dwelling monster is extremely dangerous.");
sb.append("Crikey mate!<br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1<br>");
sb.append("<u><b>Can learn</b></u>: Swampwalk");
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 1) {
sb.append("Improve the attack power of your croc.<br>");
sb.append("<u><b>Level 2</b></u>: 2/1<br>");
sb.append("<u><b>Next Level</b></u>: 3/1<br>");
sb.append("<u><b>Can learn</b></u>: Swampwalk");
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 2) {
sb.append("Improve the attack power of your croc.<br>");
sb.append("<u><b>Level 3</b></u>: 3/1<br>");
sb.append("<u><b>Next Level</b></u>: 3/1 Swampwalk<br>");
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 3) {
sb.append("Gives Swampwalk to your croc.<br>");
sb.append("<u><b>Level 4</b></u>: 3/1 Swampwalk<br>");
}
/*
else if (questData.getPetManager().getPet("Crocodile").getLevel() >= 4)
{
sb.append("Croc Level Maxed out.<br>");
}
*/
else if (questData.getBirdPetLevel() == 0)
{
sb.append("Unmatched in speed, agility and awareness,<br>");
sb.append("this trained hawk makes a fantastic hunter.<br><br>");
sb.append("<u><b>Level 1</b></u>: 0/1 Flying<br>");
sb.append("<u><b>Next Level</b></u>: 1/1<br>");
sb.append("<u><b>Can learn</b></u>: First strike");
}
else if (questData.getBirdPetLevel() == 1)
{
sb.append("Improve the attack power of your bird.<br>");
sb.append("<u><b>Level 2</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 <br>");
sb.append("<u><b>Can learn</b></u>: First strike");
}
else if (questData.getBirdPetLevel() == 2)
{
sb.append("Improve the attack power of your bird.<br>");
sb.append("<u><b>Level 3</b></u>: 2/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 First strike<br>");
}
else if (questData.getBirdPetLevel() == 3)
{
sb.append("Gives First strike to your bird.<br>");
sb.append("<u><b>Level 4</b></u>: 2/1 First strike<br>");
}
else if (questData.getHoundPetLevel() == 0)
{
sb.append("Dogs are said to be man's best friend.<br>");
sb.append("Definitely not this one.<br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 1/1 Haste<br>");
sb.append("<u><b>Can learn</b></u>: Whenever this creature attacks alone,<br> it gets +2/+0 until end of turn.");
}
else if (questData.getHoundPetLevel() == 1)
{
sb.append("Gives haste to your hound.<br>");
sb.append("<u><b>Level 2</b></u>: 1/1 Haste<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 Haste<br>");
sb.append("<u><b>Can learn</b></u>: Whenever this creature attacks alone,<br> it gets +2/+0 until end of turn.");
}
else if (questData.getHoundPetLevel() == 2)
{
sb.append("Improve the attack power of your hound.<br>");
sb.append("<u><b>Level 3</b></u>: 2/1 Haste<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 Whenever this creature attacks<br> alone, it gets +2/+0 until end of turn.<br>");
}
else if (questData.getHoundPetLevel() == 3)
{
sb.append("Greatly improves your hound's attack power if it<br> attacks alone.<br>");
sb.append("<u><b>Level 4</b></u>: 2/1 Haste, whenever this creature attacks alone, it gets +2/+0 until end of turn.<br>");
}
}//wolfPetLevel >= 4
else if (questData.getPetManager().getPet("Bird").getLevel() == 0) {
sb.append("Unmatched in speed, agility and awareness,<br>");
sb.append("this trained hawk makes a fantastic hunter.<br><br>");
sb.append("<u><b>Level 1</b></u>: 0/1 Flying<br>");
sb.append("<u><b>Next Level</b></u>: 1/1<br>");
sb.append("<u><b>Can learn</b></u>: First strike");
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 1) {
sb.append("Improve the attack power of your bird.<br>");
sb.append("<u><b>Level 2</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 <br>");
sb.append("<u><b>Can learn</b></u>: First strike");
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 2) {
sb.append("Improve the attack power of your bird.<br>");
sb.append("<u><b>Level 3</b></u>: 2/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 First strike<br>");
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 3) {
sb.append("Gives First strike to your bird.<br>");
sb.append("<u><b>Level 4</b></u>: 2/1 First strike<br>");
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 0) {
sb.append("Dogs are said to be man's best friend.<br>");
sb.append("Definitely not this one.<br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 1/1 Haste<br>");
sb.append(
"<u><b>Can learn</b></u>: Whenever this creature attacks alone,<br> it gets +2/+0 until end of turn.");
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 1) {
sb.append("Gives haste to your hound.<br>");
sb.append("<u><b>Level 2</b></u>: 1/1 Haste<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 Haste<br>");
sb.append(
"<u><b>Can learn</b></u>: Whenever this creature attacks alone,<br> it gets +2/+0 until end of turn.");
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 2) {
sb.append("Improve the attack power of your hound.<br>");
sb.append("<u><b>Level 3</b></u>: 2/1 Haste<br>");
sb.append(
"<u><b>Next Level</b></u>: 2/1 Whenever this creature attacks<br> alone, it gets +2/+0 until end of turn.<br>");
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 3) {
sb.append("Greatly improves your hound's attack power if it<br> attacks alone.<br>");
sb.append(
"<u><b>Level 4</b></u>: 2/1 Haste, whenever this creature attacks alone, it gets +2/+0 until end of turn.<br>");
}
}//wolfPetLevel >= 4
sb.append("</html>");
return sb.toString();
sb.append("</html>");
return sb.toString();
}
private long getPrice()
{
long l = 0;
if (questData.getWolfPetLevel() == 0)
l = 250;
else if (questData.getWolfPetLevel() == 1)
l = 250;
else if (questData.getWolfPetLevel() == 2)
l = 500;
else if (questData.getWolfPetLevel() == 3)
l = 550;
else if (questData.getWolfPetLevel() >= 4)
{
if (questData.getCrocPetLevel() == 0)
l = 250;
else if (questData.getCrocPetLevel() == 1)
l = 300;
else if (questData.getCrocPetLevel() == 2)
l = 450;
else if (questData.getCrocPetLevel() == 3)
l = 600;
else if (questData.getBirdPetLevel() == 0)
l = 200;
else if (questData.getBirdPetLevel() == 1)
l = 300;
else if (questData.getBirdPetLevel() == 2)
l = 450;
else if (questData.getBirdPetLevel() == 3)
l = 400;
else if (questData.getHoundPetLevel() == 0)
l = 200;
else if (questData.getHoundPetLevel() == 1)
l = 350;
else if (questData.getHoundPetLevel() == 2)
l = 450;
else if (questData.getHoundPetLevel() == 3)
l = 750;
}
return l;
private long getPrice() {
long l = 0;
if (questData.getPetManager().getPet("Wolf").getLevel() == 0) {
l = 250;
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 1) {
l = 250;
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 2) {
l = 500;
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 3) {
l = 550;
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 0) {
l = 250;
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 1) {
l = 300;
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 2) {
l = 450;
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 3) {
l = 600;
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 0) {
l = 200;
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 1) {
l = 300;
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 2) {
l = 450;
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 3) {
l = 400;
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 0) {
l = 200;
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 1) {
l = 350;
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 2) {
l = 450;
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 3) {
l = 750;
}
return l;
}
private String getButtonText(String pet)
{
String s = "";
if (pet.equals("Wolf")) {
if (questData.getWolfPetLevel() == 0)
s = "Buy " + pet;
else
s = "Train " + pet;
}
else if (pet.equals("Croc"))
{
if (questData.getCrocPetLevel() == 0)
s = "Buy " + pet;
else
s = "Train " + pet;
}
else if (pet.equals("Bird"))
{
if (questData.getBirdPetLevel() == 0)
s = "Buy " + pet;
else
s = "Train " + pet;
}
else if (pet.equals("Hound"))
{
if (questData.getHoundPetLevel() == 0)
s = "Buy " + pet;
else
s = "Train " + pet;
}
return s;
private String getButtonText(String pet) {
String s = "";
if (pet.equals("Wolf")) {
if (questData.getPetManager().getPet("Wolf").getLevel() == 0) {
s = "Buy " + pet;
}
else {
s = "Train " + pet;
}
}
else if (pet.equals("Croc")) {
if (questData.getPetManager().getPet("Crocodile").getLevel() == 0) {
s = "Buy " + pet;
}
else {
s = "Train " + pet;
}
}
else if (pet.equals("Bird")) {
if (questData.getPetManager().getPet("Bird").getLevel() == 0) {
s = "Buy " + pet;
}
else {
s = "Train " + pet;
}
}
else if (pet.equals("Hound")) {
if (questData.getPetManager().getPet("Hound").getLevel() == 0) {
s = "Buy " + pet;
}
else {
s = "Train " + pet;
}
}
return s;
}
private String getPetStats()
{
StringBuilder sb = new StringBuilder();
if (questData.getWolfPetLevel() < 4) {
if (questData.getWolfPetLevel() == 1)
sb.append("1/1");
else if (questData.getWolfPetLevel() == 2)
sb.append("1/2");
else if (questData.getWolfPetLevel() >= 3)
sb.append("2/2");
private String getPetStats() {
StringBuilder sb = new StringBuilder();
if (questData.getPetManager().getPet("Wolf").getLevel() < 4) {
if (questData.getPetManager().getPet("Wolf").getLevel() == 1) {
sb.append("1/1");
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 2) {
sb.append("1/2");
}
else if (questData.getPetManager().getPet("Wolf").getLevel() >= 3) {
sb.append("2/2");
}
sb.append(" Wolf Pet (current level ");
sb.append(questData.getWolfPetLevel());
} //getWolfPetLevel < 4
else if (questData.getCrocPetLevel() < 4)
{
if (questData.getCrocPetLevel() == 1)
sb.append("1/1");
else if (questData.getCrocPetLevel() == 2)
sb.append("2/1");
else if (questData.getCrocPetLevel() >= 3)
sb.append("3/1");
sb.append(" Wolf Pet (current level ");
sb.append(questData.getPetManager().getPet("Wolf").getLevel());
} //getWolfPetLevel < 4
else if (questData.getPetManager().getPet("Crocodile").getLevel() < 4) {
if (questData.getPetManager().getPet("Crocodile").getLevel() == 1) {
sb.append("1/1");
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 2) {
sb.append("2/1");
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() >= 3) {
sb.append("3/1");
}
sb.append(" Croc Pet (current level ");
sb.append(questData.getCrocPetLevel());
}
else if (questData.getBirdPetLevel() < 4)
{
if (questData.getBirdPetLevel() == 1)
sb.append("0/1");
else if (questData.getBirdPetLevel() == 2)
sb.append("1/1");
else if (questData.getBirdPetLevel() >= 3)
sb.append("2/1");
sb.append(" Croc Pet (current level ");
sb.append(questData.getPetManager().getPet("Crocodile").getLevel());
}
else if (questData.getPetManager().getPet("Bird").getLevel() < 4) {
if (questData.getPetManager().getPet("Bird").getLevel() == 1) {
sb.append("0/1");
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 2) {
sb.append("1/1");
}
else if (questData.getPetManager().getPet("Bird").getLevel() >= 3) {
sb.append("2/1");
}
sb.append(" Bird Pet (current level ");
sb.append(questData.getBirdPetLevel());
}
else if (questData.getHoundPetLevel() <= 4)
{
if (questData.getHoundPetLevel() == 1)
sb.append("1/1");
else if (questData.getHoundPetLevel() == 2)
sb.append("1/1");
else if (questData.getHoundPetLevel() >= 3)
sb.append("2/1");
sb.append(" Bird Pet (current level ");
sb.append(questData.getPetManager().getPet("Bird").getLevel());
}
else if (questData.getPetManager().getPet("Hound").getLevel() <= 4) {
if (questData.getPetManager().getPet("Hound").getLevel() == 1) {
sb.append("1/1");
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 2) {
sb.append("1/1");
}
else if (questData.getPetManager().getPet("Hound").getLevel() >= 3) {
sb.append("2/1");
}
sb.append(" Hound Pet (current level ");
sb.append(questData.getHoundPetLevel());
}
sb.append(" Hound Pet (current level ");
sb.append(questData.getPetManager().getPet("Hound").getLevel());
}
sb.append("/4)");
if (questData.getWolfPetLevel() == 0)
return "";
sb.append("/4)");
if (questData.getPetManager().getPet("Wolf").getLevel() == 0) {
return "";
}
return sb.toString();
return sb.toString();
}
private String getImageString()
{
String s = "";
if (questData.getWolfPetLevel() < 4)
{
if (questData.getWolfPetLevel() == 0)
s = "g_1_1_wolf_pet_small.jpg";
else if (questData.getWolfPetLevel() == 1)
s = "g_1_2_wolf_pet_small.jpg";
else if (questData.getWolfPetLevel() == 2)
s = "g_2_2_wolf_pet_small.jpg";
else if (questData.getWolfPetLevel() == 3)
s = "g_2_2_wolf_pet_flanking_small.jpg";
}
else if (questData.getCrocPetLevel() < 4)
{
if (questData.getCrocPetLevel() == 0)
s = "b_1_1_crocodile_pet_small.jpg";
else if (questData.getCrocPetLevel() == 1)
s = "b_2_1_crocodile_pet_small.jpg";
else if (questData.getCrocPetLevel() == 2)
s = "b_3_1_crocodile_pet_small.jpg";
else if (questData.getCrocPetLevel() == 3)
s = "b_3_1_crocodile_pet_swampwalk_small.jpg";
}
else if (questData.getBirdPetLevel() < 4)
{
if (questData.getBirdPetLevel() == 0)
s = "w_0_1_bird_pet_small.jpg";
else if (questData.getBirdPetLevel() == 1)
s = "w_1_1_bird_pet_small.jpg";
else if (questData.getBirdPetLevel() == 2)
s = "w_2_1_bird_pet_small.jpg";
else if (questData.getBirdPetLevel() == 3)
s = "w_2_1_bird_pet_first_strike_small.jpg";
}
private String getImageString() {
String s = "";
if (questData.getPetManager().getPet("Wolf").getLevel() < 4) {
if (questData.getPetManager().getPet("Wolf").getLevel() == 0) {
s = "g_1_1_wolf_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 1) {
s = "g_1_2_wolf_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 2) {
s = "g_2_2_wolf_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Wolf").getLevel() == 3) {
s = "g_2_2_wolf_pet_flanking_small.jpg";
}
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() < 4) {
if (questData.getPetManager().getPet("Crocodile").getLevel() == 0) {
s = "b_1_1_crocodile_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 1) {
s = "b_2_1_crocodile_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 2) {
s = "b_3_1_crocodile_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() == 3) {
s = "b_3_1_crocodile_pet_swampwalk_small.jpg";
}
}
else if (questData.getPetManager().getPet("Bird").getLevel() < 4) {
if (questData.getPetManager().getPet("Bird").getLevel() == 0) {
s = "w_0_1_bird_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 1) {
s = "w_1_1_bird_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 2) {
s = "w_2_1_bird_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Bird").getLevel() == 3) {
s = "w_2_1_bird_pet_first_strike_small.jpg";
}
}
else if (questData.getHoundPetLevel() < 4)
{
if (questData.getHoundPetLevel() == 0)
s = "r_1_1_hound_pet_small.jpg";
else if (questData.getHoundPetLevel() == 1)
s = "r_1_1_hound_pet_haste_small.jpg";
else if (questData.getHoundPetLevel() == 2)
s = "r_2_1_hound_pet_small.jpg";
else if (questData.getHoundPetLevel() == 3)
s = "r_2_1_hound_pet_alone_small.jpg";
}
else if (questData.getPetManager().getPet("Hound").getLevel() < 4) {
if (questData.getPetManager().getPet("Hound").getLevel() == 0) {
s = "r_1_1_hound_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 1) {
s = "r_1_1_hound_pet_haste_small.jpg";
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 2) {
s = "r_2_1_hound_pet_small.jpg";
}
else if (questData.getPetManager().getPet("Hound").getLevel() == 3) {
s = "r_2_1_hound_pet_alone_small.jpg";
}
}
return s;
return s;
}
private void jbInit() throws Exception {
@@ -419,18 +438,23 @@ public class Gui_PetShop extends JFrame implements NewConstants{
petIconLabel.setBounds(new Rectangle(280, 65, 201, 280));
petIconLabel.setIconTextGap(0);
if (questData.getWolfPetLevel() < 4)
buyPetButton.setText(getButtonText("Wolf"));
else if (questData.getCrocPetLevel() < 4)
buyPetButton.setText(getButtonText("Croc"));
else if (questData.getBirdPetLevel() < 4)
buyPetButton.setText(getButtonText("Bird"));
else if (questData.getHoundPetLevel() < 4)
buyPetButton.setText(getButtonText("Hound"));
if (questData.getPetManager().getPet("Wolf").getLevel() < 4) {
buyPetButton.setText(getButtonText("Wolf"));
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() < 4) {
buyPetButton.setText(getButtonText("Croc"));
}
else if (questData.getPetManager().getPet("Bird").getLevel() < 4) {
buyPetButton.setText(getButtonText("Bird"));
}
else if (questData.getPetManager().getPet("Hound").getLevel() < 4) {
buyPetButton.setText(getButtonText("Hound"));
}
buyPetButton.setEnabled(true);
if (questData.getCredits() < getPrice() || questData.getHoundPetLevel() >= 4)
buyPetButton.setEnabled(false);
buyPetButton.setEnabled(true);
if (questData.getCredits() < getPrice() || questData.getPetManager().getPet("Hound").getLevel() >= 4) {
buyPetButton.setEnabled(false);
}
quitButton.setBounds(new Rectangle(140, 297, 120, 50));
quitButton.setText("Quit");
@@ -449,7 +473,7 @@ public class Gui_PetShop extends JFrame implements NewConstants{
this.getContentPane().add(petIconLabel, null);
this.getContentPane().add(petPriceLabel, null);
this.getContentPane().add(creditsLabel, null);
this.getContentPane().add(quitButton,null);
this.getContentPane().add(quitButton, null);
}
void editDeckButton_actionPerformed(ActionEvent e) {
@@ -468,41 +492,44 @@ public class Gui_PetShop extends JFrame implements NewConstants{
}//editDeckButton_actionPerformed()
void buyPetButton_actionPerformed(ActionEvent e) throws Exception {
questData.subtractCredits(getPrice());
questData.subtractCredits(getPrice());
if (questData.getWolfPetLevel() < 4)
questData.addWolfPetLevel();
else if (questData.getCrocPetLevel() < 4)
questData.addCrocPetLevel();
else if (questData.getBirdPetLevel() < 4)
questData.addBirdPetLevel();
else if (questData.getHoundPetLevel() < 4)
questData.addHoundPetLevel();
if (questData.getPetManager().getPet("Wolf").getLevel() < 4) {
questData.getPetManager().addPetLevel("Wolf");
}
else if (questData.getPetManager().getPet("Crocodile").getLevel() < 4) {
questData.getPetManager().addPetLevel("Crocodile");
}
else if (questData.getPetManager().getPet("Bird").getLevel() < 4) {
questData.getPetManager().addPetLevel("Bird");
}
else if (questData.getPetManager().getPet("Hound").getLevel() < 4) {
questData.getPetManager().addPetLevel("hound");
}
QuestData.saveData(questData);
jbInit();
questData.saveData();
jbInit();
}
void restartButton_actionPerformed(ActionEvent e) {
Constant.Runtime.WinLose.reset();
Constant.Runtime.matchState.reset();
AllZone.GameAction.newGame(Constant.Runtime.HumanDeck[0], Constant.Runtime.ComputerDeck[0]);
AllZone.Display.setVisible(true);
dispose();
}
private ImageIcon getIcon(String fileName)
{
File base = ForgeProps.getFile(IMAGE_ICON);
File file = new File(base, fileName);
ImageIcon icon = new ImageIcon(file.toString());
return icon;
private ImageIcon getIcon(String fileName) {
File base = ForgeProps.getFile(IMAGE_ICON);
File file = new File(base, fileName);
ImageIcon icon = new ImageIcon(file.toString());
return icon;
}
void quitButton_actionPerformed(ActionEvent e) {
QuestData.saveData(questData);
questData.saveData();
//new Gui_Shops();
shopsGUI.setVisible(true);
shopsGUI.setVisible(true);
dispose();

View File

@@ -1,5 +1,10 @@
package forge;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Rectangle;
@@ -7,16 +12,6 @@ import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;
import java.io.File;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
public class Gui_PlantShop extends JFrame implements NewConstants{
private static final long serialVersionUID = 2409591658245091210L;
@@ -35,7 +30,7 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
private JButton buyPlantButton = new JButton();
private JButton quitButton = new JButton();
private QuestData questData = AllZone.QuestData;
private forge.quest.data.QuestData questData = AllZone.QuestData;
public Gui_PlantShop(JFrame parent) {
try {
@@ -78,7 +73,7 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
{
StringBuilder sb = new StringBuilder();
sb.append("<html>");
if (questData.getPlantLevel() == 0)
if (questData.getPetManager().getPlant().getLevel() == 0)
{
sb.append("Start each of your battles with this lush, <br> verdant plant on your side.<br>");
sb.append("Excellent at blocking the nastiest of critters!<br><br>");
@@ -86,34 +81,34 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
sb.append("<u><b>Next Level</b></u>: 0/2<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 1)
else if (questData.getPetManager().getPlant().getLevel() == 1)
{
sb.append("Improve the toughness of your plant.<br>");
sb.append("<u><b>Level 2</b></u>: 0/2<br>");
sb.append("<u><b>Next Level</b></u>: 0/3<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 2)
else if (questData.getPetManager().getPlant().getLevel() == 2)
{
sb.append("Improve the toughness of your plant.<br>");
sb.append("<u><b>Level 3</b></u>: 0/3<br>");
sb.append("<u><b>Next Level</b></u>: 1/3<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 3)
else if (questData.getPetManager().getPlant().getLevel() == 3)
{
sb.append("Improve the power of your plant.<br>");
sb.append("<u><b>Level 4</b></u>: 1/3<br>");
sb.append("<u><b>Next Level</b></u>: Deathtouch<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 4)
else if (questData.getPetManager().getPlant().getLevel() == 4)
{
sb.append("Grow venomous thorns on your plant.<br>");
sb.append("<u><b>Level 5</b></u>: Deathtouch<br>");
sb.append("<u><b>Next Level</b></u>: 1/4<br>");
}
else if (questData.getPlantLevel() == 5)
else if (questData.getPetManager().getPlant().getLevel() == 5)
{
sb.append("As well as gaining more toughness,<br>");
sb.append("your plant will have healing properties.<br>");
@@ -131,17 +126,17 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
private long getPrice()
{
long l = 0;
if (questData.getPlantLevel() == 0)
if (questData.getPetManager().getPlant().getLevel() == 0)
l = 100;
else if (questData.getPlantLevel() == 1)
else if (questData.getPetManager().getPlant().getLevel() == 1)
l = 150;
else if (questData.getPlantLevel() == 2)
else if (questData.getPetManager().getPlant().getLevel() == 2)
l = 200;
else if (questData.getPlantLevel() == 3)
else if (questData.getPetManager().getPlant().getLevel() == 3)
l = 300;
else if (questData.getPlantLevel() == 4)
else if (questData.getPetManager().getPlant().getLevel() == 4)
l = 750;
else if (questData.getPlantLevel() == 5)
else if (questData.getPetManager().getPlant().getLevel() == 5)
l = 1000;
return l;
}
@@ -149,7 +144,7 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
private String getButtonText()
{
String s = "";
if (questData.getPlantLevel() == 0)
if (questData.getPetManager().getPlant().getLevel() == 0)
s = "Buy Plant";
else
s = "Upgrade Plant";
@@ -159,21 +154,21 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
private String getStats()
{
StringBuilder sb = new StringBuilder();
if (questData.getPlantLevel() == 0)
if (questData.getPetManager().getPlant().getLevel() == 0)
sb.append("0/1");
else if (questData.getPlantLevel() == 1)
else if (questData.getPetManager().getPlant().getLevel() == 1)
sb.append("0/2");
else if (questData.getPlantLevel() == 2)
else if (questData.getPetManager().getPlant().getLevel() == 2)
sb.append("0/3");
else if (questData.getPlantLevel() == 3)
else if (questData.getPetManager().getPlant().getLevel() == 3)
sb.append("1/3");
else if (questData.getPlantLevel() == 4)
else if (questData.getPetManager().getPlant().getLevel() == 4)
sb.append("1/3");
else
sb.append("1/4");
sb.append(" Plant Wall (current level ");
sb.append(questData.getPlantLevel());
sb.append(questData.getPetManager().getPlant().getLevel());
sb.append("/6)");
return sb.toString();
@@ -182,17 +177,17 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
private String getImageString()
{
String s = "";
if (questData.getPlantLevel() == 0)
if (questData.getPetManager().getPlant().getLevel() == 0)
s = "g_0_1_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 1)
else if (questData.getPetManager().getPlant().getLevel() == 1)
s = "g_0_2_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 2)
else if (questData.getPetManager().getPlant().getLevel() == 2)
s = "g_0_3_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 3)
else if (questData.getPetManager().getPlant().getLevel() == 3)
s = "g_1_3_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 4)
else if (questData.getPetManager().getPlant().getLevel() == 4)
s = "g_1_3_plant_wall_deathtouch_small.jpg";
else if (questData.getPlantLevel() == 5)
else if (questData.getPetManager().getPlant().getLevel() == 5)
s = "g_1_4_plant_wall_small.jpg";
return s;
@@ -234,7 +229,7 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
buyPlantButton.setEnabled(true);
if (questData.getCredits() < getPrice() || questData.getPlantLevel() >= 6)
if (questData.getCredits() < getPrice() || questData.getPetManager().getPlant().getLevel() >= 6)
buyPlantButton.setEnabled(false);
quitButton.setBounds(new Rectangle(140, 297, 120, 50));
@@ -274,12 +269,12 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
void buyPlantButton_actionPerformed(ActionEvent e) throws Exception {
questData.subtractCredits(getPrice());
questData.addPlantLevel();
questData.getPetManager().addPlantLevel();
jbInit();
}
void restartButton_actionPerformed(ActionEvent e) {
Constant.Runtime.WinLose.reset();
Constant.Runtime.matchState.reset();
AllZone.GameAction.newGame(Constant.Runtime.HumanDeck[0], Constant.Runtime.ComputerDeck[0]);
AllZone.Display.setVisible(true);
@@ -295,7 +290,7 @@ public class Gui_PlantShop extends JFrame implements NewConstants{
}
void quitButton_actionPerformed(ActionEvent e) {
QuestData.saveData(questData);
questData.saveData();
//new Gui_Shops();
shopsGUI.setVisible(true);

View File

@@ -1,28 +1,20 @@
package forge;
import forge.error.ErrorViewer;
import forge.properties.NewConstants;
import javax.swing.*;
import javax.swing.border.Border;
import javax.swing.border.TitledBorder;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.util.ArrayList;
import java.util.Collections;
import javax.swing.BorderFactory;
import javax.swing.ButtonGroup;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JRadioButton;
import javax.swing.SwingConstants;
import javax.swing.border.Border;
import javax.swing.border.TitledBorder;
import forge.error.ErrorViewer;
import forge.properties.NewConstants;
import java.util.List;
import java.util.Set;
//presumes AllZone.QuestData is not null
@@ -30,7 +22,7 @@ import forge.properties.NewConstants;
public class Gui_Quest extends JFrame implements NewConstants{
private static final long serialVersionUID = -6432089669283627896L;
private QuestData questData;
private forge.quest.data.QuestData questData;
private JLabel jLabel1 = new JLabel();
private JLabel difficultyLabel = new JLabel();
@@ -100,7 +92,7 @@ public class Gui_Quest extends JFrame implements NewConstants{
rankLabel.setText(questData.getRank());
creditsLabel.setText("Credits: " + questData.getCredits());
if (questData.getMode().equals(QuestData.FANTASY))
if (questData.getMode().equals(forge.quest.data.QuestData.FANTASY))
{
int life = questData.getLife();
if (life<15)
@@ -121,14 +113,16 @@ public class Gui_Quest extends JFrame implements NewConstants{
//get deck names as Strings
ArrayList<String> list = questData.getDeckNames();
List<String> list = questData.getDeckNames();
Collections.sort(list);
for(int i = 0; i < list.size(); i++)
deckComboBox.addItem(list.get(i));
for (String aList : list) {
deckComboBox.addItem(aList);
}
if(Constant.Runtime.HumanDeck[0] != null) deckComboBox.setSelectedItem(Constant.Runtime.HumanDeck[0].getName());
if (QuestData.FANTASY.equals(questData.getMode()))
if (forge.quest.data.QuestData.FANTASY.equals(questData.getMode()))
{
}
@@ -178,7 +172,7 @@ public class Gui_Quest extends JFrame implements NewConstants{
});
//if (questData.getMode().equals("Fantasy"))
if (QuestData.FANTASY.equals(questData.getMode()))
if (forge.quest.data.QuestData.FANTASY.equals(questData.getMode()))
{
refreshPets();
@@ -272,7 +266,7 @@ public class Gui_Quest extends JFrame implements NewConstants{
jPanel2.add(oppOneRadio, null);
jPanel2.add(oppTwoRadio, null);
jPanel2.add(oppThreeRadio, null);
if (QuestData.FANTASY.equals(questData.getMode())) {
if (forge.quest.data.QuestData.FANTASY.equals(questData.getMode())) {
this.getContentPane().add(otherShopsButton, null);
this.getContentPane().add(lifeLabel,null);
this.getContentPane().add(questsButton, null);
@@ -316,9 +310,11 @@ public class Gui_Quest extends JFrame implements NewConstants{
void refreshPets(){
petComboBox.removeAllItems();
ArrayList<String> petList = QuestUtil.getPetNames(questData);
for (int i=0;i<petList.size();i++)
petComboBox.addItem(petList.get(i));
Set<String> petList = questData.getPetManager().getAvailablePetNames();
for (String s : petList) {
petComboBox.addItem(s);
}
petComboBox.addItem("None");
petComboBox.addItem("No Plant/Pet");
@@ -344,7 +340,7 @@ public class Gui_Quest extends JFrame implements NewConstants{
public void execute() {
//saves all deck data
QuestData.saveData(AllZone.QuestData);
AllZone.QuestData.saveData();
new Gui_Quest();
}
@@ -372,7 +368,7 @@ public class Gui_Quest extends JFrame implements NewConstants{
public void execute() {
//saves all deck data
QuestData.saveData(AllZone.QuestData);
AllZone.QuestData.saveData();
new Gui_Quest();
}
@@ -413,16 +409,16 @@ public class Gui_Quest extends JFrame implements NewConstants{
Constant.Runtime.Smooth[0] = smoothLandCheckBox.isSelected();
if (questData.getMode().equals(QuestData.REALISTIC))
if (questData.getMode().equals(forge.quest.data.QuestData.REALISTIC))
AllZone.GameAction.newGame(human, computer);
else
{
Object pet = petComboBox.getSelectedItem();
if (pet != null)
questData.setSelectedPet(pet.toString());
Object petName = petComboBox.getSelectedItem();
if (petName != null)
questData.getPetManager().setSelectedPet((String) petName);
CardList hCl = QuestUtil.getHumanPlantAndPet(questData);
int hLife = QuestUtil.getLife(questData);
CardList hCl = forge.quest.data.QuestUtil.getHumanPlantAndPet(questData);
int hLife = questData.getLife();
AllZone.GameAction.newGame(human, computer, hCl, new CardList(), hLife, 20, null);
}
@@ -448,7 +444,7 @@ public class Gui_Quest extends JFrame implements NewConstants{
Object pet = petComboBox.getSelectedItem();
if (pet != null)
questData.setSelectedPet(pet.toString());
questData.getPetManager().setSelectedPet((String) pet);
Gui_Quest_Assignments g = new Gui_Quest_Assignments(this, human);
g.setVisible(true);

View File

@@ -13,12 +13,11 @@ import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.util.ArrayList;
public class Gui_QuestOptions extends JFrame {
private static final long serialVersionUID = 2018518804206822235L;
private QuestData questData = new QuestData();
private forge.quest.data.QuestData questData = new forge.quest.data.QuestData();
private JLabel jLabel1 = new JLabel();
private JButton continueQuestButton = new JButton();
@@ -79,7 +78,7 @@ public class Gui_QuestOptions extends JFrame {
//show total number of games for each difficulty
private void setupRadioButtonText() {
String[] diff = questData.getDifficutlyChoices();
String[] diff = questData.getDifficultyChoices();
JRadioButton[] b = {easyRadio, mediumRadio, hardRadio, veryHardRadio};
for(int i = 0; i < diff.length; i++) {
@@ -188,7 +187,7 @@ public class Gui_QuestOptions extends JFrame {
void continueQuestButton_actionPerformed(ActionEvent e) {
//set global variable
AllZone.QuestData = QuestData.loadData();
AllZone.QuestData = forge.quest.data.QuestData.loadData();
AllZone.QuestData.setDifficultyIndex();
dispose();
@@ -207,7 +206,7 @@ public class Gui_QuestOptions extends JFrame {
void newQuestButton_actionPerformed(ActionEvent e) {
int difficulty = 0;
String mode = fantasyRadio.isSelected() ? QuestData.FANTASY : QuestData.REALISTIC;
String mode = fantasyRadio.isSelected() ? forge.quest.data.QuestData.FANTASY : forge.quest.data.QuestData.REALISTIC;
if(easyRadio.isSelected()) difficulty = 0;
@@ -234,10 +233,8 @@ public class Gui_QuestOptions extends JFrame {
//give the user a few cards to build a deck
questData.newGame(difficulty, mode);
copyAIDecks(questData, QuestData.loadData());
QuestData.saveData(questData);
questData.saveData();
questData.readAIQuestDeckFiles();
//set global variable
AllZone.QuestData = questData;
@@ -254,9 +251,10 @@ public class Gui_QuestOptions extends JFrame {
}
//copy AI decks from old to newData
void copyAIDecks(QuestData newData, QuestData old) {
ArrayList<String> a = old.ai_getDeckNames();
for(int i = 0; i < a.size(); i++)
newData.ai_addDeck(old.ai_getDeck(a.get(i).toString()));
void copyAIDecks(forge.quest.data.QuestData newData, forge.quest.data.QuestData old) {
java.util.List<String> oldDeckNames = old.ai_getDeckNames();
for (String oldDeckName : oldDeckNames) {
newData.ai_addDeck(old.ai_getDeck(oldDeckName));
}
}
}

View File

@@ -13,6 +13,7 @@ import java.io.File;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Enumeration;
import java.util.List;
public class Gui_Quest_Assignments extends JFrame implements NewConstants{
@@ -26,7 +27,7 @@ public class Gui_Quest_Assignments extends JFrame implements NewConstants{
private ButtonGroup buttonGroup = new ButtonGroup();
private QuestData questData;
private forge.quest.data.QuestData questData;
private Deck hDeck;
@@ -79,11 +80,11 @@ public class Gui_Quest_Assignments extends JFrame implements NewConstants{
read = new ReadQuest_Assignment(ForgeProps.getFile(QUEST.QUESTS), questData);
read.run();
ArrayList<Quest_Assignment> questsToDisplay = new ArrayList<Quest_Assignment>();
List<Quest_Assignment> questsToDisplay = new ArrayList<Quest_Assignment>();
if (questData.getAvailableQuests()!= null && questData.getAvailableQuests().size() > 0)
{
ArrayList<Quest_Assignment> availableQuests = read.getQuestsByIds(questData.getAvailableQuests());
List<Quest_Assignment> availableQuests = read.getQuestsByIds(questData.getAvailableQuests());
questsToDisplay = availableQuests;
/*
@@ -97,7 +98,7 @@ public class Gui_Quest_Assignments extends JFrame implements NewConstants{
else //generate some random quests
{
//System.out.println("null");
ArrayList<Quest_Assignment> allAvailableQuests = read.getQuests();
List<Quest_Assignment> allAvailableQuests = read.getQuests();
ArrayList<Integer> availableInts = new ArrayList<Integer>();
@@ -116,7 +117,7 @@ public class Gui_Quest_Assignments extends JFrame implements NewConstants{
questsToDisplay.add(qa);
}
questData.setAvailableQuests(availableInts);
QuestData.saveData(questData);
questData.saveData();
}//else
JRadioButton radio;
@@ -262,7 +263,7 @@ public class Gui_Quest_Assignments extends JFrame implements NewConstants{
if(Gui_Quest.newGUICheckbox.isSelected()) AllZone.Display = new GuiDisplay4();
else AllZone.Display = new GuiDisplay3();
AllZone.GameAction.newGame(hDeck, computerDeck, QuestUtil.getHumanPlantAndPet(questData, selectedQuest), new CardList(), questData.getLife()+extraLife,
AllZone.GameAction.newGame(hDeck, computerDeck, forge.quest.data.QuestUtil.getHumanPlantAndPet(questData, selectedQuest), new CardList(), questData.getLife()+extraLife,
selectedQuest.getComputerLife(), selectedQuest);
AllZone.Display.setVisible(true);
@@ -278,7 +279,7 @@ public class Gui_Quest_Assignments extends JFrame implements NewConstants{
}
void quitButton_actionPerformed(ActionEvent e) {
//QuestData.saveData(questData);
//questData.saveData();
//new Gui_Shops();
questGui.setVisible(true);

View File

@@ -2,40 +2,14 @@
package forge;
import java.awt.Color;
import java.awt.Component;
import java.awt.Container;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.GridLayout;
import java.awt.Image;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.ItemEvent;
import java.awt.event.ItemListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Random;
import forge.error.ErrorViewer;
import forge.gui.game.CardDetailPanel;
import forge.gui.game.CardPicturePanel;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import forge.quest.data.QuestBoosterPack;
import javax.swing.BorderFactory;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JFileChooser;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.SwingUtilities;
import javax.swing.*;
import javax.swing.border.Border;
import javax.swing.border.EtchedBorder;
import javax.swing.border.TitledBorder;
@@ -43,12 +17,14 @@ import javax.swing.event.MouseInputListener;
import javax.swing.event.TableModelEvent;
import javax.swing.event.TableModelListener;
import javax.swing.filechooser.FileFilter;
import forge.error.ErrorViewer;
import forge.gui.game.CardDetailPanel;
import forge.gui.game.CardPicturePanel;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import java.awt.Color;
import java.awt.*;
import java.awt.event.*;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Random;
public class Gui_Quest_DeckEditor extends JFrame implements CardContainer, DeckDisplay, NewConstants {
@@ -127,9 +103,9 @@ public class Gui_Quest_DeckEditor extends JFrame implements CardContainer, DeckD
Card c;
String cardName;
QuestData_BoosterPack pack = new QuestData_BoosterPack();
QuestBoosterPack pack = new QuestBoosterPack();
ArrayList<String> addedList = AllZone.QuestData.getAddedCards();
java.util.List<String> addedList = AllZone.QuestData.getAddedCards();
//update top
@@ -356,7 +332,7 @@ public class Gui_Quest_DeckEditor extends JFrame implements CardContainer, DeckD
this.setJMenuBar(customMenu);
QuestData questData = AllZone.QuestData;
forge.quest.data.QuestData questData = AllZone.QuestData;
Deck deck = null;
//open deck that the player used if QuestData has it
@@ -380,7 +356,7 @@ public class Gui_Quest_DeckEditor extends JFrame implements CardContainer, DeckD
}
ArrayList<String> list = AllZone.QuestData.getCardpool();
java.util.List<String> list = AllZone.QuestData.getCardpool();
CardList cardpool = Gui_Quest_DeckEditor_Menu.covertToCardList(list);
//remove bottom cards that are in the deck from the card pool

View File

@@ -2,34 +2,19 @@
package forge;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import forge.error.ErrorViewer;
import forge.gui.GuiUtils;
import javax.swing.JDialog;
import javax.swing.JFileChooser;
import javax.swing.JList;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JOptionPane;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.ListSelectionModel;
import javax.swing.*;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import javax.swing.filechooser.FileFilter;
import forge.error.ErrorViewer;
import forge.gui.GuiUtils;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.*;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
//presumes AllZone.QuestData is not null
@@ -46,7 +31,7 @@ public class Gui_Quest_DeckEditor_Menu extends JMenuBar {
private static File previousDirectory = null;
private Command exitCommand;
private QuestData questData;
private forge.quest.data.QuestData questData;
private Deck currentDeck;
//the class DeckDisplay is in the file "Gui_DeckEditor_Menu.java"
@@ -443,7 +428,7 @@ public class Gui_Quest_DeckEditor_Menu extends JMenuBar {
//convert ArrayList of card names (Strings), into Card objects
cardpool = new CardList();
ArrayList<String> list = questData.getCardpool();
List<String> list = questData.getCardpool();
for(int i = 0; i < list.size(); i++)
cardpool.add(AllZone.CardFactory.getCard(list.get(i).toString(), null));
@@ -495,7 +480,7 @@ public class Gui_Quest_DeckEditor_Menu extends JMenuBar {
//AI
viewAllDecks.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent a) {
ArrayList<String> nameList = questData.ai_getDeckNames();
List<String> nameList = questData.ai_getDeckNames();
Collections.sort(nameList);
Deck deck;
@@ -980,7 +965,7 @@ public class Gui_Quest_DeckEditor_Menu extends JMenuBar {
}
//if user cancels, returns ""
private String getUserInput_GetDeckName(ArrayList<String> nameList) {
private String getUserInput_GetDeckName(List<String> nameList) {
Object o = JOptionPane.showInputDialog(null, "", "Deck Name", JOptionPane.OK_CANCEL_OPTION);
if(o == null) return "";
@@ -997,8 +982,8 @@ public class Gui_Quest_DeckEditor_Menu extends JMenuBar {
//if user cancels, it will return ""
private String getUserInput_OpenDeck(ArrayList<String> deckNameList) {
ArrayList<String> choices = deckNameList;
private String getUserInput_OpenDeck(List<String> deckNameList) {
List<String> choices = deckNameList;
if(choices.size() == 0) {
JOptionPane.showMessageDialog(null, "No decks found", "Open Deck", JOptionPane.PLAIN_MESSAGE);
return "";
@@ -1031,11 +1016,11 @@ public class Gui_Quest_DeckEditor_Menu extends JMenuBar {
//returns CardList of Card objects,
//argument ArrayList holds String card names
public static CardList covertToCardList(ArrayList<String> list) {
public static CardList covertToCardList(List<String> list) {
CardList c = new CardList();
Card card;
for(int i = 0; i < list.size(); i++) {
card = AllZone.CardFactory.getCard(list.get(i).toString(), null);
for (String aList : list) {
card = AllZone.CardFactory.getCard(aList, null);
c.add(card);
}

View File

@@ -1,5 +1,10 @@
package forge;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Rectangle;
@@ -7,16 +12,6 @@ import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;
import java.io.File;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
public class Gui_Treasury extends JFrame implements NewConstants{
private static final long serialVersionUID = 2409591658245091210L;
@@ -36,7 +31,7 @@ public class Gui_Treasury extends JFrame implements NewConstants{
private JButton learnEstatesButton= new JButton();
private JButton quitButton = new JButton();
private QuestData questData = AllZone.QuestData;
private forge.quest.data.QuestData questData = AllZone.QuestData;
public Gui_Treasury(JFrame parent) {
try {
@@ -221,7 +216,7 @@ public class Gui_Treasury extends JFrame implements NewConstants{
{
questData.addLuckyCoinLevel(1);
}
QuestData.saveData(questData);
questData.saveData();
jbInit();
}
@@ -234,7 +229,7 @@ public class Gui_Treasury extends JFrame implements NewConstants{
}
void quitButton_actionPerformed(ActionEvent e) {
QuestData.saveData(questData);
questData.saveData();
//new Gui_Shops();
shopsGUI.setVisible(true);

View File

@@ -6,6 +6,8 @@ import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import forge.properties.NewConstants.LANG.Gui_WinLose.WINLOSE_TEXT;
import forge.quest.data.QuestMatchState;
import forge.quest.data.QuestPreferences;
import forge.quest.gui.QuestFrame;
import net.miginfocom.swing.MigLayout;
@@ -46,8 +48,8 @@ public class Gui_WinLose extends JFrame implements NewConstants {
public static void main(String[] args) {
Constant.Runtime.GameType[0] = Constant.GameType.Sealed;
Constant.Runtime.WinLose.addWin();
Constant.Runtime.WinLose.addLose();
Constant.Runtime.matchState.addWin();
Constant.Runtime.matchState.addLose();
//setup limited deck
Deck deck = new Deck(Constant.GameType.Sealed);
@@ -114,7 +116,7 @@ public class Gui_WinLose extends JFrame implements NewConstants {
private void setup() {
AllZone.GameInfo.clearColorChanges();
WinLose winLose = Constant.Runtime.WinLose;
QuestMatchState winLose = Constant.Runtime.matchState;
Phase.GameBegins = 0;
//3 is the match length, 3 is the number of games
//disable buttons if match is up, or human player won 2 or lost 2 games already
@@ -228,16 +230,16 @@ public class Gui_WinLose extends JFrame implements NewConstants {
else{
int extraLife = 0;
if (AllZone.QuestAssignment != null) {
QuestUtil.setupQuest(AllZone.QuestAssignment);
forge.quest.data.QuestUtil.setupQuest(AllZone.QuestAssignment);
if (AllZone.QuestData.getGearLevel() == 2)
extraLife = 3;
}
//AllZone.GameAction.newGame(Constant.Runtime.HumanDeck[0], Constant.Runtime.ComputerDeck[0], humanList, computerList, humanLife, computerLife);
CardList humanList = QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
CardList humanList = forge.quest.data.QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
CardList computerList = new CardList();
int humanLife = QuestUtil.getLife(AllZone.QuestData) + extraLife;
int humanLife = AllZone.QuestData.getLife() + extraLife;
int computerLife = 20;
if (AllZone.QuestAssignment!=null)
computerLife = AllZone.QuestAssignment.getComputerLife();
@@ -250,7 +252,7 @@ public class Gui_WinLose extends JFrame implements NewConstants {
}
void restartButton_actionPerformed(ActionEvent e) {
Constant.Runtime.WinLose.reset();
Constant.Runtime.matchState.reset();
if (!Constant.Quest.fantasyQuest[0])
AllZone.GameAction.newGame(Constant.Runtime.HumanDeck[0], Constant.Runtime.ComputerDeck[0]);
@@ -258,16 +260,16 @@ public class Gui_WinLose extends JFrame implements NewConstants {
int extraLife = 0;
//AllZone.GameAction.newGame(Constant.Runtime.HumanDeck[0], Constant.Runtime.ComputerDeck[0], humanList, computerList, humanLife, computerLife);
if (AllZone.QuestAssignment != null) {
QuestUtil.setupQuest(AllZone.QuestAssignment);
forge.quest.data.QuestUtil.setupQuest(AllZone.QuestAssignment);
if (AllZone.QuestData.getGearLevel() == 2)
extraLife = 3;
}
CardList humanList = QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
CardList humanList = forge.quest.data.QuestUtil.getHumanPlantAndPet(AllZone.QuestData, AllZone.QuestAssignment);
//CardList computerList = QuestUtil.getComputerCreatures(AllZone.QuestData, AllZone.QuestAssignment);
CardList computerList = new CardList();
int humanLife = QuestUtil.getLife(AllZone.QuestData) +extraLife;
int humanLife = AllZone.QuestData.getLife() +extraLife;
int computerLife = 20;
if (AllZone.QuestAssignment!=null)
@@ -280,7 +282,7 @@ public class Gui_WinLose extends JFrame implements NewConstants {
dispose();
}
private String getWinText(long creds, WinLose winLose, QuestData q)
private String getWinText(long creds, QuestMatchState winLose, forge.quest.data.QuestData q)
{
// todo use q.qdPrefs to write bonus credits in prefs file
StringBuilder sb = new StringBuilder();
@@ -288,7 +290,7 @@ public class Gui_WinLose extends JFrame implements NewConstants {
sb.append("<html>");
QuestData_Prefs qdPrefs = q.qdPrefs;
QuestPreferences qdPrefs = q.getQuestPreferences();
for (String s : wins)
{
@@ -394,11 +396,11 @@ public class Gui_WinLose extends JFrame implements NewConstants {
new Gui_NewGame();
}
else { //Quest
WinLose winLose = Constant.Runtime.WinLose;
QuestData quest = AllZone.QuestData;
QuestMatchState matchState = Constant.Runtime.matchState;
forge.quest.data.QuestData quest = AllZone.QuestData;
boolean wonMatch = false;
if(winLose.getWin() == 2){
if(matchState.getWin() == 2){
quest.addWin();
wonMatch = true;
}
@@ -425,8 +427,8 @@ public class Gui_WinLose extends JFrame implements NewConstants {
}
if (wonMatch){
long creds = quest.getCreditsToAdd(winLose);
String s = getWinText(creds, winLose, quest);
long creds = quest.getCreditsToAdd(matchState);
String s = getWinText(creds, matchState, quest);
String fileName = "GoldIcon.png";
ImageIcon icon = getIcon(fileName);
@@ -489,11 +491,11 @@ public class Gui_WinLose extends JFrame implements NewConstants {
JOptionPane.showMessageDialog(null, "", "You have won a random rare.", JOptionPane.INFORMATION_MESSAGE, icon);
}
winLose.reset();
matchState.reset();
AllZone.QuestAssignment = null;
QuestData.saveData(quest);
quest.saveData();
if (AllZone.QuestData.useNewQuestUI){
new QuestFrame();
}

View File

@@ -1,24 +1,14 @@
package forge;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Random;
import com.esotericsoftware.minlog.Log;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import java.io.*;
import java.util.*;
//when you create QuestData and AFTER you copy the AI decks over
//you have to call one of these two methods below
@@ -27,6 +17,8 @@ import forge.properties.NewConstants;
//static readAIQuestDeckFiles(QuestData data, ArrayList aiDeckNames)
//OR non-static readAIQuestDeckFiles()
//which reads the files "questDecks-easy", "questDecks-medium","questDecks-hard",
@SuppressWarnings({"deprecation"})
@Deprecated
public class QuestData implements NewConstants {
QuestData_Prefs qdPrefs = null;

View File

@@ -9,6 +9,7 @@ import java.util.*;
//balance the number of colors and creature/spells for
//new cards that are won in quest mode
@Deprecated
public class QuestData_BoosterPack implements NewConstants {
// final private static String comment = "//";

View File

@@ -1,12 +1,13 @@
package forge;
import forge.properties.ForgeProps;
import forge.properties.NewConstants.QUEST;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.Serializable;
import forge.properties.ForgeProps;
import forge.properties.NewConstants.QUEST;
@Deprecated
public class QuestData_Prefs implements Serializable {
private static final long serialVersionUID = 3266336025656577905L;

View File

@@ -20,6 +20,9 @@ import java.util.Map;
* @version V0.0 26.10.2009
* @author Clemens Koza
*/
@Deprecated
public class QuestData_State implements Serializable {
private static final long serialVersionUID = 7007940230351051937L;

View File

@@ -2,6 +2,8 @@ package forge;
import java.util.ArrayList;
@Deprecated
@SuppressWarnings("deprecation")
public class QuestUtil {
public static int getLife(QuestData qd)

View File

@@ -1,13 +1,14 @@
package forge;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.ArrayList;
import forge.error.ErrorViewer;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.ArrayList;
import java.util.List;
public class ReadQuest_Assignment implements Runnable, NewConstants {
@@ -15,7 +16,7 @@ public class ReadQuest_Assignment implements Runnable, NewConstants {
private ArrayList<Quest_Assignment> allQuests = new ArrayList<Quest_Assignment>();
private int totalWins;
private ArrayList<Integer> completedQuests = new ArrayList<Integer>();
private List<Integer> completedQuests = new ArrayList<Integer>();
public static void main(String args[]) throws Exception {
try {
@@ -40,12 +41,12 @@ public class ReadQuest_Assignment implements Runnable, NewConstants {
}
}
public ArrayList<Quest_Assignment> getQuests() {
public List<Quest_Assignment> getQuests() {
return new ArrayList<Quest_Assignment>(allQuests);
}
public ArrayList<Quest_Assignment> getQuestsByIds(ArrayList<Integer> availableQuestIds) {
ArrayList<Quest_Assignment> quests = new ArrayList<Quest_Assignment>();
public List<Quest_Assignment> getQuestsByIds(List<Integer> availableQuestIds) {
List<Quest_Assignment> quests = new ArrayList<Quest_Assignment>();
for(Quest_Assignment qa:allQuests)
{
@@ -72,11 +73,11 @@ public class ReadQuest_Assignment implements Runnable, NewConstants {
}
*/
public ReadQuest_Assignment(String filename, QuestData questData) {
public ReadQuest_Assignment(String filename, forge.quest.data.QuestData questData) {
this(new File(filename), questData);
}
public ReadQuest_Assignment(File file, QuestData questData) {
public ReadQuest_Assignment(File file, forge.quest.data.QuestData questData) {
if (questData != null) {
totalWins = questData.getWin();
@@ -171,7 +172,7 @@ public class ReadQuest_Assignment implements Runnable, NewConstants {
ids.add(qa.getId());
if (qa.getRequiredNumberWins() <= totalWins && !completedQuests.contains(qa.getId()) ) {
QuestUtil.setupQuest(qa);
forge.quest.data.QuestUtil.setupQuest(qa);
allQuests.add(qa);
}

View File

@@ -1,4 +1,5 @@
package forge;
@Deprecated
public class WinLose
{
//the way wins were achieved:

View File

@@ -1,28 +1,19 @@
package forge.gui;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Frame;
import java.awt.Image;
import java.awt.Rectangle;
import java.awt.image.BufferedImage;
import java.io.File;
import java.util.Collection;
import java.util.List;
import javax.swing.Box;
import javax.swing.ImageIcon;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import forge.AllZone;
import forge.Card;
import forge.properties.ForgeProps;
import forge.properties.NewConstants;
import javax.swing.*;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.File;
import java.util.Collection;
import java.util.List;
public class GuiUtils {
@@ -87,11 +78,11 @@ public class GuiUtils {
public static ImageIcon getIconFromFile(String iconName) {
File base = ForgeProps.getFile(NewConstants.IMAGE_ICON);
File file = new File(base, iconName);
if (file.exists()) {
return new ImageIcon(file.toString());
if (iconName.equals("") || !file.exists()) {
return null;
}
else {
return null;
return new ImageIcon(file.toString());
}
}

View File

@@ -14,66 +14,60 @@ import java.util.zip.GZIPInputStream;
import java.util.zip.GZIPOutputStream;
//when you create QuestData and AFTER you copy the AI decks over
//when you create QuestDataOld and AFTER you copy the AI decks over
//you have to call one of these two methods below
//see Gui_QuestOptions for more details
//
//static readAIQuestDeckFiles(QuestData data, ArrayList aiDeckNames)
//static readAIQuestDeckFiles(QuestDataOld data, ArrayList aiDeckNames)
//OR non-static readAIQuestDeckFiles()
//which reads the files "questDecks-easy", "questDecks-medium","questDecks-hard",
public class QuestData {
QuestPreferences qdPrefs = null;
QuestPreferences preferences = null;
private int rankIndex;
private int win;
private int lost;
private List<QuestPetAbstract> pets;
private QuestPetAbstract selectedPet;
private int life;
private int estatesLevel;
private int luckyCoinLevel;
private int sleightOfHandLevel;
private int gearLevel;
private int questsPlayed;
private long credits;
private int diffIndex;
private String difficulty;
private String mode = "";
private transient ArrayList<String> easyAIDecks;
private transient ArrayList<String> mediumAIDecks;
private transient ArrayList<String> hardAIDecks;
private transient Map<String, Deck> aiDecks;
private transient List<String> easyAIDecks;
private transient List<String> mediumAIDecks;
private transient List<String> hardAIDecks;
private Map<String, Deck> myDecks = new HashMap<String, Deck>();
private transient Map<String, Deck> aiDecks = new HashMap<String, Deck>();
//holds String card names
private ArrayList<String> cardPool = new ArrayList<String>();
private ArrayList<String> newCardList = new ArrayList<String>();
private ArrayList<String> shopList = new ArrayList<String>();
private List<String> cardPool = new ArrayList<String>();
private List<String> newCardList = new ArrayList<String>();
private ArrayList<Integer> availableQuests = new ArrayList<Integer>();
private ArrayList<Integer> completedQuests = new ArrayList<Integer>();
private List<String> shopList = new ArrayList<String>();
private List<Integer> availableQuests = new ArrayList<Integer>();
private transient QuestBoosterPack boosterPack = new QuestBoosterPack();
private List<Integer> completedQuests = new ArrayList<Integer>();
private transient QuestBoosterPack boosterPack;
//used by shouldAddAdditionalCards()
private Random random = new Random();
//feel free to change this to something funnier
private transient String[] rankArray = {
"Level 0 - Confused Wizard", "Level 1 - Mana Mage", "Level 2 - Death by Megrim",
"Level 3 - Shattered the Competition", "Level 4 - Black Knighted", "Level 5 - Shockingly Good",
"Level 6 - Regressed into Timmy", "Level 7 - Loves Blue Control", "Level 8 - Immobilized by Fear",
"Level 9 - Lands = Friends", "Saltblasted for your talent", "Serra Angel is your girlfriend",};
//feel free to change this to something funnier
private transient String[] rankArray;
public static final String FANTASY = "Fantasy";
public static final String REALISTIC = "Realistic";
@@ -81,10 +75,12 @@ public class QuestData {
//TODO: Temporary.
public boolean useNewQuestUI = false;
public QuestData() {
qdPrefs = new QuestPreferences();
public final QuestPetManager petManager = new QuestPetManager();
for (int i = 0; i < qdPrefs.getStartingBasic(); i++) {
public QuestData() {
preferences = new QuestPreferences();
for (int i = 0; i < preferences.getStartingBasic(); i++) {
cardPool.add("Forest");
cardPool.add("Mountain");
cardPool.add("Swamp");
@@ -92,7 +88,7 @@ public class QuestData {
cardPool.add("Plains");
}
for (int i = 0; i < qdPrefs.getStartingSnowBasic(); i++) {
for (int i = 0; i < preferences.getStartingSnowBasic(); i++) {
cardPool.add("Snow-Covered Forest");
cardPool.add("Snow-Covered Mountain");
cardPool.add("Snow-Covered Swamp");
@@ -100,21 +96,46 @@ public class QuestData {
cardPool.add("Snow-Covered Plains");
}
readAIQuestDeckFiles();
}//QuestData
initTransients();
}
private void initTransients() {
aiDecks = new HashMap<String, Deck>();
List<String> aiDeckNames = ai_getDeckNames();
easyAIDecks = readFile(ForgeProps.getFile(NewConstants.QUEST.EASY), aiDeckNames);
mediumAIDecks = readFile(ForgeProps.getFile(NewConstants.QUEST.MEDIUM), aiDeckNames);
hardAIDecks = readFile(ForgeProps.getFile(NewConstants.QUEST.HARD), aiDeckNames);
rankArray = new String[]{
"Level 0 - Confused Wizard",
"Level 1 - Mana Mage",
"Level 2 - Death by Megrim",
"Level 3 - Shattered the Competition",
"Level 4 - Black Knighted",
"Level 5 - Shockingly Good",
"Level 6 - Regressed into Timmy",
"Level 7 - Loves Blue Control",
"Level 8 - Immobilized by Fear",
"Level 9 - Lands = Friends",
"Saltblasted for your talent",
"Serra Angel is your girlfriend",};
boosterPack = new QuestBoosterPack();
}
//adds cards to card pool and sets difficulty
public void newGame(int difficulty, String m) {
setDifficulty(difficulty);
ArrayList<String> list = new ArrayList<String>();
list.addAll(boosterPack.getCommon(qdPrefs.getStartingCommons(difficulty)));
list.addAll(boosterPack.getUncommon(qdPrefs.getStartingUncommons(difficulty)));
list.addAll(boosterPack.getRare(qdPrefs.getStartingRares(difficulty)));
list.addAll(boosterPack.getCommon(preferences.getStartingCommons(difficulty)));
list.addAll(boosterPack.getUncommon(preferences.getStartingUncommons(difficulty)));
list.addAll(boosterPack.getRare(preferences.getStartingRares(difficulty)));
//because cardPool already has basic land added to it
cardPool.addAll(list);
credits = qdPrefs.getStartingCredits();
credits = preferences.getStartingCredits();
mode = m;
if (mode.equals(FANTASY)) {
@@ -125,36 +146,28 @@ public class QuestData {
}
}
public String[] getOpponents() {
int index = getDifficultyIndex();
if (getWin() < qdPrefs.getWinsForMediumAI(index)) {
if (getWin() < preferences.getWinsForMediumAI(index)) {
return getOpponents(easyAIDecks);
}
if (getWin() < qdPrefs.getWinsForHardAI(index)) {
if (getWin() < preferences.getWinsForHardAI(index)) {
return getOpponents(mediumAIDecks);
}
return getOpponents(hardAIDecks);
}//getOpponents()
private void readAIQuestDeckFiles(QuestData data, ArrayList<String> aiDeckNames) {
data.easyAIDecks = readFile(ForgeProps.getFile(NewConstants.QUEST.EASY), aiDeckNames);
data.mediumAIDecks = readFile(ForgeProps.getFile(NewConstants.QUEST.MEDIUM), aiDeckNames);
data.hardAIDecks = readFile(ForgeProps.getFile(NewConstants.QUEST.HARD), aiDeckNames);
}
public String[] getOpponents(ArrayList<String> aiDeck) {
public String[] getOpponents(List<String> aiDeck) {
Collections.shuffle(aiDeck);
return new String[]{aiDeck.get(0).toString(), aiDeck.get(1).toString(), aiDeck.get(2).toString()};
}//getOpponents()
}
private static ArrayList<String> readFile(File file, ArrayList<String> aiDecks) {
private static List<String> readFile(File file, List<String> aiDecks) {
ArrayList<String> list = FileUtil.readFile(file);
//remove any blank lines
@@ -177,7 +190,7 @@ public class QuestData {
for (int i = 0; i < list.size(); i++)
/*if(!aiDecks.contains(list.get(i).toString())) ErrorViewer.showError(new Exception(),
"QuestData : readFile() error, file %s contains the invalid ai deck name: %s", file,
"QuestDataOld : readFile() error, file %s contains the invalid ai deck name: %s", file,
list.get(i));*/ {
if (!aiDecks.contains(list.get(i).toString())) {
aiDecks.add(list.get(i).toString());
@@ -186,12 +199,9 @@ public class QuestData {
return list;
}//readFile()
public void readAIQuestDeckFiles() {
readAIQuestDeckFiles(this, ai_getDeckNames());
}
static public QuestData loadData() {
try {
//read file "questData"
@@ -213,7 +223,6 @@ public class QuestData {
XStream xStream = new XStream();
data = (QuestData) xStream.fromXML(zin);
data.readAIQuestDeckFiles(data, new ArrayList<String>());
zin.close();
}
@@ -226,6 +235,24 @@ public class QuestData {
}
}
public void saveData() {
try {
File f = ForgeProps.getFile(NewConstants.QUEST.XMLDATA);
BufferedOutputStream bout = new BufferedOutputStream(new FileOutputStream(f));
GZIPOutputStream zout = new GZIPOutputStream(bout);
XStream xStream = new XStream();
xStream.toXML(this, zout);
zout.flush();
zout.close();
} catch (Exception ex) {
ErrorViewer.showError(ex, "Error saving Quest Data");
throw new RuntimeException(ex);
}
}
@SuppressWarnings({"deprecation"})
private static QuestData convertSaveFormat() {
forge.QuestData oldData = forge.QuestData.loadData();
QuestData newData = new QuestData();
@@ -233,7 +260,7 @@ public class QuestData {
newData.difficulty = oldData.getDifficulty();
newData.diffIndex = oldData.getDiffIndex();
newData.rankIndex = oldData.getWin()/newData.qdPrefs.getWinsForRankIncrease(newData.diffIndex);
newData.rankIndex = oldData.getWin() / newData.preferences.getWinsForRankIncrease(newData.diffIndex);
newData.win = oldData.getWin();
newData.lost = oldData.getLost();
@@ -259,46 +286,47 @@ public class QuestData {
newData.availableQuests = oldData.getAvailableQuests();
newData.completedQuests = oldData.getCompletedQuests();
newData.pets = new ArrayList<QuestPetAbstract>();
QuestPetAbstract newPet;
if(oldData.getBirdPetLevel() > 0){
if (oldData.getBirdPetLevel() > 0) {
newPet = new QuestPetBird();
newPet.setLevel(oldData.getBirdPetLevel());
newData.pets.add(newPet);
newData.petManager.addPet(newPet);
}
if(oldData.getHoundPetLevel() > 0){
if (oldData.getHoundPetLevel() > 0) {
newPet = new QuestPetHound();
newPet.setLevel(oldData.getHoundPetLevel());
newData.pets.add(newPet);
newData.petManager.addPet(newPet);
}
if(oldData.getWolfPetLevel() > 0){
if (oldData.getWolfPetLevel() > 0) {
newPet = new QuestPetWolf();
newPet.setLevel(oldData.getWolfPetLevel());
newData.pets.add(newPet);
newData.petManager.addPet(newPet);
}
if(oldData.getCrocPetLevel() > 0){
if (oldData.getCrocPetLevel() > 0) {
newPet = new QuestPetCrocodile();
newPet.setLevel(oldData.getCrocPetLevel());
newData.pets.add(newPet);
newData.petManager.addPet(newPet);
}
if(oldData.getPlantLevel() > 0){
if (oldData.getPlantLevel() > 0) {
newPet = new QuestPetPlant();
newPet.setLevel(oldData.getPlantLevel());
newData.pets.add(newPet);
newData.petManager.getPlant().setLevel(oldData.getPlantLevel());
}
newData.getPetManager().setSelectedPet(null);
return newData;
}
//returns Strings of the card names
public ArrayList<String> getCardpool() {
public List<String> getCardpool() {
//make a copy so the internal ArrrayList cannot be changed externally
return new ArrayList<String>(cardPool);
}
public ArrayList<String> getShopList() {
public List<String> getShopList() {
if (shopList != null) {
return new ArrayList<String>(shopList);
}
@@ -307,12 +335,12 @@ public class QuestData {
}
}
public void setShopList(ArrayList<String> list) {
public void setShopList(List<String> list) {
shopList = list;
}
public ArrayList<Integer> getAvailableQuests() {
public List<Integer> getAvailableQuests() {
if (availableQuests != null) {
return new ArrayList<Integer>(availableQuests);
}
@@ -321,7 +349,7 @@ public class QuestData {
}
}
public void setAvailableQuests(ArrayList<Integer> list) {
public void setAvailableQuests(List<Integer> list) {
availableQuests = list;
}
@@ -329,7 +357,7 @@ public class QuestData {
availableQuests.clear();
}
public ArrayList<Integer> getCompletedQuests() {
public List<Integer> getCompletedQuests() {
if (completedQuests != null) {
return new ArrayList<Integer>(completedQuests);
}
@@ -338,7 +366,7 @@ public class QuestData {
}
}
public void setCompletedQuests(ArrayList<Integer> list) {
public void setCompletedQuests(List<Integer> list) {
completedQuests = list;
}
@@ -347,8 +375,6 @@ public class QuestData {
shopList.clear();
}
//rename - removeDeck, addDeck
//copy - addDeck
public void removeDeck(String deckName) {
myDecks.remove(deckName);
@@ -416,18 +442,18 @@ public class QuestData {
//returns human player decks
//returns ArrayList of String deck names
public ArrayList<String> getDeckNames() {
public List<String> getDeckNames() {
return getDeckNames_String(myDecks);
}//getDecks()
}
//returns AI computer decks
//returns ArrayList of String deck names
public ArrayList<String> ai_getDeckNames() {
public List<String> ai_getDeckNames() {
return getDeckNames_String(aiDecks);
}
//returns ArrayList of Deck String names
private ArrayList<String> getDeckNames_String(Map<String, Deck> map) {
private List<String> getDeckNames_String(Map<String, Deck> map) {
ArrayList<String> out = new ArrayList<String>();
Iterator<String> it = map.keySet().iterator();
@@ -439,16 +465,16 @@ public class QuestData {
}
//get new cards that were added to your card pool by addCards()
public ArrayList<String> getAddedCards() {
public List<String> getAddedCards() {
return new ArrayList<String>(newCardList);
}
//adds 11 cards, to the current card pool
//(I chose 11 cards instead of 15 in order to make things more challenging)
public void addCards() {
int nCommon = qdPrefs.getNumCommon();
int nUncommon = qdPrefs.getNumUncommon();
int nRare = qdPrefs.getNumRare();
int nCommon = preferences.getNumCommon();
int nUncommon = preferences.getNumUncommon();
int nRare = preferences.getNumRare();
ArrayList<String> newCards = new ArrayList<String>();
newCards.addAll(boosterPack.getCommon(nCommon));
@@ -461,18 +487,6 @@ public class QuestData {
//getAddedCards() uses newCardList
newCardList = newCards;
}//addCards()
public ArrayList<String> getRandomRares(int n, int colorIndex) {
ArrayList<String> newCards = new ArrayList<String>();
newCards.addAll(boosterPack.getRare(n, colorIndex));
/*
for(String s : newCards ) {
Card c = AllZone.CardFactory.getCard(s, AllZone.HumanPlayer);
list.add(c);
}*/
return newCards;
}
public void addRandomRare(int n) {
@@ -541,49 +555,49 @@ public class QuestData {
}
public long getCreditsToAdd(QuestMatchState matchState) {
long creds = (long) (qdPrefs.getMatchRewardBase() + (qdPrefs.getMatchRewardTotalWins() * win));
long creds = (long) (preferences.getMatchRewardBase() + (preferences.getMatchRewardTotalWins() * win));
String[] wins = matchState.getWinMethods();
int[] winTurns = matchState.getWinTurns();
boolean[] mulliganedToZero = matchState.getMulliganedToZero();
if (matchState.getLose() == 0) {
creds += qdPrefs.getMatchRewardNoLosses();
creds += preferences.getMatchRewardNoLosses();
}
for (String s : wins) {
if (s != null) {
if (s.equals("Poison Counters")) {
creds += qdPrefs.getMatchRewardPoisonWinBonus();
creds += preferences.getMatchRewardPoisonWinBonus();
}
else if (s.equals("Milled")) {
creds += qdPrefs.getMatchRewardMilledWinBonus();
creds += preferences.getMatchRewardMilledWinBonus();
}
else if (s.equals("Battle of Wits") || s.equals("Felidar Sovereign") || s.equals("Helix Pinnacle") ||
s.equals("Epic Struggle") || s.equals("Door to Nothingness") || s.equals("Barren Glory") ||
s.equals("Near-Death Experience") || s.equals("Mortal Combat") || s.equals("Test of Endurance")) {
creds += qdPrefs.getMatchRewardAltWinBonus();
creds += preferences.getMatchRewardAltWinBonus();
}
}
}
for (int i : winTurns) {
if (i == 1) {
creds += qdPrefs.getMatchRewardWinFirst();
creds += preferences.getMatchRewardWinFirst();
}
else if (i <= 5) {
creds += qdPrefs.getMatchRewardWinByFifth();
creds += preferences.getMatchRewardWinByFifth();
}
else if (i <= 10) {
creds += qdPrefs.getMatchRewardWinByTen();
creds += preferences.getMatchRewardWinByTen();
}
else if (i <= 15) {
creds += qdPrefs.getMatchRewardWinByFifteen();
creds += preferences.getMatchRewardWinByFifteen();
}
}
for (boolean b : mulliganedToZero) {
if (b == true) {
creds += qdPrefs.getMatchMullToZero();
creds += preferences.getMatchMullToZero();
}
}
@@ -603,7 +617,7 @@ public class QuestData {
}
//gets all of the cards that are in the cardpool
public ArrayList<String> getCards() {
public List<String> getCards() {
//copy CardList in order to keep private variables private
//if we just return cardPool, it could be changed externally
return new ArrayList<String>(cardPool);
@@ -613,7 +627,7 @@ public class QuestData {
public int getTotalNumberOfGames(int difficulty) {
//-2 because you start a level 1, and the last level is secret
int numberLevels = rankArray.length - 2;
int nMatches = qdPrefs.getWinsForRankIncrease(difficulty);
int nMatches = preferences.getWinsForRankIncrease(difficulty);
return numberLevels * nMatches;
}
@@ -622,10 +636,10 @@ public class QuestData {
public void addWin() {
win++;
if (win % qdPrefs.getWinsForRankIncrease(diffIndex) == 0) {
if (win % preferences.getWinsForRankIncrease(diffIndex) == 0) {
rankIndex++;
}
}//addWin()
}
public void addLost() {
lost++;
@@ -641,15 +655,6 @@ public class QuestData {
//********************FANTASY STUFF START***********************
public void setSelectedPet(QuestPetAbstract pet) {
selectedPet = pet;
}
public QuestPetAbstract getSelectedPet() {
return selectedPet;
}
public void setLife(int n) {
life = n;
}
@@ -726,6 +731,10 @@ public class QuestData {
return mode;
}
//should be called first, because the difficultly won't change
public String getDifficulty() {
return difficulty;
}
public int getDifficultyIndex() {
return diffIndex;
@@ -733,14 +742,26 @@ public class QuestData {
public void setDifficulty(int i) {
diffIndex = i;
difficulty = qdPrefs.getDifficulty(i);
difficulty = preferences.getDifficulty(i);
}
public void setDifficultyIndex() {
String[] diffStr = preferences.getDifficulty();
for (int i = 0; i < diffStr.length; i++) {
if (difficulty.equals(diffStr[i])) {
diffIndex = i;
}
}
}
public String[] getDifficultyChoices() {
return preferences.getDifficulty();
}
public String getRank() {
//is rankIndex too big?
if (rankIndex == rankArray.length) {
rankIndex--;
if (rankIndex >= rankArray.length) {
rankIndex = rankArray.length - 1;
}
return rankArray[rankIndex];
@@ -748,7 +769,7 @@ public class QuestData {
//add cards after a certain number of wins or losses
public boolean shouldAddCards(boolean didWin) {
int n = qdPrefs.getWinsForBooster(diffIndex);
int n = preferences.getWinsForBooster(diffIndex);
if (didWin) {
return getWin() % n == 0;
@@ -777,26 +798,10 @@ public class QuestData {
}
public boolean hasSaveFile() {
return ForgeProps.getFile(NewConstants.QUEST.DATA).exists();
return ForgeProps.getFile(NewConstants.QUEST.DATA).exists()||
ForgeProps.getFile(NewConstants.QUEST.XMLDATA).exists();
}
public void saveData() {
try {
File f = ForgeProps.getFile(NewConstants.QUEST.XMLDATA);
BufferedOutputStream bout = new BufferedOutputStream(new FileOutputStream(f));
GZIPOutputStream zout = new GZIPOutputStream(bout);
XStream xStream = new XStream();
xStream.toXML(this, zout);
zout.flush();
zout.close();
} catch (Exception ex) {
ErrorViewer.showError(ex, "Error saving Quest Data");
throw new RuntimeException(ex);
}
}//saveData()
public static void main(String[] args) {
QuestData q = new QuestData();
for (int i = 0; i < 20; i++) {
@@ -811,5 +816,21 @@ public class QuestData {
System.exit(1);
}
public QuestPetManager getPetManager() {
return petManager;
}
public QuestPreferences getQuestPreferences() {
return preferences;
}
//get new cards that were added to your card pool by addCards()
public void addToNewList(ArrayList<String> added) {
newCardList.addAll(added);
}
public Object readResolve() {
initTransients();
return this;
}
}

View File

@@ -6,11 +6,6 @@ import java.util.ArrayList;
public class QuestUtil {
public static int getLife(QuestData qd)
{
return qd.getLife();
}
public static CardList getComputerCreatures(QuestData qd)
{
return new CardList();
@@ -40,23 +35,13 @@ public class QuestUtil {
{
CardList list = new CardList();
if (qd.getSelectedPet() != null)
{
if (qd.getSelectedPet().equals("No Plant/Pet"))
return list;
if (qd.getPetManager().shouldPetBeUsed()){
list.add(qd.getPetManager().getSelectedPet().getPetCard());
}
if (qd.getSelectedPet().equals("Wolf") && qd.getWolfPetLevel() > 0)
list.add(getWolfPetToken(qd.getWolfPetLevel()));
else if (qd.getSelectedPet().equals("Croc") && qd.getCrocPetLevel() > 0)
list.add(getCrocPetToken(qd.getCrocPetLevel()));
else if (qd.getSelectedPet().equals("Bird") && qd.getBirdPetLevel() > 0)
list.add(getBirdPetToken(qd.getBirdPetLevel()));
else if (qd.getSelectedPet().equals("Hound") && qd.getHoundPetLevel() > 0)
list.add(getHoundPetToken(qd.getHoundPetLevel()));
}
if (qd.getPlantLevel() > 0)
list.add(getPlantToken(qd.getPlantLevel()));
if (qd.getPetManager().shouldPlantBeUsed()){
list.add(qd.getPetManager().getPlant().getPetCard());
}
return list;
}
@@ -71,356 +56,6 @@ public class QuestUtil {
return list;
}
//makeToken(String name, String imageName, Card source, String manaCost, String[] types, int baseAttack, int baseDefense, String[] intrinsicKeywords) {
public static Card getPlantToken(int level)
{
String imageName = "";
int baseAttack = 0;
int baseDefense = 0;
String keyword = "";
if (level == 1)
{
imageName = "G 0 1 Plant Wall";
baseDefense = 1;
}
else if (level == 2)
{
imageName = "G 0 2 Plant Wall";
baseDefense = 2;
}
else if (level == 3)
{
imageName = "G 0 3 Plant Wall";
baseDefense = 3;
}
else if (level == 4)
{
imageName = "G 1 3 Plant Wall";
baseDefense = 3;
baseAttack = 1;
}
else if (level == 5)
{
imageName = "G 1 3 Plant Wall Deathtouch";
baseDefense = 3;
baseAttack = 1;
keyword = "Deathtouch";
}
else if (level == 6)
{
imageName = "G 1 4 Plant Wall";
baseDefense = 4;
baseAttack = 1;
keyword = "Deathtouch";
}
Card c = new Card();
c.setName("Plant Wall");
c.setImageName(imageName);
c.setController(AllZone.HumanPlayer);
c.setOwner(AllZone.HumanPlayer);
//c.setManaCost("G");
c.addColor("G");
c.setToken(true);
c.addType("Creature");
c.addType("Plant");
c.addType("Wall");
c.addIntrinsicKeyword("Defender");
if (!keyword.equals(""))
c.addIntrinsicKeyword("Deathtouch");
c.setBaseAttack(baseAttack);
c.setBaseDefense(baseDefense);
if (level == 6)
{
final Card crd = c;
Ability_Cost abCost = new Ability_Cost("T", crd.getName(), true);
final SpellAbility ability = new Ability_Activated(crd, abCost, null){
private static final long serialVersionUID = 7546242087593613719L;
@Override
public boolean canPlayAI() {
return AllZone.Phase.getPhase().equals(Constant.Phase.Main2);
}
@Override
public void resolve() {
crd.getController().gainLife(1, crd);
}
};
c.addSpellAbility(ability);
ability.setDescription("tap: You gain 1 life.");
StringBuilder sb = new StringBuilder();
sb.append("Plant Wall - ").append(c.getController()).append(" gains 1 life.");
ability.setStackDescription(sb.toString());
c.setText("tap: You gain 1 life.");
}
return c;
}//getPlantToken
public static Card getWolfPetToken(int level)
{
String imageName = "";
int baseAttack = 0;
int baseDefense = 0;
if (level == 1)
{
imageName = "G 1 1 Wolf Pet";
baseDefense = 1;
baseAttack = 1;
}
else if (level == 2)
{
imageName = "G 1 2 Wolf Pet";
baseDefense = 2;
baseAttack = 1;
}
else if (level == 3)
{
imageName = "G 2 2 Wolf Pet";
baseDefense = 2;
baseAttack = 2;
}
else if (level == 4)
{
imageName = "G 2 2 Wolf Pet Flanking";
baseDefense = 2;
baseAttack = 2;
}
Card c = new Card();
c.setName("Wolf Pet");
c.setImageName(imageName);
c.setController(AllZone.HumanPlayer);
c.setOwner(AllZone.HumanPlayer);
//c.setManaCost("G");
c.addColor("G");
c.setToken(true);
c.addType("Creature");
c.addType("Wolf");
c.addType("Pet");
if (level >= 4)
c.addIntrinsicKeyword("Flanking");
c.setBaseAttack(baseAttack);
c.setBaseDefense(baseDefense);
return c;
}//getWolfPetToken
public static Card getCrocPetToken(int level)
{
String imageName = "";
int baseAttack = 0;
int baseDefense = 0;
if (level == 1)
{
imageName = "B 1 1 Crocodile Pet";
baseDefense = 1;
baseAttack = 1;
}
else if (level == 2)
{
imageName = "B 2 1 Crocodile Pet";
baseDefense = 1;
baseAttack = 2;
}
else if (level == 3)
{
imageName = "B 3 1 Crocodile Pet";
baseDefense = 1;
baseAttack = 3;
}
else if (level == 4)
{
imageName = "B 3 1 Crocodile Pet Swampwalk";
baseDefense = 1;
baseAttack = 3;
}
Card c = new Card();
c.setName("Crocodile Pet");
c.setImageName(imageName);
c.setController(AllZone.HumanPlayer);
c.setOwner(AllZone.HumanPlayer);
//c.setManaCost("B");
c.addColor("B");
c.setToken(true);
c.addType("Creature");
c.addType("Crocodile");
c.addType("Pet");
if (level >= 4)
c.addIntrinsicKeyword("Swampwalk");
c.setBaseAttack(baseAttack);
c.setBaseDefense(baseDefense);
return c;
}//getCrocPetToken
public static Card getBirdPetToken(int level)
{
String imageName = "";
int baseAttack = 0;
int baseDefense = 0;
if (level == 1)
{
imageName = "W 0 1 Bird Pet";
baseDefense = 1;
baseAttack = 0;
}
else if (level == 2)
{
imageName = "W 1 1 Bird Pet";
baseDefense = 1;
baseAttack = 1;
}
else if (level == 3)
{
imageName = "W 2 1 Bird Pet";
baseDefense = 1;
baseAttack = 2;
}
else if (level == 4)
{
imageName = "W 2 1 Bird Pet First Strike";
baseDefense = 1;
baseAttack = 2;
}
Card c = new Card();
c.setName("Bird Pet");
c.setImageName(imageName);
c.setController(AllZone.HumanPlayer);
c.setOwner(AllZone.HumanPlayer);
//c.setManaCost("W");
c.addColor("W");
c.setToken(true);
c.addType("Creature");
c.addType("Bird");
c.addType("Pet");
c.addIntrinsicKeyword("Flying");
if (level >= 4)
c.addIntrinsicKeyword("First Strike");
c.setBaseAttack(baseAttack);
c.setBaseDefense(baseDefense);
return c;
}
public static Card getHoundPetToken(int level)
{
String imageName = "";
int baseAttack = 0;
int baseDefense = 0;
if (level == 1)
{
imageName = "R 1 1 Hound Pet";
baseDefense = 1;
baseAttack = 1;
}
else if (level == 2)
{
imageName = "R 1 1 Hound Pet Haste";
baseDefense = 1;
baseAttack = 1;
}
else if (level == 3)
{
imageName = "R 2 1 Hound Pet";
baseDefense = 1;
baseAttack = 2;
}
else if (level == 4)
{
imageName = "R 2 1 Hound Pet Alone";
baseDefense = 1;
baseAttack = 2;
}
Card c = new Card();
c.setName("Hound Pet");
c.setImageName(imageName);
c.setController(AllZone.HumanPlayer);
c.setOwner(AllZone.HumanPlayer);
//c.setManaCost("R");
c.addColor("R");
c.setToken(true);
c.addType("Creature");
c.addType("Hound");
c.addType("Pet");
if (level >= 2)
c.addIntrinsicKeyword("Haste");
if (level >= 4)
c.addIntrinsicKeyword("Whenever this creature attacks alone, it gets +2/+0 until end of turn.");
c.setBaseAttack(baseAttack);
c.setBaseDefense(baseDefense);
return c;
}
public static ArrayList<String> getPetNames(QuestData questData)
{
ArrayList<String> list = new ArrayList<String>();
if (questData.getWolfPetLevel() > 0)
list.add("Wolf");
if (questData.getCrocPetLevel() > 0)
list.add("Croc");
if (questData.getBirdPetLevel() > 0)
list.add("Bird");
if (questData.getHoundPetLevel() > 0)
list.add("Hound");
return list;
}
public static void setupQuest(Quest_Assignment qa)
{

View File

@@ -2,7 +2,7 @@ package forge.quest.data.pet;
import forge.Card;
public abstract class QuestPetAbstract {
public abstract class QuestPetAbstract implements Comparable{
int level;
private int maxLevel;
private String name;
@@ -55,4 +55,21 @@ public abstract class QuestPetAbstract {
public void setLevel(int level){
this.level = level;
}
public String getDescription() {
return description;
}
public String getName() {
return name;
}
@Override
public String toString() {
return name;
}
public int compareTo(Object o) {
return name.compareTo(o.toString());
}
}

View File

@@ -1,17 +0,0 @@
package forge.quest.data.pet;
import java.util.ArrayList;
import java.util.List;
public class QuestPetFactory {
static List<QuestPetAbstract> getAllPets(){
List<QuestPetAbstract> pets = new ArrayList<QuestPetAbstract>();
pets.add(new QuestPetWolf());
pets.add(new QuestPetCrocodile());
pets.add(new QuestPetBird());
pets.add(new QuestPetHound());
return pets;
}
}

View File

@@ -0,0 +1,102 @@
package forge.quest.data.pet;
import java.util.*;
public class QuestPetManager{
public Map<String, QuestPetAbstract> pets = new HashMap<String, QuestPetAbstract>();
public QuestPetAbstract selectedPet;
public QuestPetAbstract plant;
public boolean usePlant;
public QuestPetManager() {
plant = new QuestPetPlant();
for (QuestPetAbstract pet : getAllPets()) {
addPet(pet);
}
}
public void setSelectedPet(String pet) {
selectedPet = (pet == null) ? null : getPet(pet);
}
public QuestPetAbstract getSelectedPet() {
return selectedPet;
}
public QuestPetAbstract getPlant() {
return plant;
}
public void addPlantLevel() {
if (plant == null) {
plant = new QuestPetPlant();
}
else {
plant.incrementLevel();
}
}
public QuestPetAbstract getPet(String petName) {
return pets.get(petName);
}
public void addPet(QuestPetAbstract newPet) {
pets.put(newPet.getName(), newPet);
}
public Set<String> getPetNames() {
return pets.keySet();
}
public void addPetLevel(String s) {
pets.get(s).incrementLevel();
}
public boolean shouldPlantBeUsed() {
return usePlant;
}
public boolean shouldPetBeUsed() {
return selectedPet != null;
}
public static Set<QuestPetAbstract> getAllPets() {
SortedSet<QuestPetAbstract> set = new TreeSet<QuestPetAbstract>();
set.add(new QuestPetBird());
set.add(new QuestPetCrocodile());
set.add(new QuestPetHound());
set.add(new QuestPetWolf());
return set;
}
public Set<String> getAvailablePetNames() {
SortedSet<String> set = new TreeSet<String>();
for (Map.Entry<String, QuestPetAbstract> pet : pets.entrySet()) {
if (pet.getValue().getLevel() > 0){
set.add(pet.getKey());
}
}
return set;
}
public Collection<QuestPetAbstract> getPets() {
return pets.values();
}
//Magic to support added pet types when reading saves.
private Object readResolve() {
for (QuestPetAbstract pet : getAllPets()) {
if (!pets.containsKey(pet.getName())) {
addPet(pet);
}
}
return this;
}
}

View File

@@ -2,7 +2,6 @@ package forge.quest.gui;
import forge.AllZone;
import forge.Gui_NewGame;
import forge.QuestData;
import forge.gui.GuiUtils;
import forge.quest.gui.bazaar.QuestBazaarPanel;
import forge.quest.gui.main.QuestMainPanel;
@@ -24,7 +23,6 @@ public class QuestFrame extends JFrame {
public static final String MAIN_PANEL = "Main";
public static final String BAZAAR_PANEL = "Bazaar";
private static final String QUESTS_PANEL = "Quests";
Map<String, QuestAbstractPanel> subPanelMap = new HashMap<String, QuestAbstractPanel>();
@@ -79,7 +77,7 @@ public class QuestFrame extends JFrame {
public void returnToMainMenu() {
QuestData.saveData(AllZone.QuestData);
AllZone.QuestData.saveData();
(new Gui_NewGame()).setVisible(true) ;
this.dispose();
}

View File

@@ -1,7 +1,6 @@
package forge.quest.gui.bazaar;
import forge.AllZone;
import forge.QuestData;
import forge.gui.GuiUtils;
import javax.swing.*;
@@ -72,7 +71,7 @@ public abstract class QuestAbstractBazaarItem {
public void actionPerformed(ActionEvent e) {
AllZone.QuestData.subtractCredits(price);
purchaseItem();
QuestData.saveData(AllZone.QuestData);
AllZone.QuestData.saveData();
QuestBazaarPanel.refreshLastInstance();
}
});

View File

@@ -1,9 +1,9 @@
package forge.quest.gui.bazaar;
import forge.AllZone;
import forge.QuestData;
import forge.gui.GuiUtils;
import forge.properties.NewConstants;
import forge.quest.data.QuestData;
import javax.swing.*;
import javax.swing.border.EmptyBorder;

View File

@@ -1,133 +1,44 @@
package forge.quest.gui.bazaar;
import forge.gui.GuiUtils;
import forge.quest.data.pet.QuestPetAbstract;
import java.util.ArrayList;
import java.util.List;
public class QuestNurseryStall extends QuestAbstractBazaarStall{
private static final long serialVersionUID = 9217496944324343390L;
public class QuestNurseryStall extends QuestAbstractBazaarStall {
private static final long serialVersionUID = 9217496944324343390L;
public QuestNurseryStall() {
super("Nursery", "LeafIconSmall.png", "The smells of the one hundred and one different plants forms a unique fragrance.");
public QuestNurseryStall() {
super("Nursery",
"LeafIconSmall.png",
"The smells of the one hundred and one different plants forms a unique fragrance.");
}
@Override
protected List<QuestAbstractBazaarItem> populateItems() {
if (questData.getPlantLevel()>=6){
QuestPetAbstract plant = questData.getPetManager().getPlant();
if (plant.getLevel() >= 6) {
return new ArrayList<QuestAbstractBazaarItem>();
}
List<QuestAbstractBazaarItem> itemList = new ArrayList<QuestAbstractBazaarItem>();
itemList.add(new QuestAbstractBazaarItem("Wall of plants",
getDesc(),
getPrice(),
GuiUtils.getIconFromFile(getImageString())) {
itemList.add(new QuestAbstractBazaarItem(plant.getName(),
plant.getUpgradeDescription(),
plant.getUpgradePrice(),
GuiUtils.getIconFromFile(plant.getImageName())) {
@Override
public void purchaseItem() {
questData.addPlantLevel();
questData.getPetManager().getPlant().incrementLevel();
}
});
return itemList;
}
private String getDesc()
{
StringBuilder sb = new StringBuilder();
sb.append("<html>");
if (questData.getPlantLevel() == 0)
{
sb.append("<br>Start each of your battles with this lush, verdant plant on your side.<br>");
sb.append("Excellent at blocking the nastiest of critters!<br><br>");
sb.append("<u><b>Current Level</b></u>: <em>Not purchased</em><br>");
sb.append("<u><b>Level 1</b></u>: 0/1<br>");
sb.append("<u><b>Level 2</b></u>: 0/2<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 1)
{
sb.append("Improve the toughness of your plant.<br>");
sb.append("<u><b>Current Level</b></u>: 0/1 <br>");
sb.append("<u><b>Level 2</b></u>: 0/2<br>");
sb.append("<u><b>Level 3</b></u>: 0/3<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 2)
{
sb.append("Improve the toughness of your plant.<br>");
sb.append("<u><b>Current Level</b></u>: 0/2 <br>");
sb.append("<u><b>Level 3</b></u>: 0/3<br>");
sb.append("<u><b>Level 4</b></u>: 1/3<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 3)
{
sb.append("Improve the power of your plant.<br>");
sb.append("<u><b>Current Level</b></u>: 0/3 <br>");
sb.append("<u><b>Level 4</b></u>: 1/3<br>");
sb.append("<u><b>Level 5</b></u>: Deathtouch<br>");
sb.append("<u><b>Can learn</b></u>: Deathtouch");
}
else if (questData.getPlantLevel() == 4)
{
sb.append("Grow venomous thorns on your plant.<br>");
sb.append("<u><b>Current Level</b></u>: 1/3 <br>");
sb.append("<u><b>Level 5</b></u>: 1/3, Deathtouch<br>");
sb.append("<u><b>Level 6</b></u>: 1/4, Deathtouch, Tap: you gain 1 life.<br>");
}
else if (questData.getPlantLevel() == 5)
{
sb.append("As well as gaining more toughness,<br>");
sb.append("your plant will have healing properties.<br>");
sb.append("<u><b>Current Level</b></u>: 1/3, Deathtouch<br>");
sb.append("<u><b>Level 6</b></u>: 1/4, Deathtouch, Tap: you gain 1 life.");
}
else
{
sb.append("Plant Level Maxed out.");
}
sb.append("</html>");
return sb.toString();
}
private int getPrice()
{
int l = 0;
if (questData.getPlantLevel() == 0)
l = 100;
else if (questData.getPlantLevel() == 1)
l = 150;
else if (questData.getPlantLevel() == 2)
l = 200;
else if (questData.getPlantLevel() == 3)
l = 300;
else if (questData.getPlantLevel() == 4)
l = 750;
else if (questData.getPlantLevel() == 5)
l = 1000;
return l;
}
private String getImageString()
{
String s = "";
if (questData.getPlantLevel() == 0)
s = "g_0_1_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 1)
s = "g_0_2_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 2)
s = "g_0_3_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 3)
s = "g_1_3_plant_wall_small.jpg";
else if (questData.getPlantLevel() == 4)
s = "g_1_3_plant_wall_deathtouch_small.jpg";
else if (questData.getPlantLevel() == 5)
s = "g_1_4_plant_wall_small.jpg";
return s;
}
}

View File

@@ -1,8 +1,10 @@
package forge.quest.gui.bazaar;
import forge.gui.GuiUtils;
import forge.quest.data.pet.QuestPetAbstract;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
public class QuestPetStall extends QuestAbstractBazaarStall {
@@ -17,246 +19,25 @@ public class QuestPetStall extends QuestAbstractBazaarStall {
protected List<QuestAbstractBazaarItem> populateItems() {
List<QuestAbstractBazaarItem> itemList = new ArrayList<QuestAbstractBazaarItem>();
if (questData.getWolfPetLevel()<=3){
itemList.add(new QuestAbstractBazaarItem("Wolf Pet",
getDesc(WOLF),
getPrice(WOLF),
GuiUtils.getIconFromFile(getImageString(WOLF))) {
@Override
public void purchaseItem() {
questData.addWolfPetLevel();
}
});
}
if (questData.getCrocPetLevel()<=3){
itemList.add(new QuestAbstractBazaarItem("Crocodile Pet",
getDesc(CROC),
getPrice(CROC),
GuiUtils.getIconFromFile(getImageString(CROC))) {
@Override
public void purchaseItem() {
questData.addCrocPetLevel();
}
});
}
if (questData.getBirdPetLevel()<=3){
itemList.add(new QuestAbstractBazaarItem("Bird Pet",
getDesc(BIRD),
getPrice(BIRD),
GuiUtils.getIconFromFile(getImageString(BIRD))) {
@Override
public void purchaseItem() {
questData.addBirdPetLevel();
}
});
}
if (questData.getHoundPetLevel()<=3){
itemList.add(new QuestAbstractBazaarItem("Hound Pet",
getDesc(HOUND),
getPrice(HOUND),
GuiUtils.getIconFromFile(getImageString(HOUND))) {
@Override
public void purchaseItem() {
questData.addHoundPetLevel();
}
});
Collection<QuestPetAbstract> pets = questData.getPetManager().getPets();
for (final QuestPetAbstract pet : pets) {
if (pet.getLevel() < pet.getMaxLevel()){
itemList.add(new QuestAbstractBazaarItem(
pet.getName(),
pet.getUpgradeDescription(),
pet.getUpgradePrice(),
GuiUtils.getIconFromFile(pet.getImageName())) {
@Override
public void purchaseItem() {
questData.getPetManager().addPetLevel(pet.getName());
}
});
}
}
return itemList;
}
private String getDesc(int petType) {
StringBuilder sb = new StringBuilder();
sb.append("<html><br>");
switch (petType) {
case WOLF:
if (questData.getWolfPetLevel() == 0) {
sb.append("This ferocious animal may have been raised in captivity, but it has been trained to<br>kill.<br>");
sb.append("<em>Eats goblins for breakfast.<em><br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 1/2<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
} else if (questData.getWolfPetLevel() == 1) {
sb.append("Improve the toughness of your wolf.<br>");
sb.append("<u><b>Level 2</b></u>: 1/2<br>");
sb.append("<u><b>Next Level</b></u>: 2/2<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
} else if (questData.getWolfPetLevel() == 2) {
sb.append("Improve the attack power of your wolf.<br>");
sb.append("<u><b>Level 3</b></u>: 2/2<br>");
sb.append("<u><b>Next Level</b></u>: Flanking<br>");
sb.append("<u><b>Can learn</b></u>: Flanking");
} else if (questData.getWolfPetLevel() == 3) {
sb.append("Gives Flanking to your wolf.<br>");
sb.append("<u><b>Level 4</b></u>: 2/2 Flanking<br>");
}
break;
case CROC:
if (questData.getCrocPetLevel() == 0) {
sb.append("With its razor sharp teeth, this swamp-dwelling monster is extremely dangerous.<br>");
sb.append("<em>Crikey mate!<em><br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1<br>");
sb.append("<u><b>Can learn</b></u>: Swampwalk");
} else if (questData.getCrocPetLevel() == 1) {
sb.append("Improve the attack power of your croc.<br>");
sb.append("<u><b>Level 2</b></u>: 2/1<br>");
sb.append("<u><b>Next Level</b></u>: 3/1<br>");
sb.append("<u><b>Can learn</b></u>: Swampwalk");
} else if (questData.getCrocPetLevel() == 2) {
sb.append("Improve the attack power of your croc.<br>");
sb.append("<u><b>Level 3</b></u>: 3/1<br>");
sb.append("<u><b>Next Level</b></u>: 3/1 Swampwalk<br>");
} else if (questData.getCrocPetLevel() == 3) {
sb.append("Gives Swampwalk to your croc.<br>");
sb.append("<u><b>Level 4</b></u>: 3/1 Swampwalk<br>");
}
break;
case BIRD:
if (questData.getBirdPetLevel() == 0) {
sb.append("Unmatched in speed, agility and awareness,<br>");
sb.append("this trained hawk makes a fantastic hunter.<br><br>");
sb.append("<u><b>Level 1</b></u>: 0/1 Flying<br>");
sb.append("<u><b>Next Level</b></u>: 1/1<br>");
sb.append("<u><b>Can learn</b></u>: First strike");
} else if (questData.getBirdPetLevel() == 1) {
sb.append("Improve the attack power of your bird.<br>");
sb.append("<u><b>Level 2</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 <br>");
sb.append("<u><b>Can learn</b></u>: First strike");
} else if (questData.getBirdPetLevel() == 2) {
sb.append("Improve the attack power of your bird.<br>");
sb.append("<u><b>Level 3</b></u>: 2/1<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 First strike<br>");
} else if (questData.getBirdPetLevel() == 3) {
sb.append("Gives First strike to your bird.<br>");
sb.append("<u><b>Level 4</b></u>: 2/1 First strike<br>");
}
break;
case HOUND:
if (questData.getHoundPetLevel() == 0) {
sb.append("Dogs are said to be man's best friend.<br>");
sb.append("Definitely not this one.<br><br>");
sb.append("<u><b>Level 1</b></u>: 1/1<br>");
sb.append("<u><b>Next Level</b></u>: 1/1 Haste<br>");
sb.append("<u><b>Can learn</b></u>: Whenever this creature attacks alone,<br> it gets +2/+0 until end of turn.");
} else if (questData.getHoundPetLevel() == 1) {
sb.append("Gives haste to your hound.<br>");
sb.append("<u><b>Level 2</b></u>: 1/1 Haste<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 Haste<br>");
sb.append("<u><b>Can learn</b></u>: Whenever this creature attacks alone,<br> it gets +2/+0 until end of turn.");
} else if (questData.getHoundPetLevel() == 2) {
sb.append("Improve the attack power of your hound.<br>");
sb.append("<u><b>Level 3</b></u>: 2/1 Haste<br>");
sb.append("<u><b>Next Level</b></u>: 2/1 Whenever this creature attacks<br> alone, it gets +2/+0 until end of turn.<br>");
} else if (questData.getHoundPetLevel() == 3) {
sb.append("Greatly improves your hound's attack power if it<br> attacks alone.<br>");
sb.append("<u><b>Level 4</b></u>: 2/1 Haste, whenever this creature attacks alone, it gets +2/+0 until end of turn.<br>");
}
break;
}
sb.append("</html>");
return sb.toString();
}
private int getPrice(int petType) {
int l = 0;
switch (petType) {
case WOLF:
if (questData.getWolfPetLevel() == 0)
l = 250;
else if (questData.getWolfPetLevel() == 1)
l = 250;
else if (questData.getWolfPetLevel() == 2)
l = 500;
else if (questData.getWolfPetLevel() == 3)
l = 550;
break;
case CROC:
if (questData.getCrocPetLevel() == 0)
l = 250;
else if (questData.getCrocPetLevel() == 1)
l = 300;
else if (questData.getCrocPetLevel() == 2)
l = 450;
else if (questData.getCrocPetLevel() == 3)
l = 600;
break;
case BIRD:
if (questData.getBirdPetLevel() == 0)
l = 200;
else if (questData.getBirdPetLevel() == 1)
l = 300;
else if (questData.getBirdPetLevel() == 2)
l = 450;
else if (questData.getBirdPetLevel() == 3)
l = 400;
break;
case HOUND:
if (questData.getHoundPetLevel() == 0)
l = 200;
else if (questData.getHoundPetLevel() == 1)
l = 350;
else if (questData.getHoundPetLevel() == 2)
l = 450;
else if (questData.getHoundPetLevel() == 3)
l = 750;
break;
}
return l;
}
private String getImageString(int petType) {
String s = null;
switch (petType) {
case WOLF:
if (questData.getWolfPetLevel() == 0)
s = "g_1_1_wolf_pet_small.jpg";
else if (questData.getWolfPetLevel() == 1)
s = "g_1_2_wolf_pet_small.jpg";
else if (questData.getWolfPetLevel() == 2)
s = "g_2_2_wolf_pet_small.jpg";
else if (questData.getWolfPetLevel() == 3)
s = "g_2_2_wolf_pet_flanking_small.jpg";
break;
case CROC:
if (questData.getCrocPetLevel() == 0)
s = "b_1_1_crocodile_pet_small.jpg";
else if (questData.getCrocPetLevel() == 1)
s = "b_2_1_crocodile_pet_small.jpg";
else if (questData.getCrocPetLevel() == 2)
s = "b_3_1_crocodile_pet_small.jpg";
else if (questData.getCrocPetLevel() == 3)
s = "b_3_1_crocodile_pet_swampwalk_small.jpg";
break;
case BIRD:
if (questData.getBirdPetLevel() == 0)
s = "w_0_1_bird_pet_small.jpg";
else if (questData.getBirdPetLevel() == 1)
s = "w_1_1_bird_pet_small.jpg";
else if (questData.getBirdPetLevel() == 2)
s = "w_2_1_bird_pet_small.jpg";
else if (questData.getBirdPetLevel() == 3)
s = "w_2_1_bird_pet_first_strike_small.jpg";
case HOUND:
if (questData.getHoundPetLevel() == 0)
s = "r_1_1_hound_pet_small.jpg";
else if (questData.getHoundPetLevel() == 1)
s = "r_1_1_hound_pet_haste_small.jpg";
else if (questData.getHoundPetLevel() == 2)
s = "r_2_1_hound_pet_small.jpg";
else if (questData.getHoundPetLevel() == 3)
s = "r_2_1_hound_pet_alone_small.jpg";
break;
}
return s;
}
public static final int WOLF = 1;
public static final int CROC = 2;
public static final int HOUND = 3;
public static final int BIRD = 4;
}

View File

@@ -2,8 +2,8 @@ package forge.quest.gui.main;
import forge.AllZone;
import forge.QuestData;
import forge.gui.GuiUtils;
import forge.quest.data.QuestData;
import javax.swing.*;
import java.util.ArrayList;
@@ -233,23 +233,23 @@ public class QuestBattle extends QuestSelectablePanel {
public static List<QuestSelectablePanel> getBattles(){
List<QuestSelectablePanel> opponentList = new ArrayList<QuestSelectablePanel>();
try{
QuestData questData = AllZone.QuestData;
String[] opponentNames = questData.getOpponents();
for (String opponentName : opponentNames) {
String oppIconName = opponentName.substring(0, opponentName.length() - 1).trim() + ".jpg";
ImageIcon icon = GuiUtils.getIconFromFile(oppIconName);
try {
String oppIconName = opponentName.substring(0, opponentName.length() - 1).trim() + ".jpg";
ImageIcon icon = GuiUtils.getIconFromFile(oppIconName);
opponentList.add(new QuestBattle(opponentName,
nameDeckMap.get(opponentName).difficulty,
nameDeckMap.get(opponentName).description,
icon));
}
}
catch (NullPointerException e)
{
System.out.println("Break Here");
opponentList.add(new QuestBattle(opponentName,
nameDeckMap.get(opponentName).difficulty,
nameDeckMap.get(opponentName).description,
icon));
}
catch (NullPointerException e) {
System.out.println("Caught NPE, Fix me:" + opponentName);
}
}
return opponentList;
}

View File

@@ -2,6 +2,7 @@ package forge.quest.gui.main;
import forge.*;
import forge.gui.GuiUtils;
import forge.quest.data.QuestData;
import forge.quest.gui.QuestAbstractPanel;
import forge.quest.gui.QuestFrame;
@@ -14,17 +15,15 @@ import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.*;
import java.util.List;
//presumes AllZone.QuestData is not null
//presumes AllZone.QuestDataOld is not null
//AllZone.QuestData should be set by Gui_QuestOptions
//AllZone.QuestDataOld should be set by Gui_QuestOptions
public class QuestMainPanel extends QuestAbstractPanel {
private QuestData questData;
private forge.quest.data.QuestData questData;
JLabel creditsLabel = new JLabel();
JLabel lifeLabel = new JLabel();
@@ -148,7 +147,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
cardShopButton.setFont(new Font(Font.SANS_SERIF, Font.PLAIN, 20));
JButton bazaarButton = null;
if (questData.getMode().equals(QuestData.FANTASY)) {
if (questData.getMode().equals(forge.quest.data.QuestData.FANTASY)) {
bazaarButton = new JButton("Bazaar");
bazaarButton.addActionListener(new ActionListener() {
@@ -192,7 +191,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
panel.add(Box.createVerticalGlue());
panel.add(Box.createVerticalGlue());
if (questData.getMode().equals(QuestData.FANTASY)) {
if (questData.getMode().equals(forge.quest.data.QuestData.FANTASY)) {
panel.add(this.lifeLabel);
this.lifeLabel.setFont(new Font(Font.DIALOG, Font.BOLD, 14));
@@ -206,7 +205,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
GuiUtils.addGap(panel, 10);
panel.add(cardShopButton);
if (questData.getMode().equals(QuestData.FANTASY)) {
if (questData.getMode().equals(forge.quest.data.QuestData.FANTASY)) {
GuiUtils.addGap(panel);
panel.add(bazaarButton);
}
@@ -274,17 +273,17 @@ public class QuestMainPanel extends QuestAbstractPanel {
GuiUtils.addGap(matchPanel);
if (questData.getMode().equals(QuestData.FANTASY)) {
if (questData.getMode().equals(forge.quest.data.QuestData.FANTASY)) {
JPanel petPanel = new JPanel();
petPanel.setLayout(new BoxLayout(petPanel, BoxLayout.X_AXIS));
this.petCheckBox.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent actionEvent) {
if (petCheckBox.isSelected()) {
questData.setSelectedPet((String) petComboBox.getSelectedItem());
questData.getPetManager().setSelectedPet((String) petComboBox.getSelectedItem());
}
else {
questData.setSelectedPet("No Plant/Pet");
questData.getPetManager().setSelectedPet(null);
}
petComboBox.setEnabled(petCheckBox.isSelected());
@@ -296,10 +295,10 @@ public class QuestMainPanel extends QuestAbstractPanel {
this.petComboBox.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent actionEvent) {
if (petCheckBox.isSelected()) {
questData.setSelectedPet((String) petComboBox.getSelectedItem());
questData.getPetManager().setSelectedPet((String) petComboBox.getSelectedItem());
}
else {
questData.setSelectedPet("No Plant/Pet");
questData.getPetManager().setSelectedPet(null);
}
}
});
@@ -350,7 +349,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
}
void refresh() {
QuestData.saveData(AllZone.QuestData);
AllZone.QuestData.saveData();
devModeCheckBox.setSelected(Constant.Runtime.DevMode[0]);
smoothLandCheckBox.setSelected(Constant.Runtime.Smooth[0]);
@@ -400,7 +399,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
petComboBox.removeAllItems();
List<String> petList = QuestUtil.getPetNames(questData);
Set<String> petList = questData.getPetManager().getAvailablePetNames();
if (petList.size() > 0) {
petComboBox.setEnabled(true);
@@ -416,13 +415,13 @@ public class QuestMainPanel extends QuestAbstractPanel {
petCheckBox.setEnabled(false);
}
if (questData.getSelectedPet() == null || questData.getSelectedPet().equals("No Plant/Pet")) {
if (!questData.getPetManager().shouldPetBeUsed()) {
petCheckBox.setSelected(false);
petComboBox.setEnabled(false);
}
else {
petCheckBox.setSelected(true);
petComboBox.setSelectedItem(questData.getSelectedPet());
petComboBox.setSelectedItem(questData.getPetManager().getSelectedPet().getName());
}
}
@@ -462,7 +461,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
public void execute() {
//saves all deck data
QuestData.saveData(AllZone.QuestData);
AllZone.QuestData.saveData();
new QuestFrame();
}
@@ -485,7 +484,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
public void execute() {
//saves all deck data
QuestData.saveData(AllZone.QuestData);
AllZone.QuestData.saveData();
new QuestFrame();
}
@@ -549,9 +548,9 @@ public class QuestMainPanel extends QuestAbstractPanel {
AllZone.GameAction.newGame(
humanDeck,
computer,
QuestUtil.getHumanPlantAndPet(questData),
forge.quest.data.QuestUtil.getHumanPlantAndPet(questData),
new CardList(),
QuestUtil.getLife(questData),
questData.getLife(),
20,
null);
}
@@ -573,7 +572,7 @@ public class QuestMainPanel extends QuestAbstractPanel {
AllZone.GameAction.newGame(
humanDeck,
computerDeck,
QuestUtil.getHumanPlantAndPet(questData, selectedQuest),
forge.quest.data.QuestUtil.getHumanPlantAndPet(questData, selectedQuest),
new CardList(),
questData.getLife() + extraLife,
selectedQuest.getComputerLife(),

View File

@@ -1,7 +1,6 @@
package forge.quest.gui.main;
import forge.AllZone;
import forge.QuestData;
import forge.Quest_Assignment;
import forge.ReadQuest_Assignment;
import forge.gui.GuiUtils;
@@ -46,21 +45,21 @@ public class QuestQuest extends QuestSelectablePanel {
}
private static List<Quest_Assignment> readQuests() {
QuestData questData = AllZone.QuestData;
forge.quest.data.QuestData questData = AllZone.QuestData;
ReadQuest_Assignment read = new ReadQuest_Assignment(ForgeProps.getFile(NewConstants.QUEST.QUESTS), questData);
read.run();
ArrayList<Quest_Assignment> questsToDisplay = new ArrayList<Quest_Assignment>();
List<Quest_Assignment> questsToDisplay = new ArrayList<Quest_Assignment>();
if (questData.getAvailableQuests() != null && questData.getAvailableQuests().size() > 0) {
ArrayList<Quest_Assignment> availableQuests = read.getQuestsByIds(questData.getAvailableQuests());
List<Quest_Assignment> availableQuests = read.getQuestsByIds(questData.getAvailableQuests());
questsToDisplay = availableQuests;
}
else {
ArrayList<Quest_Assignment> allAvailableQuests = read.getQuests();
List<Quest_Assignment> allAvailableQuests = read.getQuests();
ArrayList<Integer> availableInts = new ArrayList<Integer>();
List<Integer> availableInts = new ArrayList<Integer>();
int maxQuests = questData.getWin() / 10;
if (maxQuests > 5) {
@@ -80,7 +79,7 @@ public class QuestQuest extends QuestSelectablePanel {
questsToDisplay.add(qa);
}
questData.setAvailableQuests(availableInts);
QuestData.saveData(questData);
questData.saveData();
}//else
return questsToDisplay;
}