2014-03-29 06:33:43 -04:00
|
|
|
//
|
|
|
|
// SuperTuxKart - a fun racing game with go-kart
|
|
|
|
// Copyright (C) 2013 Lionel Fuentes
|
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License
|
|
|
|
// as published by the Free Software Foundation; either version 3
|
|
|
|
// of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
#include "debug.hpp"
|
2014-10-02 18:58:28 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
#include "config/user_config.hpp"
|
|
|
|
#include "graphics/irr_driver.hpp"
|
|
|
|
#include "items/powerup_manager.hpp"
|
2014-02-27 16:21:33 -05:00
|
|
|
#include "items/attachment.hpp"
|
2014-10-02 18:58:28 -04:00
|
|
|
#include "karts/abstract_kart.hpp"
|
|
|
|
#include "karts/controller/controller.hpp"
|
2014-03-29 06:33:43 -04:00
|
|
|
#include "modes/world.hpp"
|
|
|
|
#include "physics/irr_debug_drawer.hpp"
|
|
|
|
#include "physics/physics.hpp"
|
|
|
|
#include "race/history.hpp"
|
|
|
|
#include "main_loop.hpp"
|
|
|
|
#include "replay/replay_recorder.hpp"
|
2014-04-23 19:03:23 -04:00
|
|
|
#include "states_screens/dialogs/debug_slider.hpp"
|
2014-10-02 18:58:28 -04:00
|
|
|
#include "utils/constants.hpp"
|
2014-03-29 06:33:43 -04:00
|
|
|
#include "utils/log.hpp"
|
|
|
|
#include "utils/profiler.hpp"
|
2014-10-02 18:58:28 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
#include <IGUIEnvironment.h>
|
|
|
|
#include <IGUIContextMenu.h>
|
2014-08-19 19:56:04 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
using namespace irr;
|
|
|
|
using namespace gui;
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
namespace Debug {
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-10-02 18:18:31 -04:00
|
|
|
/** This is to let mouse input events go through when the debug menu is
|
|
|
|
* visible, otherwise GUI events would be blocked while in a race...
|
|
|
|
*/
|
2014-03-29 06:33:43 -04:00
|
|
|
static bool g_debug_menu_visible = false;
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// Commands for the debug menu
|
|
|
|
enum DebugMenuCommand
|
|
|
|
{
|
|
|
|
//! graphics commands
|
|
|
|
DEBUG_GRAPHICS_RELOAD_SHADERS,
|
|
|
|
DEBUG_GRAPHICS_RESET,
|
|
|
|
DEBUG_GRAPHICS_WIREFRAME,
|
|
|
|
DEBUG_GRAPHICS_MIPMAP_VIZ,
|
|
|
|
DEBUG_GRAPHICS_NORMALS_VIZ,
|
|
|
|
DEBUG_GRAPHICS_SSAO_VIZ,
|
2014-05-21 15:44:34 -04:00
|
|
|
DEBUG_GRAPHICS_RSM_VIZ,
|
|
|
|
DEBUG_GRAPHICS_RH_VIZ,
|
|
|
|
DEBUG_GRAPHICS_GI_VIZ,
|
2014-03-29 06:33:43 -04:00
|
|
|
DEBUG_GRAPHICS_SHADOW_VIZ,
|
|
|
|
DEBUG_GRAPHICS_LIGHT_VIZ,
|
|
|
|
DEBUG_GRAPHICS_DISTORT_VIZ,
|
|
|
|
DEBUG_GRAPHICS_BULLET_1,
|
|
|
|
DEBUG_GRAPHICS_BULLET_2,
|
|
|
|
DEBUG_PROFILER,
|
|
|
|
DEBUG_PROFILER_GENERATE_REPORT,
|
|
|
|
DEBUG_FPS,
|
|
|
|
DEBUG_SAVE_REPLAY,
|
|
|
|
DEBUG_SAVE_HISTORY,
|
|
|
|
DEBUG_POWERUP_BOWLING,
|
|
|
|
DEBUG_POWERUP_BUBBLEGUM,
|
|
|
|
DEBUG_POWERUP_CAKE,
|
|
|
|
DEBUG_POWERUP_PARACHUTE,
|
|
|
|
DEBUG_POWERUP_PLUNGER,
|
|
|
|
DEBUG_POWERUP_RUBBERBALL,
|
|
|
|
DEBUG_POWERUP_SWATTER,
|
|
|
|
DEBUG_POWERUP_SWITCH,
|
|
|
|
DEBUG_POWERUP_ZIPPER,
|
|
|
|
DEBUG_POWERUP_NITRO,
|
2014-02-27 16:21:33 -05:00
|
|
|
DEBUG_ATTACHMENT_PARACHUTE,
|
|
|
|
DEBUG_ATTACHMENT_BOMB,
|
|
|
|
DEBUG_ATTACHMENT_ANVIL,
|
2014-03-29 06:33:43 -04:00
|
|
|
DEBUG_TOGGLE_GUI,
|
2014-04-28 19:55:30 -04:00
|
|
|
DEBUG_HIDE_KARTS,
|
2014-04-23 19:03:23 -04:00
|
|
|
DEBUG_THROTTLE_FPS,
|
2014-08-09 13:22:30 -04:00
|
|
|
DEBUG_VISUAL_VALUES,
|
2014-10-02 18:58:28 -04:00
|
|
|
DEBUG_PRINT_START_POS,
|
2014-10-02 18:18:31 -04:00
|
|
|
}; // DebugMenuCommand
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// Add powerup selected from debug menu for all player karts
|
|
|
|
void addPowerup(PowerupManager::PowerupType powerup)
|
|
|
|
{
|
|
|
|
World* world = World::getWorld();
|
2014-10-02 18:58:28 -04:00
|
|
|
if (!world) return;
|
2014-03-29 06:33:43 -04:00
|
|
|
for(unsigned int i = 0; i < race_manager->getNumLocalPlayers(); i++)
|
|
|
|
{
|
|
|
|
AbstractKart* kart = world->getLocalPlayerKart(i);
|
|
|
|
kart->setPowerup(powerup, 10000);
|
|
|
|
}
|
2014-10-02 18:18:31 -04:00
|
|
|
} // addPowerup
|
2014-02-27 16:21:33 -05:00
|
|
|
|
2014-10-02 18:18:31 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-02-27 16:21:33 -05:00
|
|
|
void addAttachment(Attachment::AttachmentType type)
|
|
|
|
{
|
2014-03-29 06:33:43 -04:00
|
|
|
World* world = World::getWorld();
|
2014-10-02 18:18:31 -04:00
|
|
|
if (world == NULL) return;
|
|
|
|
for (unsigned int i = 0; i < world->getNumKarts(); i++)
|
|
|
|
{
|
2014-03-29 06:33:43 -04:00
|
|
|
AbstractKart *kart = world->getKart(i);
|
2014-10-02 18:18:31 -04:00
|
|
|
if (!kart->getController()->isPlayerController())
|
|
|
|
continue;
|
|
|
|
if (type == Attachment::ATTACH_ANVIL)
|
|
|
|
{
|
|
|
|
kart->getAttachment()
|
|
|
|
->set(type, stk_config->m_anvil_time);
|
|
|
|
kart->adjustSpeed(stk_config->m_anvil_speed_factor);
|
|
|
|
kart->updateWeight();
|
2014-03-29 06:33:43 -04:00
|
|
|
}
|
2014-10-02 18:18:31 -04:00
|
|
|
else if (type == Attachment::ATTACH_PARACHUTE)
|
|
|
|
{
|
|
|
|
kart->getAttachment()
|
|
|
|
->set(type, stk_config->m_parachute_time);
|
2014-03-29 06:33:43 -04:00
|
|
|
}
|
2014-10-02 18:18:31 -04:00
|
|
|
else if (type == Attachment::ATTACH_BOMB)
|
|
|
|
{
|
|
|
|
kart->getAttachment()
|
|
|
|
->set(type, stk_config->m_bomb_time);
|
|
|
|
}
|
|
|
|
}
|
2014-02-27 16:21:33 -05:00
|
|
|
|
2014-10-02 18:18:31 -04:00
|
|
|
} // addAttachment
|
2014-02-27 16:21:33 -05:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// Debug menu handling
|
|
|
|
bool onEvent(const SEvent &event)
|
|
|
|
{
|
|
|
|
// Only activated in artist debug mode
|
|
|
|
if(!UserConfigParams::m_artist_debug_mode)
|
|
|
|
return true; // keep handling the events
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
if(event.EventType == EET_MOUSE_INPUT_EVENT)
|
|
|
|
{
|
|
|
|
// Create the menu (only one menu at a time)
|
2014-10-02 18:18:31 -04:00
|
|
|
if(event.MouseInput.Event == EMIE_RMOUSE_PRESSED_DOWN &&
|
|
|
|
!g_debug_menu_visible)
|
2014-03-29 06:33:43 -04:00
|
|
|
{
|
|
|
|
// root menu
|
|
|
|
gui::IGUIEnvironment* guienv = irr_driver->getGUI();
|
2014-10-02 18:18:31 -04:00
|
|
|
core::rect<s32> r(event.MouseInput.X, event.MouseInput.Y,
|
|
|
|
event.MouseInput.Y+100, event.MouseInput.Y+100);
|
|
|
|
IGUIContextMenu* mnu = guienv->addContextMenu(r, NULL);
|
2014-03-29 06:33:43 -04:00
|
|
|
int graphicsMenuIndex = mnu->addItem(L"Graphics >",-1,true,true);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
// graphics menu
|
|
|
|
IGUIContextMenu* sub = mnu->getSubMenu(graphicsMenuIndex);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
sub->addItem(L"Reload shaders", DEBUG_GRAPHICS_RELOAD_SHADERS );
|
|
|
|
sub->addItem(L"Wireframe", DEBUG_GRAPHICS_WIREFRAME );
|
|
|
|
sub->addItem(L"Mipmap viz", DEBUG_GRAPHICS_MIPMAP_VIZ );
|
|
|
|
sub->addItem(L"Normals viz", DEBUG_GRAPHICS_NORMALS_VIZ );
|
|
|
|
sub->addItem(L"SSAO viz", DEBUG_GRAPHICS_SSAO_VIZ );
|
2014-05-21 15:44:34 -04:00
|
|
|
sub->addItem(L"RSM viz", DEBUG_GRAPHICS_RSM_VIZ);
|
|
|
|
sub->addItem(L"RH viz", DEBUG_GRAPHICS_RH_VIZ);
|
|
|
|
sub->addItem(L"GI viz", DEBUG_GRAPHICS_GI_VIZ);
|
2014-03-29 06:33:43 -04:00
|
|
|
sub->addItem(L"Shadow viz", DEBUG_GRAPHICS_SHADOW_VIZ );
|
|
|
|
sub->addItem(L"Light viz", DEBUG_GRAPHICS_LIGHT_VIZ );
|
|
|
|
sub->addItem(L"Distort viz", DEBUG_GRAPHICS_DISTORT_VIZ );
|
|
|
|
sub->addItem(L"Physics debug", DEBUG_GRAPHICS_BULLET_1);
|
|
|
|
sub->addItem(L"Physics debug (no kart)", DEBUG_GRAPHICS_BULLET_2);
|
2014-10-02 18:18:31 -04:00
|
|
|
sub->addItem(L"Reset debug views", DEBUG_GRAPHICS_RESET );
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
mnu->addItem(L"Items >",-1,true,true);
|
|
|
|
sub = mnu->getSubMenu(1);
|
|
|
|
sub->addItem(L"Basketball", DEBUG_POWERUP_RUBBERBALL );
|
|
|
|
sub->addItem(L"Bowling", DEBUG_POWERUP_BOWLING );
|
|
|
|
sub->addItem(L"Bubblegum", DEBUG_POWERUP_BUBBLEGUM );
|
|
|
|
sub->addItem(L"Cake", DEBUG_POWERUP_CAKE );
|
|
|
|
sub->addItem(L"Parachute", DEBUG_POWERUP_PARACHUTE );
|
|
|
|
sub->addItem(L"Plunger", DEBUG_POWERUP_PLUNGER );
|
|
|
|
sub->addItem(L"Swatter", DEBUG_POWERUP_SWATTER );
|
|
|
|
sub->addItem(L"Switch", DEBUG_POWERUP_SWITCH );
|
|
|
|
sub->addItem(L"Zipper", DEBUG_POWERUP_ZIPPER );
|
|
|
|
sub->addItem(L"Nitro", DEBUG_POWERUP_NITRO );
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-02-27 16:21:33 -05:00
|
|
|
mnu->addItem(L"Attachments >",-1,true, true);
|
|
|
|
sub = mnu->getSubMenu(2);
|
|
|
|
sub->addItem(L"Bomb", DEBUG_ATTACHMENT_BOMB);
|
|
|
|
sub->addItem(L"Anvil", DEBUG_ATTACHMENT_ANVIL);
|
|
|
|
sub->addItem(L"Parachute", DEBUG_ATTACHMENT_PARACHUTE);
|
|
|
|
|
2014-08-09 13:22:30 -04:00
|
|
|
mnu->addItem(L"Adjust values", DEBUG_VISUAL_VALUES);
|
2014-04-23 19:03:23 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
mnu->addItem(L"Profiler",DEBUG_PROFILER);
|
|
|
|
if (UserConfigParams::m_profiler_enabled)
|
2014-10-02 18:18:31 -04:00
|
|
|
mnu->addItem(L"Toggle capture profiler report",
|
|
|
|
DEBUG_PROFILER_GENERATE_REPORT);
|
2014-03-29 06:33:43 -04:00
|
|
|
mnu->addItem(L"Do not limit FPS", DEBUG_THROTTLE_FPS);
|
|
|
|
mnu->addItem(L"FPS",DEBUG_FPS);
|
|
|
|
mnu->addItem(L"Save replay", DEBUG_SAVE_REPLAY);
|
|
|
|
mnu->addItem(L"Save history", DEBUG_SAVE_HISTORY);
|
|
|
|
mnu->addItem(L"Toggle GUI", DEBUG_TOGGLE_GUI);
|
2014-04-28 19:55:30 -04:00
|
|
|
mnu->addItem(L"Hide karts", DEBUG_HIDE_KARTS);
|
2014-10-02 18:58:28 -04:00
|
|
|
mnu->addItem(L"Print position", DEBUG_PRINT_START_POS);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
g_debug_menu_visible = true;
|
|
|
|
irr_driver->showPointer();
|
|
|
|
}
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-10-02 18:18:31 -04:00
|
|
|
// Let Irrlicht handle the event while the menu is visible.
|
|
|
|
// Otherwise in a race the GUI events won't be generated
|
2014-03-29 06:33:43 -04:00
|
|
|
if(g_debug_menu_visible)
|
|
|
|
return false;
|
|
|
|
}
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
if (event.EventType == EET_GUI_EVENT)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (event.GUIEvent.Caller != NULL &&
|
|
|
|
event.GUIEvent.Caller->getType() == EGUIET_CONTEXT_MENU )
|
2014-03-29 06:33:43 -04:00
|
|
|
{
|
|
|
|
IGUIContextMenu *menu = (IGUIContextMenu*)event.GUIEvent.Caller;
|
|
|
|
s32 cmdID = menu->getItemCommandId(menu->getSelectedItem());
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
if(event.GUIEvent.EventType == EGET_ELEMENT_CLOSED)
|
|
|
|
{
|
|
|
|
g_debug_menu_visible = false;
|
|
|
|
}
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
if (event.GUIEvent.EventType == gui::EGET_MENU_ITEM_SELECTED)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
World *world = World::getWorld();
|
|
|
|
Physics *physics = world ? world->getPhysics() : NULL;
|
2014-03-29 06:33:43 -04:00
|
|
|
if(cmdID == DEBUG_GRAPHICS_RELOAD_SHADERS)
|
|
|
|
{
|
|
|
|
Log::info("Debug", "Reloading shaders...");
|
|
|
|
irr_driver->updateShaders();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_RESET)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_WIREFRAME)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleWireframe();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_MIPMAP_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleMipVisualization();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_NORMALS_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleNormals();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_SSAO_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleSSAOViz();
|
|
|
|
}
|
2014-05-21 15:44:34 -04:00
|
|
|
else if (cmdID == DEBUG_GRAPHICS_RSM_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-06-04 09:10:20 -04:00
|
|
|
|
2014-05-21 15:44:34 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleRSM();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_RH_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-06-04 09:10:20 -04:00
|
|
|
|
2014-05-21 15:44:34 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleRH();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_GI_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-06-04 09:10:20 -04:00
|
|
|
|
2014-05-21 15:44:34 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleGI();
|
|
|
|
}
|
2014-03-29 06:33:43 -04:00
|
|
|
else if (cmdID == DEBUG_GRAPHICS_SHADOW_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleShadowViz();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_LIGHT_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleLightViz();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_DISTORT_VIZ)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (physics)
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NONE);
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
irr_driver->resetDebugModes();
|
|
|
|
irr_driver->toggleDistortViz();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_BULLET_1)
|
|
|
|
{
|
|
|
|
irr_driver->resetDebugModes();
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-10-02 18:18:31 -04:00
|
|
|
if (!world) return false;
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_KARTS_PHYSICS);
|
2014-03-29 06:33:43 -04:00
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_GRAPHICS_BULLET_2)
|
|
|
|
{
|
|
|
|
irr_driver->resetDebugModes();
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-10-02 18:18:31 -04:00
|
|
|
if (!world) return false;
|
|
|
|
Physics *physics = world->getPhysics();
|
|
|
|
physics->setDebugMode(IrrDebugDrawer::DM_NO_KARTS_GRAPHICS);
|
2014-03-29 06:33:43 -04:00
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_PROFILER)
|
|
|
|
{
|
|
|
|
UserConfigParams::m_profiler_enabled =
|
|
|
|
!UserConfigParams::m_profiler_enabled;
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_PROFILER_GENERATE_REPORT)
|
|
|
|
{
|
|
|
|
profiler.setCaptureReport(!profiler.getCaptureReport());
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_THROTTLE_FPS)
|
|
|
|
{
|
|
|
|
main_loop->setThrottleFPS(false);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_FPS)
|
|
|
|
{
|
|
|
|
UserConfigParams::m_display_fps =
|
|
|
|
!UserConfigParams::m_display_fps;
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_SAVE_REPLAY)
|
|
|
|
{
|
|
|
|
ReplayRecorder::get()->Save();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_SAVE_HISTORY)
|
|
|
|
{
|
|
|
|
history->Save();
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_BOWLING)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_BOWLING);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_BUBBLEGUM)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_BUBBLEGUM);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_CAKE)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_CAKE);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_PARACHUTE)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_PARACHUTE);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_PLUNGER)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_PLUNGER);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_RUBBERBALL)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_RUBBERBALL);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_SWATTER)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_SWATTER);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_SWITCH)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_SWITCH);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_ZIPPER)
|
|
|
|
{
|
|
|
|
addPowerup(PowerupManager::POWERUP_ZIPPER);
|
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_POWERUP_NITRO)
|
|
|
|
{
|
2014-10-02 18:18:31 -04:00
|
|
|
if (!world) return false;
|
|
|
|
const unsigned int num_local_players =
|
|
|
|
race_manager->getNumLocalPlayers();
|
|
|
|
for(unsigned int i = 0; i < num_local_players; i++)
|
2014-03-29 06:33:43 -04:00
|
|
|
{
|
|
|
|
AbstractKart* kart = world->getLocalPlayerKart(i);
|
|
|
|
kart->setEnergy(100.0f);
|
|
|
|
}
|
|
|
|
}
|
2014-02-27 16:21:33 -05:00
|
|
|
else if (cmdID == DEBUG_ATTACHMENT_ANVIL)
|
|
|
|
{
|
2014-04-23 19:03:23 -04:00
|
|
|
addAttachment(Attachment::ATTACH_ANVIL);
|
2014-02-27 16:21:33 -05:00
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_ATTACHMENT_BOMB)
|
|
|
|
{
|
2014-04-23 19:03:23 -04:00
|
|
|
addAttachment(Attachment::ATTACH_BOMB);
|
2014-02-27 16:21:33 -05:00
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_ATTACHMENT_PARACHUTE)
|
|
|
|
{
|
2014-04-23 19:03:23 -04:00
|
|
|
addAttachment(Attachment::ATTACH_PARACHUTE);
|
2014-02-27 16:21:33 -05:00
|
|
|
}
|
2014-03-29 06:33:43 -04:00
|
|
|
else if (cmdID == DEBUG_TOGGLE_GUI)
|
|
|
|
{
|
2014-10-02 18:58:28 -04:00
|
|
|
if (!world) return false;
|
2014-03-29 06:33:43 -04:00
|
|
|
RaceGUIBase* gui = world->getRaceGUI();
|
|
|
|
if (gui != NULL) gui->m_enabled = !gui->m_enabled;
|
2014-04-28 19:55:30 -04:00
|
|
|
}
|
|
|
|
else if (cmdID == DEBUG_HIDE_KARTS)
|
|
|
|
{
|
2014-10-02 18:58:28 -04:00
|
|
|
if (!world) return false;
|
2014-10-08 07:49:32 -04:00
|
|
|
for (unsigned int n = 0; n<world->getNumKarts(); n++)
|
2014-03-29 06:33:43 -04:00
|
|
|
{
|
|
|
|
AbstractKart* kart = world->getKart(n);
|
|
|
|
if (kart->getController()->isPlayerController())
|
2014-04-28 19:55:30 -04:00
|
|
|
kart->getNode()->setVisible(false);
|
2014-03-29 06:33:43 -04:00
|
|
|
}
|
|
|
|
}
|
2014-10-02 18:58:28 -04:00
|
|
|
else if (cmdID == DEBUG_PRINT_START_POS)
|
|
|
|
{
|
|
|
|
if(!world) return false;
|
|
|
|
for(unsigned int i=0; i<world->getNumKarts(); i++)
|
|
|
|
{
|
|
|
|
AbstractKart *kart = world->getKart(i);
|
|
|
|
Log::warn(kart->getIdent().c_str(),
|
2014-10-03 02:48:47 -04:00
|
|
|
"<start position=\"%d\" x=\"%f\" y=\"%f\" z=\"%f\" h=\"%f\"/>",
|
2014-10-02 18:58:28 -04:00
|
|
|
i, kart->getXYZ().getX(), kart->getXYZ().getY(),
|
|
|
|
kart->getXYZ().getZ(),kart->getHeading()*RAD_TO_DEGREE
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2014-08-09 13:22:30 -04:00
|
|
|
else if (cmdID == DEBUG_VISUAL_VALUES)
|
2014-04-23 19:03:23 -04:00
|
|
|
{
|
2014-08-19 20:02:34 -04:00
|
|
|
#if !defined(__APPLE__)
|
2014-08-09 13:22:30 -04:00
|
|
|
DebugSliderDialog *dsd = new DebugSliderDialog();
|
2014-10-02 18:18:31 -04:00
|
|
|
dsd->setSliderHook( "red_slider", 0, 255,
|
|
|
|
[](){ return int(irr_driver->getAmbientLight().r * 255.f); },
|
2014-08-08 19:10:19 -04:00
|
|
|
[](int v){
|
2014-08-08 19:30:36 -04:00
|
|
|
video::SColorf ambient = irr_driver->getAmbientLight();
|
2014-08-22 16:21:46 -04:00
|
|
|
ambient.setColorComponentValue(0, v / 255.f);
|
2014-08-08 19:10:19 -04:00
|
|
|
irr_driver->setAmbientLight(ambient); }
|
|
|
|
);
|
2014-10-02 18:18:31 -04:00
|
|
|
dsd->setSliderHook("green_slider", 0, 255,
|
|
|
|
[](){ return int(irr_driver->getAmbientLight().g * 255.f); },
|
2014-08-08 19:10:19 -04:00
|
|
|
[](int v){
|
2014-08-09 13:22:30 -04:00
|
|
|
video::SColorf ambient = irr_driver->getAmbientLight();
|
2014-08-22 16:21:46 -04:00
|
|
|
ambient.setColorComponentValue(1, v / 255.f);
|
2014-08-09 13:22:30 -04:00
|
|
|
irr_driver->setAmbientLight(ambient); }
|
|
|
|
);
|
2014-10-02 18:18:31 -04:00
|
|
|
dsd->setSliderHook("blue_slider", 0, 255,
|
|
|
|
[](){ return int(irr_driver->getAmbientLight().b * 255.f); },
|
2014-08-08 19:10:19 -04:00
|
|
|
[](int v){
|
2014-08-08 19:30:36 -04:00
|
|
|
video::SColorf ambient = irr_driver->getAmbientLight();
|
2014-08-22 16:21:46 -04:00
|
|
|
ambient.setColorComponentValue(2, v / 255.f);
|
2014-08-09 13:22:30 -04:00
|
|
|
irr_driver->setAmbientLight(ambient); }
|
|
|
|
);
|
2014-10-02 18:18:31 -04:00
|
|
|
dsd->setSliderHook("ssao_radius", 0, 100,
|
|
|
|
[](){ return int(irr_driver->getSSAORadius() * 10.f); },
|
2014-08-22 16:21:46 -04:00
|
|
|
[](int v){irr_driver->setSSAORadius(v / 10.f); }
|
2014-08-09 13:22:30 -04:00
|
|
|
);
|
2014-10-02 18:18:31 -04:00
|
|
|
dsd->setSliderHook("ssao_k", 0, 100,
|
|
|
|
[](){ return int(irr_driver->getSSAOK() * 10.f); },
|
2014-08-22 16:21:46 -04:00
|
|
|
[](int v){irr_driver->setSSAOK(v / 10.f); }
|
2014-08-09 13:22:30 -04:00
|
|
|
);
|
2014-10-02 18:18:31 -04:00
|
|
|
dsd->setSliderHook("ssao_sigma", 0, 100,
|
|
|
|
[](){ return int(irr_driver->getSSAOSigma() * 10.f); },
|
2014-08-22 16:21:46 -04:00
|
|
|
[](int v){irr_driver->setSSAOSigma(v / 10.f); }
|
2014-08-08 19:10:19 -04:00
|
|
|
);
|
2014-08-19 20:02:34 -04:00
|
|
|
#endif
|
2014-04-23 19:03:23 -04:00
|
|
|
}
|
2014-03-29 06:33:43 -04:00
|
|
|
}
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
return false; // event has been handled
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true; // continue event handling
|
2014-10-02 18:18:31 -04:00
|
|
|
} // onEvent
|
2014-05-23 22:00:25 -04:00
|
|
|
|
2014-10-02 18:18:31 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Returns if the debug menu is visible.
|
|
|
|
*/
|
2014-03-29 06:33:43 -04:00
|
|
|
bool isOpen()
|
|
|
|
{
|
|
|
|
return g_debug_menu_visible;
|
2014-10-02 18:18:31 -04:00
|
|
|
} // isOpen
|
|
|
|
|
|
|
|
} // namespace Debug
|