Added: Preliminary keyhandling code for linux
~g2k
This commit is contained in:
324
src/linux.cpp
324
src/linux.cpp
@@ -48,7 +48,7 @@ void ResizeGLScene(GLsizei width, GLsizei height)
|
|||||||
{
|
{
|
||||||
if(height == 0)
|
if(height == 0)
|
||||||
height = 1;
|
height = 1;
|
||||||
|
|
||||||
glViewport(0,0,width, height);
|
glViewport(0,0,width, height);
|
||||||
glMatrixMode(GL_PROJECTION);
|
glMatrixMode(GL_PROJECTION);
|
||||||
glLoadIdentity();
|
glLoadIdentity();
|
||||||
@@ -59,7 +59,7 @@ void ResizeGLScene(GLsizei width, GLsizei height)
|
|||||||
int DrawGLScene()
|
int DrawGLScene()
|
||||||
{
|
{
|
||||||
level.Render();
|
level.Render();
|
||||||
|
|
||||||
//Maybe this should be integrated into the Window class
|
//Maybe this should be integrated into the Window class
|
||||||
if(g_Screen.doubleBuffered)
|
if(g_Screen.doubleBuffered)
|
||||||
{
|
{
|
||||||
@@ -125,7 +125,7 @@ void KillGLWindow()
|
|||||||
glXDestroyContext(g_Screen.display, g_Screen.hRC);
|
glXDestroyContext(g_Screen.display, g_Screen.hRC);
|
||||||
g_Screen.hRC = NULL;
|
g_Screen.hRC = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(g_Screen.fullscreen)
|
if(g_Screen.fullscreen)
|
||||||
{
|
{
|
||||||
XF86VidModeSwitchToMode(g_Screen.display, g_Screen.screen, &g_Screen.vidMode);
|
XF86VidModeSwitchToMode(g_Screen.display, g_Screen.screen, &g_Screen.vidMode);
|
||||||
@@ -152,7 +152,7 @@ bool CreateGLWindow(string title, int width, int height, int bits, bool fullscre
|
|||||||
Atom wmDelete;
|
Atom wmDelete;
|
||||||
Window winDummy;
|
Window winDummy;
|
||||||
unsigned int borderDummy;
|
unsigned int borderDummy;
|
||||||
|
|
||||||
g_Screen.name = title;
|
g_Screen.name = title;
|
||||||
g_Screen.width = width;
|
g_Screen.width = width;
|
||||||
g_Screen.height = height;
|
g_Screen.height = height;
|
||||||
@@ -163,10 +163,10 @@ bool CreateGLWindow(string title, int width, int height, int bits, bool fullscre
|
|||||||
g_Screen.screen = DefaultScreen(g_Screen.display);
|
g_Screen.screen = DefaultScreen(g_Screen.display);
|
||||||
XF86VidModeQueryVersion(g_Screen.display, &vidModeMajorVersion, &vidModeMinorVersion);
|
XF86VidModeQueryVersion(g_Screen.display, &vidModeMajorVersion, &vidModeMinorVersion);
|
||||||
printf("XF86VidModeExtension-Version %d.%d\n", vidModeMajorVersion, vidModeMinorVersion);
|
printf("XF86VidModeExtension-Version %d.%d\n", vidModeMajorVersion, vidModeMinorVersion);
|
||||||
|
|
||||||
XF86VidModeGetAllModeLines(g_Screen.display, g_Screen.screen, &modeNum, &modes);
|
XF86VidModeGetAllModeLines(g_Screen.display, g_Screen.screen, &modeNum, &modes);
|
||||||
g_Screen.vidMode = *modes[0];
|
g_Screen.vidMode = *modes[0];
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
for(i=0; i<modeNum; i++)
|
for(i=0; i<modeNum; i++)
|
||||||
{
|
{
|
||||||
@@ -176,7 +176,7 @@ bool CreateGLWindow(string title, int width, int height, int bits, bool fullscre
|
|||||||
bestMode = i;
|
bestMode = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
vi = glXChooseVisual(g_Screen.display, g_Screen.screen, attrListDbl);
|
vi = glXChooseVisual(g_Screen.display, g_Screen.screen, attrListDbl);
|
||||||
if(vi == NULL)
|
if(vi == NULL)
|
||||||
{
|
{
|
||||||
@@ -189,21 +189,21 @@ bool CreateGLWindow(string title, int width, int height, int bits, bool fullscre
|
|||||||
g_Screen.doubleBuffered = true;
|
g_Screen.doubleBuffered = true;
|
||||||
printf("Got Doublebuffered Visual!\n");
|
printf("Got Doublebuffered Visual!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
glXQueryVersion(g_Screen.display, &glxMajorVersion, & glxMinorVersion);
|
glXQueryVersion(g_Screen.display, &glxMajorVersion, & glxMinorVersion);
|
||||||
printf("glX-Version %d.%d\n", glxMajorVersion, glxMinorVersion);
|
printf("glX-Version %d.%d\n", glxMajorVersion, glxMinorVersion);
|
||||||
|
|
||||||
g_Screen.hRC = glXCreateContext(g_Screen.display, vi, 0, GL_TRUE);
|
g_Screen.hRC = glXCreateContext(g_Screen.display, vi, 0, GL_TRUE);
|
||||||
cmap = XCreateColormap(g_Screen.display, RootWindow(g_Screen.display, vi->screen), vi->visual, AllocNone);
|
cmap = XCreateColormap(g_Screen.display, RootWindow(g_Screen.display, vi->screen), vi->visual, AllocNone);
|
||||||
g_Screen.attributes.colormap = cmap;
|
g_Screen.attributes.colormap = cmap;
|
||||||
g_Screen.attributes.border_pixel = 0;
|
g_Screen.attributes.border_pixel = 0;
|
||||||
|
|
||||||
if(g_Screen.fullscreen)
|
if(g_Screen.fullscreen)
|
||||||
{
|
{
|
||||||
XF86VidModeSwitchToMode(g_Screen.display, g_Screen.screen, modes[bestMode]);
|
XF86VidModeSwitchToMode(g_Screen.display, g_Screen.screen, modes[bestMode]);
|
||||||
XF86VidModeSetViewPort(g_Screen.display, g_Screen.screen, 0, 0);
|
XF86VidModeSetViewPort(g_Screen.display, g_Screen.screen, 0, 0);
|
||||||
XFree(modes);
|
XFree(modes);
|
||||||
|
|
||||||
g_Screen.attributes.override_redirect = true;
|
g_Screen.attributes.override_redirect = true;
|
||||||
g_Screen.attributes.event_mask = ExposureMask | KeyPressMask | ButtonPressMask | StructureNotifyMask;
|
g_Screen.attributes.event_mask = ExposureMask | KeyPressMask | ButtonPressMask | StructureNotifyMask;
|
||||||
g_Screen.window = XCreateWindow(g_Screen.display, RootWindow(g_Screen.display, vi->screen), 0, 0, width, height, 0, vi->depth, InputOutput, vi->visual, CWBorderPixel | CWColormap | CWEventMask | CWOverrideRedirect, &g_Screen.attributes);
|
g_Screen.window = XCreateWindow(g_Screen.display, RootWindow(g_Screen.display, vi->screen), 0, 0, width, height, 0, vi->depth, InputOutput, vi->visual, CWBorderPixel | CWColormap | CWEventMask | CWOverrideRedirect, &g_Screen.attributes);
|
||||||
@@ -221,7 +221,7 @@ bool CreateGLWindow(string title, int width, int height, int bits, bool fullscre
|
|||||||
XSetStandardProperties(g_Screen.display, g_Screen.window, title.c_str(), title.c_str(), None, NULL, 0, NULL);
|
XSetStandardProperties(g_Screen.display, g_Screen.window, title.c_str(), title.c_str(), None, NULL, 0, NULL);
|
||||||
XMapRaised(g_Screen.display, g_Screen.window);
|
XMapRaised(g_Screen.display, g_Screen.window);
|
||||||
}
|
}
|
||||||
|
|
||||||
glXMakeCurrent(g_Screen.display, g_Screen.window, g_Screen.hRC);
|
glXMakeCurrent(g_Screen.display, g_Screen.window, g_Screen.hRC);
|
||||||
unsigned int twidth, theight, depth;
|
unsigned int twidth, theight, depth;
|
||||||
XGetGeometry(g_Screen.display, g_Screen.window, &winDummy, &g_Screen.x, &g_Screen.y, &twidth, &theight, &borderDummy, &depth);
|
XGetGeometry(g_Screen.display, g_Screen.window, &winDummy, &g_Screen.x, &g_Screen.y, &twidth, &theight, &borderDummy, &depth);
|
||||||
@@ -286,46 +286,48 @@ int main(int argc, char** argv)
|
|||||||
XNextEvent(g_Screen.display, &event);
|
XNextEvent(g_Screen.display, &event);
|
||||||
switch(event.type)
|
switch(event.type)
|
||||||
{
|
{
|
||||||
case Expose:
|
case Expose:
|
||||||
if(event.xexpose.count != 0)
|
if(event.xexpose.count != 0)
|
||||||
{
|
{
|
||||||
break;
|
|
||||||
}
|
|
||||||
DrawGLScene();
|
|
||||||
break;
|
break;
|
||||||
case ConfigureNotify:
|
}
|
||||||
if((event.xconfigure.width != g_Screen.width) || (event.xconfigure.height != g_Screen.height))
|
DrawGLScene();
|
||||||
{
|
break;
|
||||||
g_Screen.width = event.xconfigure.width;
|
case ConfigureNotify:
|
||||||
g_Screen.height = event.xconfigure.height;
|
if((event.xconfigure.width != g_Screen.width) || (event.xconfigure.height != g_Screen.height))
|
||||||
printf("Resize event\n");
|
{
|
||||||
ResizeGLScene(event.xconfigure.width, event.xconfigure.height);
|
g_Screen.width = event.xconfigure.width;
|
||||||
}
|
g_Screen.height = event.xconfigure.height;
|
||||||
break;
|
printf("Resize event\n");
|
||||||
case ButtonPress:
|
ResizeGLScene(event.xconfigure.width, event.xconfigure.height);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case ButtonPress:
|
||||||
|
done = true;
|
||||||
|
break;
|
||||||
|
case KeyPress:
|
||||||
|
keys[TraslateKey(XLookupKeysym(&event.xkey, 0))] = true;
|
||||||
|
//Remove this later it shouldn't be needed
|
||||||
|
if(XLookupKeysym(&event.xkey, 0) == XK_Escape)
|
||||||
|
{
|
||||||
|
done = true;
|
||||||
|
}
|
||||||
|
if(XLookupKeysym(&event.xkey, 0) == XK_F1)
|
||||||
|
{
|
||||||
|
KillGLWindow();
|
||||||
|
g_Screen.fullscreen = !g_Screen.fullscreen;
|
||||||
|
CreateGLWindow("Blah Blah Blah", 640, 480, 24, g_Screen.fullscreen);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case ClientMessage:
|
||||||
|
if(*XGetAtomName(g_Screen.display, event.xclient.message_type) == *"WM_PROTOCOLS")
|
||||||
|
{
|
||||||
|
printf("Exiting sanely...\n");
|
||||||
done = true;
|
done = true;
|
||||||
break;
|
}
|
||||||
case KeyPress:
|
break;
|
||||||
if(XLookupKeysym(&event.xkey, 0) == XK_Escape)
|
default:
|
||||||
{
|
break;
|
||||||
done = true;
|
|
||||||
}
|
|
||||||
if(XLookupKeysym(&event.xkey, 0) == XK_F1)
|
|
||||||
{
|
|
||||||
KillGLWindow();
|
|
||||||
g_Screen.fullscreen = !g_Screen.fullscreen;
|
|
||||||
CreateGLWindow("Blah Blah Blah", 640, 480, 24, g_Screen.fullscreen);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case ClientMessage:
|
|
||||||
if(*XGetAtomName(g_Screen.display, event.xclient.message_type) == *"WM_PROTOCOLS")
|
|
||||||
{
|
|
||||||
printf("Exiting sanely...\n");
|
|
||||||
done = true;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
//End Equivalent of WNDPROC
|
//End Equivalent of WNDPROC
|
||||||
if(active)
|
if(active)
|
||||||
@@ -350,7 +352,7 @@ int main(int argc, char** argv)
|
|||||||
SetCursorPos(g_Screen.width/2, g_Screen.height/2);//Shit this may be windows specific
|
SetCursorPos(g_Screen.width/2, g_Screen.height/2);//Shit this may be windows specific
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
//Maybe some of these if not almost all should be moved into Level
|
//Maybe some of these if not almost all should be moved into Level
|
||||||
//////////
|
//////////
|
||||||
//Move Backward
|
//Move Backward
|
||||||
@@ -632,9 +634,9 @@ int main(int argc, char** argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DrawGLScene();
|
DrawGLScene();
|
||||||
|
|
||||||
if(keys[KEY_F1])
|
if(keys[KEY_F1])
|
||||||
{
|
{
|
||||||
keys[KEY_F1] = false;
|
keys[KEY_F1] = false;
|
||||||
@@ -652,4 +654,220 @@ int main(int argc, char** argv)
|
|||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//This should probably be moved into oa_input
|
||||||
|
usigned char TranslateKey(int keyCode)
|
||||||
|
{
|
||||||
|
switch (keyCode)
|
||||||
|
{
|
||||||
|
case XK_BackSpace:
|
||||||
|
return KEY_BACK;
|
||||||
|
case XK_Tab:
|
||||||
|
return KEY_TAB;
|
||||||
|
case XK_Return:
|
||||||
|
return KEY_RETURN;
|
||||||
|
case XK_Escape:
|
||||||
|
return KEY_ESCAPE;
|
||||||
|
case XK_Left:
|
||||||
|
return KEY_LEFT;
|
||||||
|
case XK_Right:
|
||||||
|
return KEY_RIGHT;
|
||||||
|
case XK_Up:
|
||||||
|
return KEY_UP;
|
||||||
|
case XK_Down:
|
||||||
|
return KEY_DOWN;
|
||||||
|
case XK_Home:
|
||||||
|
return KEY_HOME;
|
||||||
|
case XK_End:
|
||||||
|
return KEY_END;
|
||||||
|
case XK_Prior:
|
||||||
|
return KEY_PRIOR;
|
||||||
|
case XK_Next:
|
||||||
|
return KEY_NEXT;
|
||||||
|
case XK_Num_Lock:
|
||||||
|
return KEY_NUMLOCK;
|
||||||
|
case XK_KP_Enter:
|
||||||
|
return KEY_RETURN;
|
||||||
|
case XK_KP_Home:
|
||||||
|
return KEY_HOME;
|
||||||
|
case XK_KP_End:
|
||||||
|
return KEY_END;
|
||||||
|
case XK_KP_Prior:
|
||||||
|
return KEY_PRIOR;
|
||||||
|
case XK_KP_Next:
|
||||||
|
return KEY_NEXT;
|
||||||
|
case XK_KP_0:
|
||||||
|
return KEY_NUMPAD0;
|
||||||
|
case XK_KP_1:
|
||||||
|
return KEY_NUMPAD1;
|
||||||
|
case XK_KP_2:
|
||||||
|
return KEY_NUMPAD2;
|
||||||
|
case XK_KP_3;
|
||||||
|
return KEY_NUMPAD3;
|
||||||
|
case XK_KP_4:
|
||||||
|
return KEY_NUMPAD4;
|
||||||
|
case XK_KP_5:
|
||||||
|
return KEY_NUMPAD5;
|
||||||
|
case XK_KP_6:
|
||||||
|
return KEY_NUMPAD6;
|
||||||
|
case XK_KP_7:
|
||||||
|
return KEY_NUMPAD7;
|
||||||
|
case XK_KP_8:
|
||||||
|
return KEY_NUMPAD8;
|
||||||
|
case XK_KP_9:
|
||||||
|
return KEY_NUMPAD9;
|
||||||
|
case XK_KP_Multiply:
|
||||||
|
return KEY_MULTIPLY;
|
||||||
|
case XK_KP_Add:
|
||||||
|
return KEY_ADD;
|
||||||
|
case XK_KP_Subtract:
|
||||||
|
return KEY_SUBTRACT;
|
||||||
|
case XK_KP_Divide:
|
||||||
|
return KEY_DIVIDE;
|
||||||
|
case XK_F1:
|
||||||
|
return KEY_F1:
|
||||||
|
case XK_F2:
|
||||||
|
return KEY_F2:
|
||||||
|
case XK_F3;
|
||||||
|
return KEY_F3:
|
||||||
|
case XK_F4:
|
||||||
|
return KEY_F4:
|
||||||
|
case XK_F5:
|
||||||
|
return KEY_F5:
|
||||||
|
case XK_F6:
|
||||||
|
return KEY_F6:
|
||||||
|
case XK_F7:
|
||||||
|
return KEY_F7:
|
||||||
|
case XK_F8:
|
||||||
|
return KEY_F8:
|
||||||
|
case XK_F9:
|
||||||
|
return KEY_F9:
|
||||||
|
case XK_F10:
|
||||||
|
return KEY_F10:
|
||||||
|
case XK_F11:
|
||||||
|
return KEY_F11:
|
||||||
|
case XK_F12:
|
||||||
|
return KEY_F12:
|
||||||
|
case XK_Shift_L:
|
||||||
|
return KEY_SHIFT;
|
||||||
|
case XK_Shift_R:
|
||||||
|
return KEY_SHIFT;
|
||||||
|
case XK_Control_L:
|
||||||
|
return KEY_CONTROL;
|
||||||
|
case XK_Control_R:
|
||||||
|
return KEY_CONTROL;
|
||||||
|
case XK_Caps_Lock:
|
||||||
|
return KEY_CAPITAL;
|
||||||
|
case XK_Pause:
|
||||||
|
return KEY_PAUSE;
|
||||||
|
case XK_KP_Space:
|
||||||
|
return KEY_SPACE;
|
||||||
|
case XK_Insert:
|
||||||
|
return KEY_INSERT;
|
||||||
|
case XK_Delete:
|
||||||
|
return KEY_DELETE;
|
||||||
|
case XK_KP_Separator:
|
||||||
|
return KEY_SEPARATOR;
|
||||||
|
case XK_Scroll_Lock:
|
||||||
|
return KEY_SCROLL;
|
||||||
|
case XK_period:
|
||||||
|
return KEY_OEM_PERIOD;
|
||||||
|
case XK_plus:
|
||||||
|
return KEY_OEM_PLUS;
|
||||||
|
case XK_minus:
|
||||||
|
return KEY_OEM_MINUS;
|
||||||
|
case XK_comma:
|
||||||
|
return KEY_OEM_COMMA;
|
||||||
|
case XK_0:
|
||||||
|
return KEY_0;
|
||||||
|
case XK_1:
|
||||||
|
return KEY_1;
|
||||||
|
case XK_2:
|
||||||
|
return KEY_2;
|
||||||
|
case XK_3:
|
||||||
|
return KEY_3;
|
||||||
|
case XK_4:
|
||||||
|
return KEY_4;
|
||||||
|
case XK_5:
|
||||||
|
return KEY_5;
|
||||||
|
case XK_6:
|
||||||
|
return KEY_6;
|
||||||
|
case XK_7:
|
||||||
|
return KEY_7;
|
||||||
|
case XK_8:
|
||||||
|
return KEY_8;
|
||||||
|
case XK_9:
|
||||||
|
return KEY_9;
|
||||||
|
case XK_A:
|
||||||
|
return KEY_A;
|
||||||
|
case XK_B:
|
||||||
|
return KEY_B;
|
||||||
|
case XK_C:
|
||||||
|
return KEY_C;
|
||||||
|
case XK_D:
|
||||||
|
return KEY_D;
|
||||||
|
case XK_E:
|
||||||
|
return KEY_E;
|
||||||
|
case XK_F:
|
||||||
|
return KEY_F;
|
||||||
|
case XK_G:
|
||||||
|
return KEY_G;
|
||||||
|
case XK_H:
|
||||||
|
return KEY_H;
|
||||||
|
case XK_I:
|
||||||
|
return KEY_I;
|
||||||
|
case XK_J:
|
||||||
|
return KEY_J;
|
||||||
|
case XK_K:
|
||||||
|
return KEY_K;
|
||||||
|
case XK_L:
|
||||||
|
return KEY_L;
|
||||||
|
case XK_M:
|
||||||
|
return KEY_M;
|
||||||
|
case XK_N:
|
||||||
|
return KEY_N;
|
||||||
|
case XK_O:
|
||||||
|
return KEY_O;
|
||||||
|
case XK_P:
|
||||||
|
return KEY_P;
|
||||||
|
case XK_Q:
|
||||||
|
return KEY_Q;
|
||||||
|
case XK_R:
|
||||||
|
return KEY_R;
|
||||||
|
case XK_S:
|
||||||
|
return KEY_S;
|
||||||
|
case XK_T:
|
||||||
|
return KEY_T;
|
||||||
|
case XK_U:
|
||||||
|
return KEY_U;
|
||||||
|
case XK_V:
|
||||||
|
return KEY_V;
|
||||||
|
case XK_W:
|
||||||
|
return KEY_W;
|
||||||
|
case XK_X:
|
||||||
|
return KEY_X;
|
||||||
|
case XK_Y:
|
||||||
|
return KEY_Y;
|
||||||
|
case XK_Z:
|
||||||
|
return KEY_Z;
|
||||||
|
|
||||||
|
/*These keys definately still need to be accounted for
|
||||||
|
#define KEY_LBUTTON 1
|
||||||
|
#define KEY_RBUTTON 2
|
||||||
|
#define KEY_MBUTTON 3
|
||||||
|
#define KEY_LWIN 21
|
||||||
|
#define KEY_RWIN 22
|
||||||
|
#define KEY_APPS 23
|
||||||
|
#define KEY_OEM_1 53
|
||||||
|
#define KEY_OEM_2 54
|
||||||
|
#define KEY_OEM_3 55
|
||||||
|
#define KEY_OEM_4 56
|
||||||
|
#define KEY_OEM_5 57
|
||||||
|
#define KEY_OEM_6 58
|
||||||
|
#define KEY_OEM_7 59
|
||||||
|
*/
|
||||||
|
default:
|
||||||
|
return KEY_UNKNOWN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
Reference in New Issue
Block a user