maintaining an event queue for passing events to the engine thread from the main SDL thread
git-svn-id: svn://anubis/anaglym/trunk@79 99a6e188-d820-4881-8870-2d33a10e2619
This commit is contained in:
parent
a630609767
commit
917a226e0f
@ -28,7 +28,6 @@ Engine::Engine(const string & path)
|
|||||||
m_up[0] = 0;
|
m_up[0] = 0;
|
||||||
m_up[1] = 0;
|
m_up[1] = 0;
|
||||||
m_up[2] = 1;
|
m_up[2] = 1;
|
||||||
m_drawing = false;
|
|
||||||
m_autoPhysics = true;
|
m_autoPhysics = true;
|
||||||
|
|
||||||
size_t pos = path.find_last_of("\\/");
|
size_t pos = path.find_last_of("\\/");
|
||||||
@ -215,7 +214,6 @@ int Engine::setCamera(lua_State * L)
|
|||||||
|
|
||||||
void Engine::update()
|
void Engine::update()
|
||||||
{
|
{
|
||||||
m_drawing = true;
|
|
||||||
if (m_autoPhysics)
|
if (m_autoPhysics)
|
||||||
doPhysics();
|
doPhysics();
|
||||||
lua_getfield(m_luaState, LUA_GLOBALSINDEX, "update");
|
lua_getfield(m_luaState, LUA_GLOBALSINDEX, "update");
|
||||||
@ -229,7 +227,6 @@ void Engine::update()
|
|||||||
{
|
{
|
||||||
lua_pop(m_luaState, 1);
|
lua_pop(m_luaState, 1);
|
||||||
}
|
}
|
||||||
m_drawing = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Engine::doPhysics()
|
void Engine::doPhysics()
|
||||||
|
3
Engine.h
3
Engine.h
@ -60,6 +60,7 @@ class Engine
|
|||||||
void drawObjects();
|
void drawObjects();
|
||||||
void setAutoPhysics(bool autoPhysics) { m_autoPhysics = autoPhysics; }
|
void setAutoPhysics(bool autoPhysics) { m_autoPhysics = autoPhysics; }
|
||||||
bool getAutoPhysics() { return m_autoPhysics; }
|
bool getAutoPhysics() { return m_autoPhysics; }
|
||||||
|
void update();
|
||||||
|
|
||||||
/* lua services */
|
/* lua services */
|
||||||
int startFrame(lua_State * L);
|
int startFrame(lua_State * L);
|
||||||
@ -69,7 +70,6 @@ class Engine
|
|||||||
protected:
|
protected:
|
||||||
void registerLibraries();
|
void registerLibraries();
|
||||||
bool fileExists(const std::string & path);
|
bool fileExists(const std::string & path);
|
||||||
void update();
|
|
||||||
Object * createObject(bool is_static, GLuint display_list,
|
Object * createObject(bool is_static, GLuint display_list,
|
||||||
float scale = 1.0f)
|
float scale = 1.0f)
|
||||||
{
|
{
|
||||||
@ -85,7 +85,6 @@ class Engine
|
|||||||
GLdouble m_eye[3];
|
GLdouble m_eye[3];
|
||||||
GLdouble m_center[3];
|
GLdouble m_center[3];
|
||||||
GLdouble m_up[3];
|
GLdouble m_up[3];
|
||||||
bool m_drawing;
|
|
||||||
bool m_autoPhysics;
|
bool m_autoPhysics;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
62
anaglym.cc
62
anaglym.cc
@ -6,14 +6,29 @@
|
|||||||
#include <stdlib.h> /* exit() */
|
#include <stdlib.h> /* exit() */
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <queue>
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
enum EventType { EVENT_UPDATE };
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
EventType type;
|
||||||
|
} Event;
|
||||||
|
|
||||||
static void usage();
|
static void usage();
|
||||||
static void mainloop();
|
static void mainloop();
|
||||||
|
static void update();
|
||||||
|
static void addEvent(const Event & event);
|
||||||
static Uint32 updateCallback(Uint32 interval, void * param);
|
static Uint32 updateCallback(Uint32 interval, void * param);
|
||||||
|
|
||||||
static bool lastDrawCompleted;
|
static bool lastDrawCompleted;
|
||||||
|
static bool engine_running;
|
||||||
static SDL_Event userEvent;
|
static SDL_Event userEvent;
|
||||||
|
static SDL_cond * event_condition;
|
||||||
|
static SDL_mutex * event_mutex;
|
||||||
|
static SDL_mutex * event_queue_mutex;
|
||||||
|
static queue<Event> event_queue;
|
||||||
Uint32 g_ticks;
|
Uint32 g_ticks;
|
||||||
|
|
||||||
static void usage()
|
static void usage()
|
||||||
@ -22,6 +37,21 @@ static void usage()
|
|||||||
exit(42);
|
exit(42);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int engine_thread(void * param)
|
||||||
|
{
|
||||||
|
const char * program = (const char *) param;
|
||||||
|
if (g_engine->load(program))
|
||||||
|
{
|
||||||
|
for (;;)
|
||||||
|
{
|
||||||
|
SDL_mutexP(event_mutex);
|
||||||
|
SDL_CondWait(event_condition, event_mutex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
engine_running = false;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char * argv[])
|
int main(int argc, char * argv[])
|
||||||
{
|
{
|
||||||
const char * program = NULL;
|
const char * program = NULL;
|
||||||
@ -53,9 +83,13 @@ int main(int argc, char * argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
lastDrawCompleted = true;
|
lastDrawCompleted = true;
|
||||||
|
engine_running = true;
|
||||||
/* setup SDL update event */
|
/* setup SDL update event */
|
||||||
userEvent.type = SDL_USEREVENT;
|
userEvent.type = SDL_USEREVENT;
|
||||||
userEvent.user.code = 0;
|
userEvent.user.code = 0;
|
||||||
|
event_condition = SDL_CreateCond();
|
||||||
|
event_mutex = SDL_CreateMutex();
|
||||||
|
event_queue_mutex = SDL_CreateMutex();
|
||||||
|
|
||||||
Video video;
|
Video video;
|
||||||
#if 0
|
#if 0
|
||||||
@ -66,12 +100,12 @@ int main(int argc, char * argv[])
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
g_engine = new Engine(argv[0]);
|
g_engine = new Engine(argv[0]);
|
||||||
if (g_engine->load(program))
|
SDL_CreateThread(engine_thread, (void *) program);
|
||||||
{
|
|
||||||
mainloop();
|
|
||||||
}
|
|
||||||
delete g_engine;
|
|
||||||
|
|
||||||
|
mainloop();
|
||||||
|
|
||||||
|
SDL_DestroyCond(event_condition);
|
||||||
|
delete g_engine;
|
||||||
video.stop();
|
video.stop();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -94,6 +128,8 @@ static void mainloop()
|
|||||||
|
|
||||||
while (SDL_WaitEvent(&event))
|
while (SDL_WaitEvent(&event))
|
||||||
{
|
{
|
||||||
|
if (!engine_running)
|
||||||
|
goto RET;
|
||||||
switch (event.type)
|
switch (event.type)
|
||||||
{
|
{
|
||||||
case SDL_KEYDOWN:
|
case SDL_KEYDOWN:
|
||||||
@ -108,7 +144,7 @@ static void mainloop()
|
|||||||
case SDL_USEREVENT:
|
case SDL_USEREVENT:
|
||||||
if (event.user.code == 0)
|
if (event.user.code == 0)
|
||||||
{
|
{
|
||||||
/* TODO: update */
|
update();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -117,3 +153,17 @@ RET:
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void update()
|
||||||
|
{
|
||||||
|
Event update_event;
|
||||||
|
update_event.type = EVENT_UPDATE;
|
||||||
|
addEvent(update_event);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void addEvent(const Event & event)
|
||||||
|
{
|
||||||
|
SDL_mutexP(event_queue_mutex);
|
||||||
|
event_queue.push(event);
|
||||||
|
SDL_mutexV(event_queue_mutex);
|
||||||
|
SDL_CondSignal(event_condition);
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user