first try for a Random GP generator
This commit is contained in:
parent
359c846df4
commit
0fdfe16a93
@ -376,8 +376,7 @@ void ChallengeData::setRace(RaceManager::Difficulty d) const
|
||||
else if(m_mode==CM_GRAND_PRIX)
|
||||
{
|
||||
race_manager->setMinorMode(m_minor);
|
||||
const GrandPrixData *gp = grand_prix_manager->getGrandPrix(m_gp_id);
|
||||
race_manager->setGrandPrix(*gp);
|
||||
race_manager->setGrandPrix(grand_prix_manager->getGrandPrix(m_gp_id));
|
||||
race_manager->setDifficulty(d);
|
||||
race_manager->setNumKarts(m_num_karts[d]);
|
||||
race_manager->setNumLocalPlayers(1);
|
||||
|
@ -808,14 +808,14 @@ int handleCmdLine()
|
||||
if(CommandLine::has("--gp", &s))
|
||||
{
|
||||
race_manager->setMajorMode(RaceManager::MAJOR_MODE_GRAND_PRIX);
|
||||
const GrandPrixData *gp = grand_prix_manager->getGrandPrix(s);
|
||||
GrandPrixData *gp = grand_prix_manager->getGrandPrix(s);
|
||||
|
||||
if (!gp)
|
||||
{
|
||||
Log::warn("main", "There is no GP named '%s'.", s.c_str());
|
||||
return 0;
|
||||
}
|
||||
race_manager->setGrandPrix(*gp);
|
||||
race_manager->setGrandPrix(gp);
|
||||
} // --gp
|
||||
|
||||
if(CommandLine::has("--numkarts", &n) ||CommandLine::has("-k", &n))
|
||||
|
@ -28,9 +28,10 @@
|
||||
#include "tracks/track.hpp"
|
||||
#include "utils/string_utils.hpp"
|
||||
|
||||
#include <algorithm>
|
||||
#include <cstdlib>
|
||||
#include <iostream>
|
||||
#include <memory>
|
||||
#include <algorithm>
|
||||
#include <stdexcept>
|
||||
|
||||
|
||||
@ -44,6 +45,33 @@ GrandPrixData::GrandPrixData(const std::string& filename)
|
||||
reload();
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
GrandPrixData::GrandPrixData(const unsigned int number_of_tracks,
|
||||
const std::string& track_group,
|
||||
const bool use_reverse)
|
||||
{
|
||||
m_filename = "Random GP - Not loaded from a file!";
|
||||
m_id = "random";
|
||||
m_name = L"Random";
|
||||
m_editable = false;
|
||||
|
||||
const std::vector<int> track_indices = track_manager->getTracksInGroup(track_group);
|
||||
const size_t available_tracks = track_indices.size();
|
||||
assert(number_of_tracks <= available_tracks);
|
||||
|
||||
m_tracks.reserve(number_of_tracks);
|
||||
m_laps.reserve(number_of_tracks);
|
||||
m_reversed.reserve(number_of_tracks);
|
||||
|
||||
for (unsigned int i = 0; i < number_of_tracks; i++)
|
||||
{
|
||||
int index = track_indices[int(rand() % available_tracks)];
|
||||
m_tracks.push_back(std::string(track_manager->getTrack(index)->getIdent()));
|
||||
m_laps.push_back(3);
|
||||
m_reversed.push_back(rand() % 2);
|
||||
}
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
void GrandPrixData::setId(const std::string& id)
|
||||
{
|
||||
|
@ -76,6 +76,10 @@ public:
|
||||
GrandPrixData(const std::string& filename);
|
||||
/** Needed for simple creation of an instance of GrandPrixData */
|
||||
GrandPrixData() {};
|
||||
/** TODO */
|
||||
GrandPrixData(const unsigned int number_of_tracks,
|
||||
const std::string& m_track_group,
|
||||
const bool use_reverse);
|
||||
|
||||
// Methods for the GP editor
|
||||
void setId(const std::string& id);
|
||||
@ -117,7 +121,6 @@ public:
|
||||
// ------------------------------------------------------------------------
|
||||
/** Returns the filename of the grand prix xml file. */
|
||||
const std::string& getFilename() const { return m_filename; }
|
||||
|
||||
}; // GrandPrixData
|
||||
|
||||
#endif
|
||||
|
@ -283,9 +283,9 @@ void RaceManager::startNew(bool from_overworld)
|
||||
if(m_major_mode==MAJOR_MODE_GRAND_PRIX)
|
||||
{
|
||||
// GP: get tracks, laps and reverse info from grand prix
|
||||
m_tracks = m_grand_prix.getTrackNames();
|
||||
m_num_laps = m_grand_prix.getLaps();
|
||||
m_reverse_track = m_grand_prix.getReverse();
|
||||
m_tracks = m_grand_prix->getTrackNames();
|
||||
m_num_laps = m_grand_prix->getLaps();
|
||||
m_reverse_track = m_grand_prix->getReverse();
|
||||
}
|
||||
//assert(m_player_karts.size() > 0);
|
||||
|
||||
@ -348,7 +348,7 @@ void RaceManager::startNew(bool from_overworld)
|
||||
SavedGrandPrix* gp = SavedGrandPrix::getSavedGP( StateManager::get()
|
||||
->getActivePlayerProfile(0)
|
||||
->getUniqueID(),
|
||||
m_grand_prix.getId(),
|
||||
m_grand_prix->getId(),
|
||||
m_difficulty,
|
||||
m_num_karts,
|
||||
m_player_karts.size());
|
||||
@ -499,7 +499,7 @@ void RaceManager::next()
|
||||
SavedGrandPrix::getSavedGP(StateManager::get()
|
||||
->getActivePlayerProfile(0)
|
||||
->getUniqueID(),
|
||||
m_grand_prix.getId(),
|
||||
m_grand_prix->getId(),
|
||||
m_difficulty,
|
||||
m_num_karts,
|
||||
m_player_karts.size());
|
||||
@ -516,7 +516,7 @@ void RaceManager::next()
|
||||
new SavedGrandPrix(
|
||||
StateManager::get()->getActivePlayerProfile(0)
|
||||
->getUniqueID(),
|
||||
m_grand_prix.getId(),
|
||||
m_grand_prix->getId(),
|
||||
m_difficulty,
|
||||
m_player_karts.size(),
|
||||
m_track_number,
|
||||
@ -642,7 +642,7 @@ void RaceManager::exitRace(bool delete_world)
|
||||
SavedGrandPrix::getSavedGP(StateManager::get()
|
||||
->getActivePlayerProfile(0)
|
||||
->getUniqueID(),
|
||||
m_grand_prix.getId(),
|
||||
m_grand_prix->getId(),
|
||||
m_difficulty,
|
||||
m_num_karts,
|
||||
m_player_karts.size());
|
||||
@ -774,13 +774,14 @@ void RaceManager::rerunRace()
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
|
||||
void RaceManager::startGP(const GrandPrixData* gp, bool from_overworld,
|
||||
void RaceManager::startGP(GrandPrixData* gp, bool from_overworld,
|
||||
bool continue_saved_gp)
|
||||
{
|
||||
assert(gp != NULL);
|
||||
//std::cout << gp->getId();
|
||||
|
||||
StateManager::get()->enterGameState();
|
||||
setGrandPrix(*gp);
|
||||
setGrandPrix(gp);
|
||||
setCoinTarget( 0 ); // Might still be set from a previous challenge
|
||||
race_manager->setupPlayerKartInfo();
|
||||
m_continue_saved_gp = continue_saved_gp;
|
||||
|
@ -324,7 +324,7 @@ private:
|
||||
* same list of AIs is used for all tracks of a GP. */
|
||||
std::vector<std::string> m_ai_kart_list;
|
||||
int m_track_number;
|
||||
GrandPrixData m_grand_prix;
|
||||
GrandPrixData* m_grand_prix;
|
||||
int m_num_karts;
|
||||
unsigned int m_num_finished_karts;
|
||||
unsigned int m_num_finished_players;
|
||||
@ -410,7 +410,7 @@ public:
|
||||
void setDifficulty(Difficulty diff);
|
||||
|
||||
// ------------------------------------------------------------------------
|
||||
void setGrandPrix(const GrandPrixData &gp)
|
||||
void setGrandPrix(GrandPrixData* gp)
|
||||
{
|
||||
m_grand_prix = gp;
|
||||
m_coin_target = 0;
|
||||
@ -525,7 +525,7 @@ public:
|
||||
// ------------------------------------------------------------------------
|
||||
const std::string& getTrackName() const { return m_tracks[m_track_number];}
|
||||
// ------------------------------------------------------------------------
|
||||
const GrandPrixData *getGrandPrix() const { return &m_grand_prix; }
|
||||
GrandPrixData* getGrandPrix() const { return m_grand_prix; }
|
||||
// ------------------------------------------------------------------------
|
||||
unsigned int getFinishedKarts() const { return m_num_finished_karts; }
|
||||
// ------------------------------------------------------------------------
|
||||
@ -682,7 +682,7 @@ public:
|
||||
* \brief Higher-level method to start a GP without having to care about
|
||||
* the exact startup sequence
|
||||
*/
|
||||
void startGP(const GrandPrixData* gp, bool from_overworld,
|
||||
void startGP(GrandPrixData* gp, bool from_overworld,
|
||||
bool continue_saved_gp);
|
||||
|
||||
/**
|
||||
|
@ -123,7 +123,6 @@ void GPInfoDialog::InitAfterDrawingTheHeader(const int y1,
|
||||
}
|
||||
|
||||
// ---- Track screenshot
|
||||
|
||||
m_screenshot_widget = new IconButtonWidget(IconButtonWidget::SCALE_MODE_KEEP_CUSTOM_ASPECT_RATIO,
|
||||
false /* tab stop */, false /* focusable */,
|
||||
IconButtonWidget::ICON_PATH_TYPE_ABSOLUTE /* Track gives us absolute paths */);
|
||||
@ -215,7 +214,7 @@ void GPInfoDialog::onEnterPressedInternal()
|
||||
ModalDialog::dismiss();
|
||||
// Disable accidentally unlocking of a challenge
|
||||
PlayerManager::getCurrentPlayer()->setCurrentChallenge("");
|
||||
race_manager->startGP(grand_prix_manager->getGrandPrix(gp_id), false, false);
|
||||
race_manager->startGP(m_gp, false, false);
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
@ -225,9 +224,8 @@ GUIEngine::EventPropagation GPInfoDialog::processEvent(const std::string& eventS
|
||||
if (eventSource == "start")
|
||||
{
|
||||
// Save GP identifier, since dismiss will delete this object.
|
||||
std::string gp_id = m_gp_ident;
|
||||
ModalDialog::dismiss();
|
||||
race_manager->startGP(grand_prix_manager->getGrandPrix(gp_id), false, false);
|
||||
race_manager->startGP(m_gp, false, false);
|
||||
return GUIEngine::EVENT_BLOCK;
|
||||
}
|
||||
if (eventSource == "continue")
|
||||
|
@ -33,7 +33,7 @@ namespace GUIEngine
|
||||
*/
|
||||
class GPInfoDialog : public GUIEngine::ModalDialog
|
||||
{
|
||||
protected: // Needed for randomGPInfoDialog
|
||||
protected: // Necessary for randomGPInfoDialog
|
||||
std::string m_gp_ident;
|
||||
GUIEngine::IconButtonWidget* m_screenshot_widget;
|
||||
float m_curr_time;
|
||||
@ -46,7 +46,7 @@ public:
|
||||
* Creates a modal dialog with given percentage of screen width and height
|
||||
* atm only used in track_screen.cpp
|
||||
*/
|
||||
GPInfoDialog() : ModalDialog(PERCENT_WIDTH, PERCENT_HEIGHT) {} // FIXME: This line's only here for compiling
|
||||
GPInfoDialog() : ModalDialog(PERCENT_WIDTH, PERCENT_HEIGHT) {}
|
||||
GPInfoDialog(const std::string& gpIdent);
|
||||
virtual ~GPInfoDialog();
|
||||
|
||||
|
@ -30,9 +30,9 @@ using namespace GUIEngine;
|
||||
randomGPInfoDialog::randomGPInfoDialog()
|
||||
{
|
||||
// Defaults - loading selection from last time frrom a file would be better
|
||||
int m_number_of_tracks = 4;
|
||||
std::string m_track_group = "standart";
|
||||
bool m_use_reverse = true;
|
||||
m_number_of_tracks = 2;
|
||||
m_track_group = "nextgen";
|
||||
m_use_reverse = true;
|
||||
|
||||
doInit();
|
||||
m_curr_time = 0.0f;
|
||||
@ -41,9 +41,7 @@ randomGPInfoDialog::randomGPInfoDialog()
|
||||
const int y2 = m_area.getHeight()*6/7;
|
||||
|
||||
m_gp_ident = "random";
|
||||
|
||||
//const GrandPrixData* gp = grand_prix_manager->newRandomGP(m_number_of_tracks, m_track_group, m_use_reverse);
|
||||
m_gp = grand_prix_manager->getGrandPrix("1_penguinplayground");
|
||||
m_gp = new GrandPrixData(m_number_of_tracks, m_track_group, m_use_reverse);
|
||||
|
||||
// ---- GP Name
|
||||
core::rect< s32 > area_top(0, 0, m_area.getWidth(), y1);
|
||||
|
@ -25,11 +25,13 @@
|
||||
class randomGPInfoDialog : public GPInfoDialog
|
||||
{
|
||||
private:
|
||||
int m_number_of_laps;
|
||||
unsigned int m_number_of_tracks;
|
||||
std::string m_track_group;
|
||||
bool m_use_reverse;
|
||||
|
||||
public:
|
||||
randomGPInfoDialog();
|
||||
~randomGPInfoDialog() { delete m_gp; }
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@ -119,7 +119,6 @@ void TracksScreen::eventCallback(Widget* widget, const std::string& name,
|
||||
}
|
||||
else
|
||||
{
|
||||
std::cout << selection << std::endl;
|
||||
if (selection != "Random")
|
||||
new GPInfoDialog(selection);
|
||||
else
|
||||
|
Loading…
Reference in New Issue
Block a user