Work on associating a player to its device in the kart selection screen
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/branches/irrlicht@3732 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
f987fff348
commit
0e890dc5cc
@ -49,12 +49,16 @@ namespace StateManager
|
|||||||
|
|
||||||
class PlayerKartWidget : public Widget
|
class PlayerKartWidget : public Widget
|
||||||
{
|
{
|
||||||
|
ActivePlayer* m_associatedPlayer;
|
||||||
public:
|
public:
|
||||||
LabelWidget* playerIDLabel;
|
LabelWidget* playerIDLabel;
|
||||||
SpinnerWidget* playerName;
|
SpinnerWidget* playerName;
|
||||||
ModelViewWidget* modelView;
|
ModelViewWidget* modelView;
|
||||||
LabelWidget* kartName;
|
LabelWidget* kartName;
|
||||||
|
|
||||||
|
int playerID;
|
||||||
|
std::string spinnerID;
|
||||||
|
|
||||||
int player_id_x, player_id_y, player_id_w, player_id_h;
|
int player_id_x, player_id_y, player_id_w, player_id_h;
|
||||||
int player_name_x, player_name_y, player_name_w, player_name_h;
|
int player_name_x, player_name_y, player_name_w, player_name_h;
|
||||||
int model_x, model_y, model_w, model_h;
|
int model_x, model_y, model_w, model_h;
|
||||||
@ -62,8 +66,12 @@ namespace StateManager
|
|||||||
|
|
||||||
int target_x, target_y, target_w, target_h;
|
int target_x, target_y, target_w, target_h;
|
||||||
|
|
||||||
PlayerKartWidget(Widget* area, const int playerID) : Widget()
|
PlayerKartWidget(ActivePlayer* associatedPlayer, Widget* area, const int playerID) : Widget()
|
||||||
{
|
{
|
||||||
|
m_associatedPlayer = associatedPlayer;
|
||||||
|
|
||||||
|
this->playerID = playerID;
|
||||||
|
|
||||||
// FIXME : if a player removes itself, all IDs need to be updated
|
// FIXME : if a player removes itself, all IDs need to be updated
|
||||||
this->m_properties[PROP_ID] = StringUtils::insert_values("@p%i", playerID);
|
this->m_properties[PROP_ID] = StringUtils::insert_values("@p%i", playerID);
|
||||||
|
|
||||||
@ -90,14 +98,18 @@ namespace StateManager
|
|||||||
playerName->w = player_name_w;
|
playerName->w = player_name_w;
|
||||||
playerName->h = player_name_h;
|
playerName->h = player_name_h;
|
||||||
|
|
||||||
|
spinnerID = StringUtils::insert_values("@p%i_spinner", playerID);
|
||||||
|
|
||||||
const int playerAmount = UserConfigParams::m_player.size();
|
const int playerAmount = UserConfigParams::m_player.size();
|
||||||
playerName->m_properties[PROP_MIN_VALUE] = "0";
|
playerName->m_properties[PROP_MIN_VALUE] = "0";
|
||||||
playerName->m_properties[PROP_MAX_VALUE] = (playerAmount-1);
|
playerName->m_properties[PROP_MAX_VALUE] = (playerAmount-1);
|
||||||
playerName->m_properties[PROP_ID] = StringUtils::insert_values("@p%i_spinner", playerID);
|
playerName->m_properties[PROP_ID] = spinnerID;
|
||||||
//playerName->setParent(this);
|
//playerName->setParent(this);
|
||||||
m_children.push_back(playerName);
|
m_children.push_back(playerName);
|
||||||
|
|
||||||
|
|
||||||
|
playerName->m_event_handler = this;
|
||||||
|
|
||||||
modelView = new ModelViewWidget();
|
modelView = new ModelViewWidget();
|
||||||
|
|
||||||
modelView->x = model_x;
|
modelView->x = model_x;
|
||||||
@ -227,6 +239,35 @@ namespace StateManager
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virtual bool transmitEvent(Widget* w, std::string& originator)
|
||||||
|
{
|
||||||
|
if (w->m_event_handler != NULL && w->m_event_handler != this)
|
||||||
|
{
|
||||||
|
if (!w->m_event_handler->transmitEvent(w, originator)) return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
Widget* topmost = w;
|
||||||
|
/* Find topmost parent. Stop looping if a widget event handler's is itself, to not fall
|
||||||
|
in an infinite loop (this can happen e.g. in checkboxes, where they need to be
|
||||||
|
notified of clicks onto themselves so they can toggle their state. )
|
||||||
|
*/
|
||||||
|
while(topmost->m_event_handler != NULL && topmost->m_event_handler != topmost)
|
||||||
|
{
|
||||||
|
topmost = topmost->m_event_handler;
|
||||||
|
|
||||||
|
std::string name = topmost->m_properties[PROP_ID];
|
||||||
|
|
||||||
|
if (name == spinnerID)
|
||||||
|
{
|
||||||
|
m_associatedPlayer->setPlayer( UserConfigParams::m_player.get(playerName->getValue()) );
|
||||||
|
return false; // do not continue propagating the event
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return true; // continue propagating the event
|
||||||
|
}
|
||||||
|
|
||||||
void setSize(const int x, const int y, const int w, const int h)
|
void setSize(const int x, const int y, const int w, const int h)
|
||||||
{
|
{
|
||||||
this->x = x;
|
this->x = x;
|
||||||
@ -314,12 +355,16 @@ void firePressedOnNewDevice(InputDevice* device)
|
|||||||
Widget rightarea = *getCurrentScreen()->getWidget("playerskarts");
|
Widget rightarea = *getCurrentScreen()->getWidget("playerskarts");
|
||||||
rightarea.x = irr_driver->getFrameSize().Width;
|
rightarea.x = irr_driver->getFrameSize().Width;
|
||||||
|
|
||||||
|
ActivePlayer* aplayer = new ActivePlayer( UserConfigParams::m_player.get(0) );
|
||||||
|
|
||||||
// FIXME : player ID needs to be synced with active player list
|
// FIXME : player ID needs to be synced with active player list
|
||||||
PlayerKartWidget* newPlayer = new PlayerKartWidget(&rightarea, g_player_karts.size());
|
PlayerKartWidget* newPlayer = new PlayerKartWidget(aplayer, &rightarea, g_player_karts.size());
|
||||||
getCurrentScreen()->manualAddWidget(newPlayer);
|
getCurrentScreen()->manualAddWidget(newPlayer);
|
||||||
g_player_karts.push_back(newPlayer);
|
g_player_karts.push_back(newPlayer);
|
||||||
newPlayer->add();
|
newPlayer->add();
|
||||||
|
|
||||||
|
StateManager::addActivePlayer(aplayer);
|
||||||
|
|
||||||
const int amount = g_player_karts.size();
|
const int amount = g_player_karts.size();
|
||||||
|
|
||||||
Widget* fullarea = getCurrentScreen()->getWidget("playerskarts");
|
Widget* fullarea = getCurrentScreen()->getWidget("playerskarts");
|
||||||
@ -351,7 +396,6 @@ void setPlayer0Device(InputDevice* device)
|
|||||||
std::cout << "Player 0 is using a gamepad\n";
|
std::cout << "Player 0 is using a gamepad\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO : support more than 1 player
|
|
||||||
ActivePlayer* newPlayer = new ActivePlayer(UserConfigParams::m_player.get(0));
|
ActivePlayer* newPlayer = new ActivePlayer(UserConfigParams::m_player.get(0));
|
||||||
StateManager::addActivePlayer( newPlayer );
|
StateManager::addActivePlayer( newPlayer );
|
||||||
newPlayer->setDevice(device);
|
newPlayer->setDevice(device);
|
||||||
@ -408,7 +452,7 @@ void menuEventKarts(Widget* widget, std::string& name)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PlayerKartWidget* playerKart1 = new PlayerKartWidget(area, 0 /* first player */);
|
PlayerKartWidget* playerKart1 = new PlayerKartWidget(StateManager::getActivePlayers().get(0), area, 0 /* first player */);
|
||||||
getCurrentScreen()->manualAddWidget(playerKart1);
|
getCurrentScreen()->manualAddWidget(playerKart1);
|
||||||
playerKart1->add();
|
playerKart1->add();
|
||||||
g_player_karts.push_back(playerKart1);
|
g_player_karts.push_back(playerKart1);
|
||||||
@ -426,6 +470,14 @@ void menuEventKarts(Widget* widget, std::string& name)
|
|||||||
RibbonGridWidget* w = getCurrentScreen()->getWidget<RibbonGridWidget>("karts");
|
RibbonGridWidget* w = getCurrentScreen()->getWidget<RibbonGridWidget>("karts");
|
||||||
assert( w != NULL );
|
assert( w != NULL );
|
||||||
|
|
||||||
|
ptr_vector< ActivePlayer, HOLD >& players = StateManager::getActivePlayers();
|
||||||
|
std::cout << "==========\n" << players.size() << " players :\n";
|
||||||
|
for(int n=0; n<players.size(); n++)
|
||||||
|
{
|
||||||
|
std::cout << " Player " << n << " is " << players[n].getPlayer()->getName() << std::endl;
|
||||||
|
}
|
||||||
|
std::cout << "==========\n";
|
||||||
|
|
||||||
g_player_karts.clearWithoutDeleting();
|
g_player_karts.clearWithoutDeleting();
|
||||||
race_manager->setLocalKartInfo(0, w->getSelectionIDString());
|
race_manager->setLocalKartInfo(0, w->getSelectionIDString());
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ namespace StateManager
|
|||||||
*/
|
*/
|
||||||
ptr_vector<ActivePlayer, HOLD> g_active_players;
|
ptr_vector<ActivePlayer, HOLD> g_active_players;
|
||||||
|
|
||||||
const ptr_vector<ActivePlayer, HOLD>& getActivePlayers()
|
ptr_vector<ActivePlayer, HOLD>& getActivePlayers()
|
||||||
{
|
{
|
||||||
return g_active_players;
|
return g_active_players;
|
||||||
}
|
}
|
||||||
|
@ -37,7 +37,7 @@ namespace StateManager
|
|||||||
bool isGameState();
|
bool isGameState();
|
||||||
void reshowTopMostMenu();
|
void reshowTopMostMenu();
|
||||||
|
|
||||||
const ptr_vector<ActivePlayer, HOLD>& getActivePlayers();
|
ptr_vector<ActivePlayer, HOLD>& getActivePlayers();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a new player to the list of active players. StateManager takes ownership of the object
|
* Adds a new player to the list of active players. StateManager takes ownership of the object
|
||||||
|
@ -99,10 +99,6 @@ namespace GUIEngine
|
|||||||
virtual bool rightPressed() { return false; }
|
virtual bool rightPressed() { return false; }
|
||||||
virtual bool leftPressed() { return false; }
|
virtual bool leftPressed() { return false; }
|
||||||
|
|
||||||
/** used when you set parents - see m_event_handler explainations below.
|
|
||||||
returns whether main event callback should be notified or not */
|
|
||||||
virtual bool transmitEvent(Widget* w, std::string& originator) { return true; }
|
|
||||||
|
|
||||||
/** used when you set eventSupervisors - see m_event_handler explainations below
|
/** used when you set eventSupervisors - see m_event_handler explainations below
|
||||||
called when one of a widget's children is hovered.
|
called when one of a widget's children is hovered.
|
||||||
Returns 'true' if main event handler should be notified of a change. */
|
Returns 'true' if main event handler should be notified of a change. */
|
||||||
@ -113,16 +109,6 @@ namespace GUIEngine
|
|||||||
|
|
||||||
void readCoords(Widget* parent=NULL);
|
void readCoords(Widget* parent=NULL);
|
||||||
|
|
||||||
/**
|
|
||||||
* This is set to NULL by default; set to something else in a widget to mean
|
|
||||||
* that events happening on this widget should not go straight into the
|
|
||||||
* event handler. Instead, they will first be passed to m_event_handler->transmitEvent,
|
|
||||||
* which is usually the parent analysing events from its children.
|
|
||||||
* This is especially useful with logical widgets built with more than
|
|
||||||
* one irrlicht widgets (e.g. Spinner, Ribbon)
|
|
||||||
*/
|
|
||||||
Widget* m_event_handler;
|
|
||||||
|
|
||||||
IGUIElement* m_parent;
|
IGUIElement* m_parent;
|
||||||
|
|
||||||
static bool convertToCoord(std::string& x, int* absolute, int* percentage);
|
static bool convertToCoord(std::string& x, int* absolute, int* percentage);
|
||||||
@ -133,6 +119,16 @@ namespace GUIEngine
|
|||||||
IGUIElement* m_element;
|
IGUIElement* m_element;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
/**
|
||||||
|
* This is set to NULL by default; set to something else in a widget to mean
|
||||||
|
* that events happening on this widget should not go straight into the
|
||||||
|
* event handler. Instead, they will first be passed to m_event_handler->transmitEvent,
|
||||||
|
* which is usually the parent analysing events from its children.
|
||||||
|
* This is especially useful with logical widgets built with more than
|
||||||
|
* one irrlicht widgets (e.g. Spinner, Ribbon)
|
||||||
|
*/
|
||||||
|
Widget* m_event_handler;
|
||||||
|
|
||||||
Widget();
|
Widget();
|
||||||
virtual ~Widget() {}
|
virtual ~Widget() {}
|
||||||
|
|
||||||
@ -144,6 +140,10 @@ namespace GUIEngine
|
|||||||
|
|
||||||
virtual void update(float delta) { }
|
virtual void update(float delta) { }
|
||||||
|
|
||||||
|
/** used when you set parents - see m_event_handler explainations below.
|
||||||
|
returns whether main event callback should be notified or not */
|
||||||
|
virtual bool transmitEvent(Widget* w, std::string& originator) { return true; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create and add the irrLicht widget(s) associated with this object.
|
* Create and add the irrLicht widget(s) associated with this object.
|
||||||
* Call after Widget was read from XML file and laid out.
|
* Call after Widget was read from XML file and laid out.
|
||||||
|
Loading…
Reference in New Issue
Block a user