Extend funto's debug menu

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@14676 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
auria 2013-12-09 01:51:03 +00:00
parent 31c29c7a92
commit 55018ee089
7 changed files with 263 additions and 74 deletions

View File

@ -374,6 +374,17 @@ public:
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
inline bool isGLSL() const { return m_glsl; } inline bool isGLSL() const { return m_glsl; }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
void resetDebugModes()
{
m_wireframe = false;
m_mipviz = false;
m_normals = false;
m_ssaoviz = false;
m_shadowviz = false;
m_lightviz = false;
m_distortviz = false;
}
// ------------------------------------------------------------------------
void toggleWireframe() { m_wireframe = !m_wireframe; } void toggleWireframe() { m_wireframe = !m_wireframe; }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
void toggleMipVisualization() { m_mipviz = !m_mipviz; } void toggleMipVisualization() { m_mipviz = !m_mipviz; }

View File

@ -2194,6 +2194,8 @@ core::recti Skin::draw3DWindowBackground(IGUIElement *element,
void Skin::draw3DMenuPane (IGUIElement *element, const core::recti &rect, void Skin::draw3DMenuPane (IGUIElement *element, const core::recti &rect,
const core::recti *clip) const core::recti *clip)
{ {
SColor color = SColor(150, 255, 255, 255);
GUIEngine::getDriver()->draw2DRectangle(color, rect);
} // draw3DMenuPane } // draw3DMenuPane
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------

View File

@ -161,7 +161,7 @@ void InputManager::handleStaticAction(int key, int value)
if (value ==0 ) if (value ==0 )
irr_driver->requestScreenshot(); irr_driver->requestScreenshot();
break; break;
/*
case KEY_F1: case KEY_F1:
if (UserConfigParams::m_artist_debug_mode && world) if (UserConfigParams::m_artist_debug_mode && world)
{ {
@ -222,7 +222,7 @@ void InputManager::handleStaticAction(int key, int value)
kart->setPowerup(PowerupManager::POWERUP_ZIPPER, 10000); kart->setPowerup(PowerupManager::POWERUP_ZIPPER, 10000);
} }
break; break;
*/
case KEY_F8: case KEY_F8:
if (UserConfigParams::m_artist_debug_mode && value && world) if (UserConfigParams::m_artist_debug_mode && value && world)
{ {
@ -283,60 +283,6 @@ void InputManager::handleStaticAction(int key, int value)
UserConfigParams::m_display_fps = UserConfigParams::m_display_fps =
!UserConfigParams::m_display_fps; !UserConfigParams::m_display_fps;
break; break;
case KEY_KEY_P:
if (UserConfigParams::m_artist_debug_mode && value &&
control_is_pressed)
UserConfigParams::m_profiler_enabled =
!UserConfigParams::m_profiler_enabled;
break;
// Debug views
// These should be available in normal (non-artist) mode
// to enable easier bug reports (go there, press this key, screenshot)
// without requiring editing the UTF-32 config files (which is inconvenient).
case KEY_HOME:
if (value)
{
irr_driver->toggleWireframe();
}
break;
case KEY_END:
if (value)
{
irr_driver->toggleMipVisualization();
}
break;
case KEY_DELETE:
if (value)
{
irr_driver->toggleNormals();
}
break;
case KEY_NEXT: // pgdown
if (value)
{
irr_driver->toggleSSAOViz();
}
break;
case KEY_PRIOR: // pgup
if (value)
{
irr_driver->toggleLightViz();
}
break;
case KEY_INSERT:
if (value)
{
irr_driver->toggleShadowViz();
}
break;
case KEY_SCROLL:
if (value)
{
irr_driver->toggleDistortViz();
}
break;
default: default:
break; break;
} // switch } // switch

View File

@ -35,7 +35,13 @@ IrrDebugDrawer::IrrDebugDrawer()
void IrrDebugDrawer::nextDebugMode() void IrrDebugDrawer::nextDebugMode()
{ {
// Go to next debug mode. Note that debug mode 3 ( // Go to next debug mode. Note that debug mode 3 (
m_debug_mode = (DebugModeType) ((m_debug_mode+1) % 3); setDebugMode((DebugModeType) ((m_debug_mode+1) % 3));
}
// -----------------------------------------------------------------------------
void IrrDebugDrawer::setDebugMode(DebugModeType mode)
{
m_debug_mode = mode;
World *world = World::getWorld(); World *world = World::getWorld();
unsigned int num_karts = world->getNumKarts(); unsigned int num_karts = world->getNumKarts();
for(unsigned int i=0; i<num_karts; i++) for(unsigned int i=0; i<num_karts; i++)

View File

@ -28,6 +28,7 @@
*/ */
class IrrDebugDrawer : public btIDebugDraw class IrrDebugDrawer : public btIDebugDraw
{ {
public:
/** The drawing mode to use: /** The drawing mode to use:
* If bit 0 is set, draw the bullet collision shape of karts * If bit 0 is set, draw the bullet collision shape of karts
* If bit 1 is set, don't draw the kart graphics * If bit 1 is set, don't draw the kart graphics
@ -63,6 +64,7 @@ public:
/** Returns true if debug mode is enabled. */ /** Returns true if debug mode is enabled. */
bool debugEnabled() const {return m_debug_mode!=0;} bool debugEnabled() const {return m_debug_mode!=0;}
void nextDebugMode(); void nextDebugMode();
void setDebugMode(DebugModeType mode);
}; // IrrDebugDrawer }; // IrrDebugDrawer
#endif #endif

View File

@ -162,6 +162,7 @@ public:
/** Activates the next debug mode (or switches it off again). /** Activates the next debug mode (or switches it off again).
*/ */
void nextDebugMode () {m_debug_drawer->nextDebugMode(); } void nextDebugMode () {m_debug_drawer->nextDebugMode(); }
void setDebugMode(IrrDebugDrawer::DebugModeType mode) { m_debug_drawer->setDebugMode(mode); }
/** Returns true if the debug drawer is enabled. */ /** Returns true if the debug drawer is enabled. */
bool isDebug() const {return m_debug_drawer->debugEnabled(); } bool isDebug() const {return m_debug_drawer->debugEnabled(); }
virtual btScalar solveGroup(btCollisionObject** bodies, int numBodies, virtual btScalar solveGroup(btCollisionObject** bodies, int numBodies,

View File

@ -17,8 +17,15 @@
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include "debug.hpp" #include "debug.hpp"
#include "karts/abstract_kart.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "config/user_config.hpp" #include "config/user_config.hpp"
#include "items/powerup_manager.hpp"
#include "modes/world.hpp"
#include "physics/irr_debug_drawer.hpp"
#include "physics/physics.hpp"
#include "race/history.hpp"
#include "replay/replay_recorder.hpp"
#include "utils/log.hpp" #include "utils/log.hpp"
#include <IGUIEnvironment.h> #include <IGUIEnvironment.h>
#include <IGUIContextMenu.h> #include <IGUIContextMenu.h>
@ -39,6 +46,29 @@ enum DebugMenuCommand
{ {
//! graphics commands //! graphics commands
DEBUG_GRAPHICS_RELOAD_SHADERS, DEBUG_GRAPHICS_RELOAD_SHADERS,
DEBUG_GRAPHICS_RESET,
DEBUG_GRAPHICS_WIREFRAME,
DEBUG_GRAPHICS_MIPMAP_VIZ,
DEBUG_GRAPHICS_NORMALS_VIZ,
DEBUG_GRAPHICS_SSAO_VIZ,
DEBUG_GRAPHICS_SHADOW_VIZ,
DEBUG_GRAPHICS_LIGHT_VIZ,
DEBUG_GRAPHICS_DISTORT_VIZ,
DEBUG_GRAPHICS_BULLET_1,
DEBUG_GRAPHICS_BULLET_2,
DEBUG_PROFILER,
DEBUG_FPS,
DEBUG_SAVE_REPLAY,
DEBUG_SAVE_HISTORY,
DEBUG_POWERUP_BOWLING,
DEBUG_POWERUP_BUBBLEGUM,
DEBUG_POWERUP_CAKE,
DEBUG_POWERUP_PLUNGER,
DEBUG_POWERUP_RUBBERBALL,
DEBUG_POWERUP_SWATTER,
DEBUG_POWERUP_SWITCH,
DEBUG_POWERUP_ZIPPER,
DEBUG_POWERUP_NITRO
}; };
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
@ -55,15 +85,45 @@ bool onEvent(const SEvent &event)
if(event.MouseInput.Event == EMIE_RMOUSE_PRESSED_DOWN && !g_debug_menu_visible) if(event.MouseInput.Event == EMIE_RMOUSE_PRESSED_DOWN && !g_debug_menu_visible)
{ {
// root menu // root menu
gui::IGUIEnvironment* guienv = irr_driver->getGUI(); gui::IGUIEnvironment* guienv = irr_driver->getGUI();
IGUIContextMenu* mnu = guienv->addContextMenu( IGUIContextMenu* mnu = guienv->addContextMenu(
core::rect<s32>(event.MouseInput.X, event.MouseInput.Y, event.MouseInput.Y+100, event.MouseInput.Y+100),NULL); core::rect<s32>(event.MouseInput.X, event.MouseInput.Y, event.MouseInput.Y+100, event.MouseInput.Y+100),NULL);
mnu->addItem(L"Graphics >",-1,true,true); int graphicsMenuIndex = mnu->addItem(L"Graphics >",-1,true,true);
// graphics menu // graphics menu
IGUIContextMenu* sub = mnu->getSubMenu(0); IGUIContextMenu* sub = mnu->getSubMenu(graphicsMenuIndex);
sub->addItem(L"Reload shaders", DEBUG_GRAPHICS_RELOAD_SHADERS ); sub->addItem(L"Reload shaders", DEBUG_GRAPHICS_RELOAD_SHADERS );
sub->addItem(L"Reset debug views", DEBUG_GRAPHICS_RESET );
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 );
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);
int itemsMenuIndex = 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"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 );
mnu->addItem(L"Profiler",DEBUG_PROFILER);
mnu->addItem(L"FPS",DEBUG_FPS);
mnu->addItem(L"Save replay", DEBUG_SAVE_REPLAY);
mnu->addItem(L"Save history", DEBUG_SAVE_HISTORY);
g_debug_menu_visible = true; g_debug_menu_visible = true;
g_was_pointer_shown = irr_driver->isPointerShown(); g_was_pointer_shown = irr_driver->isPointerShown();
@ -77,29 +137,190 @@ bool onEvent(const SEvent &event)
if (event.EventType == EET_GUI_EVENT) if (event.EventType == EET_GUI_EVENT)
{ {
if (event.GUIEvent.Caller != NULL) if (event.GUIEvent.Caller != NULL && event.GUIEvent.Caller->getType() == EGUIET_CONTEXT_MENU )
{ {
if(event.GUIEvent.Caller->getType() == EGUIET_CONTEXT_MENU) IGUIContextMenu *menu = (IGUIContextMenu*)event.GUIEvent.Caller;
s32 cmdID = menu->getItemCommandId(menu->getSelectedItem());
if(event.GUIEvent.EventType == EGET_ELEMENT_CLOSED)
{ {
IGUIContextMenu *menu = (IGUIContextMenu*)event.GUIEvent.Caller; g_debug_menu_visible = false;
s32 cmdID = menu->getItemCommandId(menu->getSelectedItem()); if(g_was_pointer_shown)
irr_driver->showPointer();
if(event.GUIEvent.EventType == EGET_ELEMENT_CLOSED) else
{ irr_driver->hidePointer();
g_debug_menu_visible = false; }
if(g_was_pointer_shown)
irr_driver->showPointer();
else
irr_driver->hidePointer();
}
if (event.GUIEvent.EventType == gui::EGET_MENU_ITEM_SELECTED)
{
if(cmdID == DEBUG_GRAPHICS_RELOAD_SHADERS) if(cmdID == DEBUG_GRAPHICS_RELOAD_SHADERS)
{ {
Log::info("Debug", "Reloading shaders...\n"); Log::info("Debug", "Reloading shaders...\n");
irr_driver->updateShaders(); irr_driver->updateShaders();
} }
return false; // event has been treated else if (cmdID == DEBUG_GRAPHICS_RESET)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
}
else if (cmdID == DEBUG_GRAPHICS_WIREFRAME)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
irr_driver->toggleWireframe();
}
else if (cmdID == DEBUG_GRAPHICS_MIPMAP_VIZ)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
irr_driver->toggleMipVisualization();
}
else if (cmdID == DEBUG_GRAPHICS_NORMALS_VIZ)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
irr_driver->toggleNormals();
}
else if (cmdID == DEBUG_GRAPHICS_SSAO_VIZ)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
irr_driver->toggleSSAOViz();
}
else if (cmdID == DEBUG_GRAPHICS_SHADOW_VIZ)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
irr_driver->toggleShadowViz();
}
else if (cmdID == DEBUG_GRAPHICS_LIGHT_VIZ)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
irr_driver->toggleLightViz();
}
else if (cmdID == DEBUG_GRAPHICS_DISTORT_VIZ)
{
World* world = World::getWorld();
if (world != NULL) world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NONE);
irr_driver->resetDebugModes();
irr_driver->toggleDistortViz();
}
else if (cmdID == DEBUG_GRAPHICS_BULLET_1)
{
irr_driver->resetDebugModes();
World* world = World::getWorld();
if (world == NULL) return false;
world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_KARTS_PHYSICS);
}
else if (cmdID == DEBUG_GRAPHICS_BULLET_2)
{
irr_driver->resetDebugModes();
World* world = World::getWorld();
if (world == NULL) return false;
world->getPhysics()->setDebugMode(IrrDebugDrawer::DM_NO_KARTS_GRAPHICS);
}
else if (cmdID == DEBUG_PROFILER)
{
UserConfigParams::m_profiler_enabled =
!UserConfigParams::m_profiler_enabled;
}
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)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_BOWLING, 10000);
}
else if (cmdID == DEBUG_POWERUP_BUBBLEGUM)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_BUBBLEGUM, 10000);
}
else if (cmdID == DEBUG_POWERUP_CAKE)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_CAKE, 10000);
}
else if (cmdID == DEBUG_POWERUP_PLUNGER)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_PLUNGER, 10000);
}
else if (cmdID == DEBUG_POWERUP_RUBBERBALL)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_RUBBERBALL, 10000);
}
else if (cmdID == DEBUG_POWERUP_SWATTER)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_SWATTER, 10000);
}
else if (cmdID == DEBUG_POWERUP_SWITCH)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_SWITCH, 10000);
}
else if (cmdID == DEBUG_POWERUP_ZIPPER)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setPowerup(PowerupManager::POWERUP_ZIPPER, 10000);
}
else if (cmdID == DEBUG_POWERUP_NITRO)
{
World* world = World::getWorld();
if (world == NULL) return false;
AbstractKart* kart = world->getLocalPlayerKart(0);
kart->setEnergy(100.0f);
}
} }
return false; // event has been handled
} }
} }
return true; // continue event handling return true; // continue event handling