| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 | #include "gui/core/guiCanvas.h"#include "console/engineAPI.h"#include "gfx/gfxDebugEvent.h"#include "gfx/gl/gfxGLDevice.h"#ifndef TORQUE_BASIC_GPU_PROFILER   //#define TORQUE_BASIC_GPU_PROFILER#endifclass GLTimer{public:         void begin()   {      glBeginQuery(GL_TIME_ELAPSED, mQueryId);   }   void end()   {     glEndQuery(GL_TIME_ELAPSED);   }   F64 getTime()   {      GLuint64 time;      glGetQueryObjectui64v(mQueryId, GL_QUERY_RESULT, &time);      return static_cast<F64>(time)/1000000.0f;   }         class Data   {   public:            Data()  {}      void init()      {      }      void onBeginFrame()      {               }      void onEndFrame()      {               }   };   typedef Data DataType;    GLTimer(GFXDevice *device, Data &data) : mData(&data)   {      glGenQueries(1, &mQueryId);   }    GLTimer() : mName(NULL), mQueryId(0), mData(NULL)    {    }    GLTimer& operator=(const GLTimer &b)    {       mName = b.mName;       mQueryId = b.mQueryId;       return *this;    }    StringTableEntry mName; protected:   Data *mData;   GLuint mQueryId;   };#ifdef TORQUE_BASIC_GPU_PROFILER#include "gfx/gfxProfiler.h"GFXProfiler<GLTimer> gfxProfiler;DefineConsoleFunction(printGFXGLTimers, void,(), ,""){   gfxProfiler.printTimes();}#endifbool initGLProfiler(GFXDevice::GFXDeviceEventType ev){   if(ev != GFXDevice::deInit || GFX->getAdapterType() != OpenGL)              return true;   Con::evaluatef("GlobalActionMap.bindCmd(keyboard, \"alt F4\", \"printGFXGLTimers();\");");   return true;}void GFXGLDevice::enterDebugEvent(ColorI color, const char *name){#ifdef TORQUE_BASIC_GPU_PROFILER   gfxProfiler.enterDebugEvent(color, name);#endif}void GFXGLDevice::leaveDebugEvent(){#ifdef TORQUE_BASIC_GPU_PROFILER   gfxProfiler.leaveDebugEvent();#endif}void GFXGLDevice::setDebugMarker(ColorI color, const char *name){}#ifdef TORQUE_BASIC_GPU_PROFILERAFTER_MODULE_INIT(Sim){   // GFXGLDevice Profiler   GuiCanvas::getGuiCanvasFrameSignal().notify(&gfxProfiler, &GFXProfiler<GLTimer>::onEndFrame);   GFXDevice::getDeviceEventSignal().notify( &initGLProfiler );   }#endif
 |