mirror of
https://github.com/leozide/leocad
synced 2025-01-18 22:26:44 +01:00
Linux fixes.
This commit is contained in:
parent
719f88af51
commit
ce65a22250
3 changed files with 226 additions and 146 deletions
|
@ -1407,10 +1407,20 @@ bool preferencesdlg_getopts(LC_PREFERENCESDLG_STRUCT* s, LC_PREFERENCESDLG_OPTS*
|
||||||
if (GTK_TOGGLE_BUTTON(s->det_edges)->active) opts->nDetail |= LC_DET_BRICKEDGES;
|
if (GTK_TOGGLE_BUTTON(s->det_edges)->active) opts->nDetail |= LC_DET_BRICKEDGES;
|
||||||
if (GTK_TOGGLE_BUTTON(s->det_lighting)->active) opts->nDetail |= LC_DET_LIGHTING;
|
if (GTK_TOGGLE_BUTTON(s->det_lighting)->active) opts->nDetail |= LC_DET_LIGHTING;
|
||||||
if (GTK_TOGGLE_BUTTON(s->det_smooth)->active) opts->nDetail |= LC_DET_SMOOTH;
|
if (GTK_TOGGLE_BUTTON(s->det_smooth)->active) opts->nDetail |= LC_DET_SMOOTH;
|
||||||
if (GTK_TOGGLE_BUTTON(s->det_antialias)->active) opts->nDetail |= LC_DET_ANTIALIAS;
|
|
||||||
if (GTK_TOGGLE_BUTTON(s->det_fast)->active) opts->nDetail |= LC_DET_FAST;
|
if (GTK_TOGGLE_BUTTON(s->det_fast)->active) opts->nDetail |= LC_DET_FAST;
|
||||||
if (!read_float(s->det_width, &opts->fLineWidth, 0.5f, 5.0f))
|
if (!read_float(s->det_width, &opts->fLineWidth, 0.5f, 5.0f))
|
||||||
return false;
|
return false;
|
||||||
|
const gchar* AASamples = gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(s->det_antialias)->entry));
|
||||||
|
if (!strcmp(AASamples, "Off"))
|
||||||
|
opts->AASamples = 1;
|
||||||
|
else if (!strcmp(AASamples, "2x"))
|
||||||
|
opts->AASamples = 2;
|
||||||
|
else if (!strcmp(AASamples, "4x"))
|
||||||
|
opts->AASamples = 4;
|
||||||
|
else if (!strcmp(AASamples, "8x"))
|
||||||
|
opts->AASamples = 8;
|
||||||
|
else
|
||||||
|
opts->AASamples = 1;
|
||||||
|
|
||||||
opts->nSnap = 0;
|
opts->nSnap = 0;
|
||||||
if (GTK_TOGGLE_BUTTON(s->draw_grid)->active) opts->nSnap |= LC_DRAW_GRID;
|
if (GTK_TOGGLE_BUTTON(s->draw_grid)->active) opts->nSnap |= LC_DRAW_GRID;
|
||||||
|
@ -1466,6 +1476,7 @@ static void preferencesdlg_default(GtkWidget *widget, gpointer data)
|
||||||
Sys_ProfileSaveInt("Default", "Mouse", (int)Opts.nMouse);
|
Sys_ProfileSaveInt("Default", "Mouse", (int)Opts.nMouse);
|
||||||
Sys_ProfileSaveInt("Default", "Detail", Opts.nDetail);
|
Sys_ProfileSaveInt("Default", "Detail", Opts.nDetail);
|
||||||
Sys_ProfileSaveInt("Default", "Line", (int)(Opts.fLineWidth * 100));
|
Sys_ProfileSaveInt("Default", "Line", (int)(Opts.fLineWidth * 100));
|
||||||
|
Sys_ProfileSaveInt("Default", "AASamples", Opts.AASamples);
|
||||||
Sys_ProfileSaveInt("Default", "Snap", Opts.nSnap);
|
Sys_ProfileSaveInt("Default", "Snap", Opts.nSnap);
|
||||||
Sys_ProfileSaveInt("Default", "Angle", Opts.nAngleSnap);
|
Sys_ProfileSaveInt("Default", "Angle", Opts.nAngleSnap);
|
||||||
Sys_ProfileSaveInt("Default", "Grid", Opts.nGridSize);
|
Sys_ProfileSaveInt("Default", "Grid", Opts.nGridSize);
|
||||||
|
@ -1565,25 +1576,9 @@ int preferencesdlg_execute(void* param)
|
||||||
gtk_widget_show(s.det_edges);
|
gtk_widget_show(s.det_edges);
|
||||||
gtk_table_attach_defaults(GTK_TABLE(table), s.det_edges, 0, 1, 0, 1);
|
gtk_table_attach_defaults(GTK_TABLE(table), s.det_edges, 0, 1, 0, 1);
|
||||||
|
|
||||||
s.det_lighting = gtk_check_button_new_with_label("Lighting");
|
|
||||||
gtk_widget_show(s.det_lighting);
|
|
||||||
gtk_table_attach_defaults(GTK_TABLE(table), s.det_lighting, 0, 1, 1, 2);
|
|
||||||
|
|
||||||
s.det_smooth = gtk_check_button_new_with_label("Smooth shading");
|
|
||||||
gtk_widget_show(s.det_smooth);
|
|
||||||
gtk_table_attach_defaults(GTK_TABLE(table), s.det_smooth, 0, 1, 2, 3);
|
|
||||||
|
|
||||||
s.det_antialias = gtk_check_button_new_with_label("Anti-aliasing");
|
|
||||||
gtk_widget_show(s.det_antialias);
|
|
||||||
gtk_table_attach_defaults(GTK_TABLE(table), s.det_antialias, 0, 1, 3, 4);
|
|
||||||
|
|
||||||
s.det_fast = gtk_check_button_new_with_label("Fast rendering");
|
|
||||||
gtk_widget_show(s.det_fast);
|
|
||||||
gtk_table_attach_defaults(GTK_TABLE(table), s.det_fast, 0, 1, 4, 5);
|
|
||||||
|
|
||||||
hbox = gtk_hbox_new(FALSE, 5);
|
hbox = gtk_hbox_new(FALSE, 5);
|
||||||
gtk_widget_show(hbox);
|
gtk_widget_show(hbox);
|
||||||
gtk_table_attach_defaults(GTK_TABLE(table), hbox, 0, 1, 5, 6);
|
gtk_table_attach_defaults(GTK_TABLE(table), hbox, 0, 1, 1, 2);
|
||||||
|
|
||||||
label = gtk_label_new("Line width");
|
label = gtk_label_new("Line width");
|
||||||
gtk_widget_show(label);
|
gtk_widget_show(label);
|
||||||
|
@ -1595,6 +1590,40 @@ int preferencesdlg_execute(void* param)
|
||||||
gtk_box_pack_start(GTK_BOX(hbox), s.det_width, FALSE, FALSE, 0);
|
gtk_box_pack_start(GTK_BOX(hbox), s.det_width, FALSE, FALSE, 0);
|
||||||
gtk_entry_set_width_chars(GTK_ENTRY(s.det_width), 4);
|
gtk_entry_set_width_chars(GTK_ENTRY(s.det_width), 4);
|
||||||
|
|
||||||
|
hbox = gtk_hbox_new(FALSE, 5);
|
||||||
|
gtk_widget_show(hbox);
|
||||||
|
gtk_table_attach_defaults(GTK_TABLE(table), hbox, 0, 1, 2, 3);
|
||||||
|
|
||||||
|
label = gtk_label_new("Anti-aliasing");
|
||||||
|
gtk_widget_show(label);
|
||||||
|
gtk_box_pack_start(GTK_BOX(hbox), label, FALSE, TRUE, 0);
|
||||||
|
gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_LEFT);
|
||||||
|
|
||||||
|
s.det_antialias = gtk_combo_new();
|
||||||
|
gtk_widget_show(s.det_antialias);
|
||||||
|
gtk_box_pack_start(GTK_BOX(hbox), s.det_antialias, FALSE, FALSE, 0);
|
||||||
|
gtk_entry_set_width_chars(GTK_ENTRY(GTK_COMBO(s.det_antialias)->entry), 3);
|
||||||
|
|
||||||
|
GList* Samples = NULL;
|
||||||
|
Samples = g_list_append(Samples, (void*)"Off");
|
||||||
|
Samples = g_list_append(Samples, (void*)"2x");
|
||||||
|
Samples = g_list_append(Samples, (void*)"4x");
|
||||||
|
Samples = g_list_append(Samples, (void*)"8x");
|
||||||
|
gtk_combo_set_popdown_strings(GTK_COMBO(s.det_antialias), Samples);
|
||||||
|
g_list_free(Samples);
|
||||||
|
|
||||||
|
s.det_lighting = gtk_check_button_new_with_label("Lighting");
|
||||||
|
gtk_widget_show(s.det_lighting);
|
||||||
|
gtk_table_attach_defaults(GTK_TABLE(table), s.det_lighting, 0, 1, 3, 4);
|
||||||
|
|
||||||
|
s.det_smooth = gtk_check_button_new_with_label("Smooth shading");
|
||||||
|
gtk_widget_show(s.det_smooth);
|
||||||
|
gtk_table_attach_defaults(GTK_TABLE(table), s.det_smooth, 0, 1, 4, 5);
|
||||||
|
|
||||||
|
s.det_fast = gtk_check_button_new_with_label("Fast rendering");
|
||||||
|
gtk_widget_show(s.det_fast);
|
||||||
|
gtk_table_attach_defaults(GTK_TABLE(table), s.det_fast, 0, 1, 5, 6);
|
||||||
|
|
||||||
table = gtk_table_new(7, 2, TRUE);
|
table = gtk_table_new(7, 2, TRUE);
|
||||||
gtk_widget_show(table);
|
gtk_widget_show(table);
|
||||||
gtk_container_add(GTK_CONTAINER(notebook), table);
|
gtk_container_add(GTK_CONTAINER(notebook), table);
|
||||||
|
@ -1825,9 +1854,28 @@ int preferencesdlg_execute(void* param)
|
||||||
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_edges),(opts->nDetail & LC_DET_BRICKEDGES) ? TRUE : FALSE);
|
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_edges),(opts->nDetail & LC_DET_BRICKEDGES) ? TRUE : FALSE);
|
||||||
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_lighting),(opts->nDetail & LC_DET_LIGHTING) ? TRUE : FALSE);
|
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_lighting),(opts->nDetail & LC_DET_LIGHTING) ? TRUE : FALSE);
|
||||||
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_smooth),(opts->nDetail & LC_DET_SMOOTH) ? TRUE : FALSE);
|
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_smooth),(opts->nDetail & LC_DET_SMOOTH) ? TRUE : FALSE);
|
||||||
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_antialias),(opts->nDetail & LC_DET_ANTIALIAS) ? TRUE : FALSE);
|
|
||||||
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_fast),(opts->nDetail & LC_DET_FAST) ? TRUE : FALSE);
|
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.det_fast),(opts->nDetail & LC_DET_FAST) ? TRUE : FALSE);
|
||||||
write_float(s.det_width, opts->fLineWidth);
|
write_float(s.det_width, opts->fLineWidth);
|
||||||
|
switch (opts->AASamples)
|
||||||
|
{
|
||||||
|
default:
|
||||||
|
case 1:
|
||||||
|
gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(s.det_antialias)->entry), "Off");
|
||||||
|
gtk_list_select_item(GTK_LIST(GTK_COMBO(s.det_antialias)->list), 0);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(s.det_antialias)->entry), "2x");
|
||||||
|
gtk_list_select_item(GTK_LIST(GTK_COMBO(s.det_antialias)->list), 1);
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(s.det_antialias)->entry), "4x");
|
||||||
|
gtk_list_select_item(GTK_LIST(GTK_COMBO(s.det_antialias)->list), 2);
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(s.det_antialias)->entry), "8x");
|
||||||
|
gtk_list_select_item(GTK_LIST(GTK_COMBO(s.det_antialias)->list), 3);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.draw_grid), (opts->nSnap & LC_DRAW_GRID) ? TRUE : FALSE);
|
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.draw_grid), (opts->nSnap & LC_DRAW_GRID) ? TRUE : FALSE);
|
||||||
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.draw_axis), (opts->nSnap & LC_DRAW_AXIS) ? TRUE : FALSE);
|
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(s.draw_axis), (opts->nSnap & LC_DRAW_AXIS) ? TRUE : FALSE);
|
||||||
|
@ -1864,12 +1912,15 @@ int preferencesdlg_execute(void* param)
|
||||||
opts->nMouse = TempOpts.nMouse;
|
opts->nMouse = TempOpts.nMouse;
|
||||||
opts->nDetail = TempOpts.nDetail;
|
opts->nDetail = TempOpts.nDetail;
|
||||||
opts->fLineWidth = TempOpts.fLineWidth;
|
opts->fLineWidth = TempOpts.fLineWidth;
|
||||||
|
opts->AASamples = TempOpts.AASamples;
|
||||||
opts->nSnap = TempOpts.nSnap;
|
opts->nSnap = TempOpts.nSnap;
|
||||||
opts->nAngleSnap = TempOpts.nAngleSnap;
|
opts->nAngleSnap = TempOpts.nAngleSnap;
|
||||||
opts->nGridSize = TempOpts.nGridSize;
|
opts->nGridSize = TempOpts.nGridSize;
|
||||||
opts->nScene = TempOpts.nScene;
|
opts->nScene = TempOpts.nScene;
|
||||||
opts->fDensity = TempOpts.fDensity;
|
opts->fDensity = TempOpts.fDensity;
|
||||||
strcpy(opts->strBackground, TempOpts.strBackground);
|
strcpy(opts->strBackground, TempOpts.strBackground);
|
||||||
|
|
||||||
|
Sys_ProfileSaveInt("Default", "AASamples", opts->AASamples);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
ret = LC_CANCEL;
|
ret = LC_CANCEL;
|
||||||
|
|
|
@ -5,41 +5,45 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
#include <gdk/gdkx.h>
|
#include <gdk/gdkx.h>
|
||||||
|
#include "lc_global.h"
|
||||||
#include "opengl.h"
|
#include "opengl.h"
|
||||||
#include "glwindow.h"
|
#include "glwindow.h"
|
||||||
|
#include "defines.h"
|
||||||
|
#include "system.h"
|
||||||
|
|
||||||
typedef struct
|
struct GLWindowPrivate
|
||||||
{
|
{
|
||||||
GtkWidget *widget;
|
GtkWidget *widget;
|
||||||
Display* xdisplay;
|
Display* xdisplay;
|
||||||
GLXContext context;
|
GLXContext context;
|
||||||
} GLWindowPrivate;
|
bool Multisample;
|
||||||
|
};
|
||||||
|
|
||||||
// =============================================================================
|
// =============================================================================
|
||||||
// static functions
|
// static functions
|
||||||
|
|
||||||
static gint realize_event (GtkWidget *widget, gpointer data)
|
static gint realize_event(GtkWidget *widget, gpointer data)
|
||||||
{
|
{
|
||||||
GLWindow *wnd = (GLWindow*)data;
|
GLWindow *wnd = (GLWindow*)data;
|
||||||
|
|
||||||
wnd->OnInitialUpdate ();
|
wnd->OnInitialUpdate();
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint expose_event (GtkWidget *widget, GdkEventExpose *event, gpointer data)
|
static gint expose_event(GtkWidget *widget, GdkEventExpose *event, gpointer data)
|
||||||
{
|
{
|
||||||
GLWindow *wnd = (GLWindow*)data;
|
GLWindow *wnd = (GLWindow*)data;
|
||||||
|
|
||||||
if (event->count > 0)
|
if (event->count > 0)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
wnd->OnDraw ();
|
wnd->OnDraw();
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint button_press_event (GtkWidget *widget, GdkEventButton *event, gpointer data)
|
static gint button_press_event(GtkWidget *widget, GdkEventButton *event, gpointer data)
|
||||||
{
|
{
|
||||||
GLWindow *wnd = (GLWindow*)data;
|
GLWindow *wnd = (GLWindow*)data;
|
||||||
int x, y;
|
int x, y;
|
||||||
|
@ -131,144 +135,166 @@ static void destroy_event (GtkWidget *widget, gpointer data)
|
||||||
wnd->DestroyContext ();
|
wnd->DestroyContext ();
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
void GL_InitializeExtensions()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
// =============================================================================
|
// =============================================================================
|
||||||
// GLWindow class
|
// GLWindow class
|
||||||
|
|
||||||
GLWindow::GLWindow (GLWindow *share)
|
GLWindow::GLWindow(GLWindow *share)
|
||||||
{
|
{
|
||||||
m_pShare = share;
|
m_pShare = share;
|
||||||
m_pData = g_malloc (sizeof (GLWindowPrivate));
|
m_pData = g_malloc(sizeof(GLWindowPrivate));
|
||||||
|
memset(m_pData, 0, sizeof(GLWindowPrivate));
|
||||||
}
|
}
|
||||||
|
|
||||||
GLWindow::~GLWindow ()
|
GLWindow::~GLWindow()
|
||||||
{
|
{
|
||||||
DestroyContext ();
|
DestroyContext();
|
||||||
g_free (m_pData);
|
g_free(m_pData);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool GLWindow::CreateFromWindow (void *data)
|
bool GLWindow::CreateFromWindow (void *data)
|
||||||
{
|
{
|
||||||
int attrlist[] = { GLX_RGBA, GLX_DOUBLEBUFFER, GLX_DEPTH_SIZE, 16, 0 };
|
int attrlist[] = { GLX_RGBA, GLX_DOUBLEBUFFER, GLX_DEPTH_SIZE, 16, 0 };
|
||||||
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
||||||
Display *dpy = GDK_DISPLAY();
|
Display *dpy = GDK_DISPLAY();
|
||||||
GdkVisual *visual;
|
GdkVisual *visual;
|
||||||
XVisualInfo *vi;
|
XVisualInfo *vi = NULL;
|
||||||
|
|
||||||
// choose visual
|
// choose visual
|
||||||
visual = gdk_visual_get_system ();
|
visual = gdk_visual_get_system();
|
||||||
if (visual->depth < 16)
|
if (visual->depth < 16)
|
||||||
printf ("OpenGL fatal error: LeoCAD needs a display with at least 16 bit colors.\n");
|
printf("OpenGL fatal error: LeoCAD needs a display with at least 16 bit colors.\n");
|
||||||
|
|
||||||
if (dpy == NULL)
|
if (dpy == NULL)
|
||||||
{
|
{
|
||||||
printf ("OpenGL fatal error: Cannot get display.\n");
|
printf("OpenGL fatal error: Cannot get display.\n");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
prv->xdisplay = dpy;
|
prv->xdisplay = dpy;
|
||||||
|
|
||||||
vi = pfnglXChooseVisual (dpy, DefaultScreen (dpy), attrlist);
|
int AASamples = Sys_ProfileLoadInt("Default", "AASamples", 1);
|
||||||
if (vi == NULL)
|
|
||||||
{
|
|
||||||
printf ("OpenGL fatal error: glXChooseVisual failed.\n");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
visual = gdkx_visual_get (vi->visualid);
|
if (AASamples > 1)
|
||||||
if (visual == NULL)
|
{
|
||||||
{
|
int attrlistAA[] = { GLX_RGBA, GLX_DOUBLEBUFFER, GLX_DEPTH_SIZE, 16, GLX_SAMPLE_BUFFERS_ARB, 1, GLX_SAMPLES_ARB, AASamples, 0 };
|
||||||
printf ("OpenGL fatal error: Cannot get visual.\n");
|
vi = pfnglXChooseVisual(dpy, DefaultScreen(dpy), attrlistAA);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
gtk_widget_push_colormap (gdk_colormap_new (visual, TRUE));
|
if (vi)
|
||||||
gtk_widget_push_visual (visual);
|
prv->Multisample = true;
|
||||||
|
else
|
||||||
|
printf("OpenGL error: Could not find multisample visual.\n");
|
||||||
|
}
|
||||||
|
|
||||||
prv->widget = gtk_drawing_area_new ();
|
if (!vi)
|
||||||
gtk_widget_set_double_buffered(GTK_WIDGET(prv->widget), FALSE);
|
{
|
||||||
|
vi = pfnglXChooseVisual(dpy, DefaultScreen(dpy), attrlist);
|
||||||
|
if (vi == NULL)
|
||||||
|
{
|
||||||
|
printf("OpenGL fatal error: glXChooseVisual failed.\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (m_pShare == NULL)
|
visual = gdkx_visual_get(vi->visualid);
|
||||||
prv->context = pfnglXCreateContext (dpy, vi, NULL, True);
|
if (visual == NULL)
|
||||||
else
|
{
|
||||||
{
|
printf("OpenGL fatal error: Cannot get visual.\n");
|
||||||
GLWindowPrivate *share = (GLWindowPrivate*)m_pShare->m_pData;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
prv->context = pfnglXCreateContext (dpy, vi, share->context, True);
|
gtk_widget_push_colormap(gdk_colormap_new(visual, TRUE));
|
||||||
}
|
gtk_widget_push_visual(visual);
|
||||||
|
|
||||||
gtk_widget_pop_visual ();
|
prv->widget = gtk_drawing_area_new();
|
||||||
gtk_widget_pop_colormap ();
|
gtk_widget_set_double_buffered(GTK_WIDGET(prv->widget), FALSE);
|
||||||
|
|
||||||
XFree (vi);
|
if (m_pShare == NULL)
|
||||||
|
prv->context = pfnglXCreateContext(dpy, vi, NULL, True);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GLWindowPrivate *share = (GLWindowPrivate*)m_pShare->m_pData;
|
||||||
|
|
||||||
GTK_WIDGET_SET_FLAGS (prv->widget, GTK_CAN_FOCUS);
|
prv->context = pfnglXCreateContext(dpy, vi, share->context, True);
|
||||||
|
}
|
||||||
|
|
||||||
gtk_widget_set_events (GTK_WIDGET (prv->widget), GDK_EXPOSURE_MASK | GDK_BUTTON_PRESS_MASK |
|
gtk_widget_pop_visual();
|
||||||
GDK_BUTTON_RELEASE_MASK | GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK);
|
gtk_widget_pop_colormap();
|
||||||
|
|
||||||
// Connect signal handlers
|
XFree(vi);
|
||||||
gtk_signal_connect (GTK_OBJECT (prv->widget), "expose_event",
|
|
||||||
GTK_SIGNAL_FUNC (expose_event), this);
|
|
||||||
// gtk_signal_connect (GTK_OBJECT (prv->widget), "destroy",
|
|
||||||
// GTK_SIGNAL_FUNC (destroy_event), this);
|
|
||||||
gtk_signal_connect (GTK_OBJECT (prv->widget), "size_allocate",
|
|
||||||
GTK_SIGNAL_FUNC (size_allocate_event), this);
|
|
||||||
gtk_signal_connect (GTK_OBJECT (prv->widget), "motion_notify_event",
|
|
||||||
GTK_SIGNAL_FUNC (pointer_motion_event), this);
|
|
||||||
gtk_signal_connect (GTK_OBJECT (prv->widget), "button_press_event",
|
|
||||||
GTK_SIGNAL_FUNC (button_press_event), this);
|
|
||||||
gtk_signal_connect (GTK_OBJECT (prv->widget), "button_release_event",
|
|
||||||
GTK_SIGNAL_FUNC (button_release_event), this);
|
|
||||||
gtk_signal_connect (GTK_OBJECT (prv->widget), "realize",
|
|
||||||
GTK_SIGNAL_FUNC (realize_event), this);
|
|
||||||
|
|
||||||
*((GtkWidget**)data) = prv->widget;
|
GTK_WIDGET_SET_FLAGS(prv->widget, GTK_CAN_FOCUS);
|
||||||
|
|
||||||
return true;
|
gtk_widget_set_events(GTK_WIDGET(prv->widget), GDK_EXPOSURE_MASK | GDK_BUTTON_PRESS_MASK |
|
||||||
|
GDK_BUTTON_RELEASE_MASK | GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK);
|
||||||
|
|
||||||
|
// Connect signal handlers
|
||||||
|
gtk_signal_connect(GTK_OBJECT(prv->widget), "expose_event", GTK_SIGNAL_FUNC(expose_event), this);
|
||||||
|
// gtk_signal_connect(GTK_OBJECT(prv->widget), "destroy", GTK_SIGNAL_FUNC(destroy_event), this);
|
||||||
|
gtk_signal_connect(GTK_OBJECT(prv->widget), "size_allocate", GTK_SIGNAL_FUNC(size_allocate_event), this);
|
||||||
|
gtk_signal_connect(GTK_OBJECT(prv->widget), "motion_notify_event", GTK_SIGNAL_FUNC(pointer_motion_event), this);
|
||||||
|
gtk_signal_connect(GTK_OBJECT(prv->widget), "button_press_event", GTK_SIGNAL_FUNC(button_press_event), this);
|
||||||
|
gtk_signal_connect(GTK_OBJECT(prv->widget), "button_release_event", GTK_SIGNAL_FUNC(button_release_event), this);
|
||||||
|
gtk_signal_connect(GTK_OBJECT(prv->widget), "realize", GTK_SIGNAL_FUNC(realize_event), this);
|
||||||
|
|
||||||
|
*((GtkWidget**)data) = prv->widget;
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void GLWindow::DestroyContext ()
|
void GLWindow::DestroyContext()
|
||||||
|
{
|
||||||
|
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
||||||
|
|
||||||
|
if (prv->context == pfnglXGetCurrentContext())
|
||||||
|
pfnglXMakeCurrent(prv->xdisplay, None, NULL);
|
||||||
|
|
||||||
|
if (prv->context)
|
||||||
|
pfnglXDestroyContext(prv->xdisplay, prv->context);
|
||||||
|
|
||||||
|
prv->context = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void GLWindow::OnInitialUpdate()
|
||||||
|
{
|
||||||
|
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
||||||
|
|
||||||
|
MakeCurrent();
|
||||||
|
|
||||||
|
GL_InitializeSharedExtensions();
|
||||||
|
// GL_InitializeExtensions();
|
||||||
|
|
||||||
|
if (prv->Multisample)
|
||||||
|
glEnable(GL_MULTISAMPLE_ARB);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool GLWindow::MakeCurrent()
|
||||||
|
{
|
||||||
|
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
||||||
|
gboolean ret = false;
|
||||||
|
|
||||||
|
if (prv->context)
|
||||||
|
ret = pfnglXMakeCurrent(prv->xdisplay, GDK_WINDOW_XWINDOW(prv->widget->window), prv->context);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
void GLWindow::SwapBuffers()
|
||||||
|
{
|
||||||
|
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
||||||
|
|
||||||
|
if (prv->context)
|
||||||
|
pfnglXSwapBuffers(GDK_WINDOW_XDISPLAY(prv->widget->window), GDK_WINDOW_XWINDOW(prv->widget->window));
|
||||||
|
}
|
||||||
|
|
||||||
|
void GLWindow::Redraw(bool ForceRedraw)
|
||||||
{
|
{
|
||||||
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
||||||
|
|
||||||
if (prv->context == pfnglXGetCurrentContext ())
|
gtk_widget_draw(prv->widget, (GdkRectangle*)NULL);
|
||||||
pfnglXMakeCurrent (prv->xdisplay, None, NULL);
|
|
||||||
|
|
||||||
if (prv->context)
|
|
||||||
pfnglXDestroyContext (prv->xdisplay, prv->context);
|
|
||||||
|
|
||||||
prv->context = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
void GLWindow::OnInitialUpdate ()
|
|
||||||
{
|
|
||||||
MakeCurrent ();
|
|
||||||
GL_InitializeExtensions ();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool GLWindow::MakeCurrent ()
|
|
||||||
{
|
|
||||||
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
|
||||||
gboolean ret = false;
|
|
||||||
|
|
||||||
if (prv->context)
|
|
||||||
ret = pfnglXMakeCurrent (prv->xdisplay, GDK_WINDOW_XWINDOW (prv->widget->window), prv->context);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
void GLWindow::SwapBuffers ()
|
|
||||||
{
|
|
||||||
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
|
||||||
|
|
||||||
if (prv->context)
|
|
||||||
pfnglXSwapBuffers (GDK_WINDOW_XDISPLAY (prv->widget->window), GDK_WINDOW_XWINDOW (prv->widget->window));
|
|
||||||
}
|
|
||||||
|
|
||||||
void GLWindow::Redraw (bool ForceRedraw)
|
|
||||||
{
|
|
||||||
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
|
||||||
|
|
||||||
gtk_widget_draw (prv->widget, (GdkRectangle*)NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GLWindow::CaptureMouse()
|
void GLWindow::CaptureMouse()
|
||||||
|
@ -278,3 +304,4 @@ void GLWindow::CaptureMouse()
|
||||||
void GLWindow::ReleaseMouse()
|
void GLWindow::ReleaseMouse()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -407,9 +407,6 @@ bool GLWindow::CreateFromWindow(void* data)
|
||||||
wglShareLists(share->m_hrc, prv->m_hrc);
|
wglShareLists(share->m_hrc, prv->m_hrc);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prv->Multisample)
|
|
||||||
glEnable(GL_MULTISAMPLE_ARB);
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -491,7 +488,12 @@ void GLWindow::DestroyContext()
|
||||||
|
|
||||||
void GLWindow::OnInitialUpdate()
|
void GLWindow::OnInitialUpdate()
|
||||||
{
|
{
|
||||||
|
GLWindowPrivate *prv = (GLWindowPrivate*)m_pData;
|
||||||
|
|
||||||
MakeCurrent();
|
MakeCurrent();
|
||||||
|
|
||||||
|
if (prv->Multisample)
|
||||||
|
glEnable(GL_MULTISAMPLE_ARB);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool GLWindow::MakeCurrent()
|
bool GLWindow::MakeCurrent()
|
||||||
|
|
Loading…
Reference in a new issue