2014-09-13 19:32:00 -04:00
|
|
|
#pragma once
|
|
|
|
|
2014-09-21 16:58:09 -04:00
|
|
|
#include <memory>
|
2014-09-20 17:03:13 -04:00
|
|
|
#include <QList>
|
2014-09-13 19:32:00 -04:00
|
|
|
#include <QMainWindow>
|
2014-09-22 12:26:35 -04:00
|
|
|
#include <QHBoxLayout>
|
2014-09-13 19:32:00 -04:00
|
|
|
#include "BiomeView.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-09-21 16:58:09 -04:00
|
|
|
// fwd:
|
2014-09-22 12:26:35 -04:00
|
|
|
class GeneratorSetup;
|
2014-09-21 16:58:09 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-09-13 19:32:00 -04:00
|
|
|
class MainWindow :
|
|
|
|
public QMainWindow
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2014-09-21 16:58:09 -04:00
|
|
|
MainWindow(QWidget * parent = nullptr);
|
2014-09-13 19:32:00 -04:00
|
|
|
~MainWindow();
|
|
|
|
|
|
|
|
private slots:
|
2014-09-21 16:58:09 -04:00
|
|
|
/** Creates a generator definition from scratch, lets user modify generator params in realtime. */
|
|
|
|
void newGenerator();
|
|
|
|
|
2014-09-13 19:32:00 -04:00
|
|
|
/** Opens a generator definition and generates the biomes based on that. */
|
2014-09-21 16:58:09 -04:00
|
|
|
void openGenerator();
|
2014-09-13 19:32:00 -04:00
|
|
|
|
|
|
|
/** Opens an existing world and displays the loaded biomes. */
|
2014-09-21 16:58:09 -04:00
|
|
|
void openWorld();
|
2014-09-13 19:32:00 -04:00
|
|
|
|
2014-09-20 17:03:13 -04:00
|
|
|
/** Opens a vanilla world that is specified by the calling action. */
|
|
|
|
void openVanillaWorld();
|
|
|
|
|
2014-09-13 19:32:00 -04:00
|
|
|
protected:
|
|
|
|
// Actions:
|
2014-09-21 16:58:09 -04:00
|
|
|
QAction * m_actNewGen;
|
|
|
|
QAction * m_actOpenGen;
|
|
|
|
QAction * m_actOpenWorld;
|
2014-09-15 11:29:34 -04:00
|
|
|
QAction * m_actReload;
|
2014-09-13 19:32:00 -04:00
|
|
|
QAction * m_actExit;
|
|
|
|
|
2014-09-20 17:03:13 -04:00
|
|
|
/** List of actions that open the specific vanilla world. */
|
|
|
|
QList<QAction *> m_WorldActions;
|
|
|
|
|
|
|
|
/** Path to the vanilla folder. */
|
|
|
|
QString m_MinecraftPath;
|
|
|
|
|
2014-09-22 12:26:35 -04:00
|
|
|
/** The pane for setting up the generator, available when visualising a generator. */
|
|
|
|
GeneratorSetup * m_GeneratorSetup;
|
|
|
|
|
|
|
|
/** The main biome display widget. */
|
|
|
|
BiomeView * m_BiomeView;
|
|
|
|
|
|
|
|
/** The layout for the window. */
|
|
|
|
QHBoxLayout * m_MainLayout;
|
|
|
|
|
|
|
|
/** The separator line between biome view and generator setup. */
|
|
|
|
QWidget * m_LineSeparator;
|
2014-09-21 16:58:09 -04:00
|
|
|
|
2014-09-20 17:03:13 -04:00
|
|
|
|
|
|
|
/** Initializes the m_MinecraftPath based on the proper MC path */
|
|
|
|
void initMinecraftPath();
|
2014-09-13 19:32:00 -04:00
|
|
|
|
|
|
|
/** Creates the actions that the UI supports. */
|
|
|
|
void createActions();
|
|
|
|
|
2014-09-20 17:03:13 -04:00
|
|
|
/** Creates the actions that open a specific vanilla world. Iterates over the minecraft saves folder. */
|
|
|
|
void createWorldActions();
|
|
|
|
|
2014-09-13 19:32:00 -04:00
|
|
|
/** Creates the menu bar and connects its events. */
|
|
|
|
void createMenus();
|
2014-09-20 17:03:13 -04:00
|
|
|
|
|
|
|
/** Returns the name of the vanilla world in the specified path.
|
|
|
|
Reads the level.dat file for the name. Returns an empty string on failure. */
|
|
|
|
QString getWorldName(const AString & a_Path);
|
2014-09-22 12:26:35 -04:00
|
|
|
|
|
|
|
/** Opens the generator setup pane, if not already open, and loads the specified INI file to it. */
|
|
|
|
void openGeneratorSetup(const AString & a_IniFileName);
|
|
|
|
|
|
|
|
/** Closes and destroys the generator setup pane, if there is one. */
|
|
|
|
void closeGeneratorSetup();
|
2014-09-13 19:32:00 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|