Comments added to ApplicationFrame.java

This commit is contained in:
Siket Melinda Tekla 2016-05-16 14:31:31 +02:00
parent ac78f83d82
commit d30d641f03
1 changed files with 101 additions and 1 deletions

View File

@ -10,20 +10,61 @@ import java.awt.event.MouseEvent;
import java.io.File;
import java.io.IOException;
/**
* Az alkalmazás megjelenítéséért felelős osztály.
* Inicializálja az ablak egyes részeit, illetve beállítja az eseménykezelőket.
*/
public class ApplicationFrame implements Runnable
{
/**
* A ablakot reprezentáló <code>JFrame</code> példány.
*/
private JFrame jframe;
/**
* A térképválasztás alatt megjelenő tartalmat magában foglaló <code>JPanel</code> példány.
*/
private JPanel mapselectorpanel = null;
/**
* A játékmenet alatt megjelenő képernyőt reprezentáló
* <code>Display</code> példány.
*/
private Display gamepanel;
/**
* A térképválasztás alatt megjelenő fájllistát
* reprezentáló <code>JScrollPane</code> példány.
*/
private JScrollPane filescroll;
/**
* A térképválasztás alatt megjelenő menükép mérete.
*/
private Dimension menuDimension = new Dimension(640, 395);
/**
* A <code>Control</code> osztályban lévő <code>KeyHandler</code> osztály
* egy példánya, amely a billentyűzet figyeléséért felel.
*/
private KeyListener keyHandler = new Control.KeyHandler();
/**
* A fájllistából való választás eseményét kezelő osztály.
* A kiválasztott elemre való kattintás után eltűnteti a térképlistát,
* betölti az elemnek megfelelő térképet, majd azt felhasználva
* elindítja és megjeleníti a játékot.
*/
private class ListMouseHandler extends MouseAdapter{
/**
* A kiválaszott elemnek megfelelő térképet betölti,
* majd elindítja a játékot.
*
* @param e a <code>MouseEvent</code> esemény, ameny a kattintást
* reprezentálja
* @throws IOException Ha nem találja a bemeneti fájlokat.
*/
@Override
public void mouseClicked(MouseEvent e) {
jframe.remove(mapselectorpanel);
@ -40,6 +81,13 @@ public class ApplicationFrame implements Runnable
}
}
/**
* Az ablak inicializálása, alapvető tulajdonságainak beállítása.
* Elindítja a térképválasztó inicializálását, illetve megjeleníti
* azt.
*
* @see #initMapselector()
*/
public void init(){
jframe = new JFrame();
jframe.setFocusable(true);
@ -52,6 +100,13 @@ public class ApplicationFrame implements Runnable
jframe.setLocationRelativeTo(null);
}
/**
* Játék után visszatérés a térképválasztáshoz.
* Eltávolítja a játék nézetet, elindítja a térképválasztó
* inicializálását, illetve frissíti az ablak tartalmát.
*
* @see #initMapselector()
*/
public void backToMapSelection() {
jframe.remove(gamepanel);
jframe.removeKeyListener(keyHandler);
@ -61,15 +116,36 @@ public class ApplicationFrame implements Runnable
jframe.revalidate();
}
/**
* Megjeleníti az ablak aktuális tartalmát.
*/
@Override
public void run() {
jframe.setVisible(true);
}
/**
* A térképválasztó inicializálása.
* Amennyiben nem üres a panel, úgy kiveszi azt az ablakból.
* Létrehoz egy új panelt, amelybe betölti a menüképet, majd feltölti
* a térképválasztó listát is. Beállítja a térképválasztó lista
* megjelenését, majd hozzákapcsol egy egér eseménykezelőt a panelhez.
* Ebben lekezeli a Play gombra való kattintást, amely hatására hozzáadja
* és megjeleníti a térképválasztó listát a panelhez.
*
* @throws IOException Ha nem találja a bemeneti fájlokat.
*/
private void initMapselector() {
if(mapselectorpanel != null)
jframe.remove(mapselectorpanel);
mapselectorpanel = new JPanel() {
/**
* Kirajzolja a fájlból betöltött menüképet.
*
* @param g egy <code>Graphics</code> objektum, amelyre
* a rajzolófüggvény meg van hívva
*/
@Override
protected void paintComponent(Graphics g) {
super.paintComponent(g);
@ -106,6 +182,16 @@ public class ApplicationFrame implements Runnable
mapselectorpanel.setLayout(new BorderLayout());
mapselectorpanel.addMouseListener(new MouseAdapter() {
/**
* Az egérrel való kattintás eseményét lekezelő függévény.
* Amennyiben a megadott koordinátákon belül kattintanak
* (Play gomb), úgy hozzáadja a térképválasztó listát
* a panelhez, amjd frissíti a panel megjelenítését.
*
* @param e a <code>MouseEvent</code> esemény, ameny a kattintást
* reprezentálja
*/
@Override
public void mouseClicked(MouseEvent e) {
if(e.getX() > 229 && e.getY() > 186 && e.getX() < 433 && e.getY() < 219) {
@ -116,8 +202,22 @@ public class ApplicationFrame implements Runnable
}
});
}
}
/**
* Beállítja a játékmenet paramétereit.
* Létrehoz egy új <code>Display</code> példányt, egy új
* <code>Dungeon</code> példányt, amelyeket a kapott <code>File</code>
* példánnyal együtt átad a megfelelő függvényeknek, amelyek aztán
* elindítják a játékmenetet.
*
* @param dungeonFile az a <code>File</code>, amelyet a felhasználó
* a térképválasztóból választott ki
* @throws IOException Ha nem találja a bemeneti fájlokat.
* @see Game#setDisplay(Display)
* @see Game#setDungeon(Dungeon)
* @see Game#startGame(File)
*/
private void setGameParams(File dungeonFile) throws IOException {
gamepanel = new Display();