aboutsummaryrefslogtreecommitdiff
path: root/generic/tkZinc.h
diff options
context:
space:
mode:
authorlecoanet2004-04-30 14:39:52 +0000
committerlecoanet2004-04-30 14:39:52 +0000
commit0ac5b5d3c229786e9d73141d0d4a92010631802b (patch)
tree58ed8f927ac2d32e52127ffd24b0f736e7594a22 /generic/tkZinc.h
parentbfbccfc7914acd367c3508317bef79054e71beb1 (diff)
downloadtkzinc-0ac5b5d3c229786e9d73141d0d4a92010631802b.zip
tkzinc-0ac5b5d3c229786e9d73141d0d4a92010631802b.tar.gz
tkzinc-0ac5b5d3c229786e9d73141d0d4a92010631802b.tar.bz2
tkzinc-0ac5b5d3c229786e9d73141d0d4a92010631802b.tar.xz
Added new global variables extracted from the widget structure.
Diffstat (limited to 'generic/tkZinc.h')
-rw-r--r--generic/tkZinc.h33
1 files changed, 30 insertions, 3 deletions
diff --git a/generic/tkZinc.h b/generic/tkZinc.h
index 361fdd2..5ff75b1 100644
--- a/generic/tkZinc.h
+++ b/generic/tkZinc.h
@@ -34,6 +34,7 @@
#include "Item.h"
#include "List.h"
#include "MapInfo.h"
+#include "glu.h"
typedef struct _ZnTagSearch {
ZnWInfo *wi;
@@ -60,6 +61,25 @@ typedef struct _ZnTagSearch {
ZnList item_stack;
} ZnTagSearch;
+/*
+ * Structure used by the tesselator.
+ */
+typedef struct _ZnCombineData {
+ ZnReal v[2];
+ struct _ZnCombineData *next;
+} ZnCombineData;
+
+typedef struct _ZnTess {
+ GLUtesselator *tess;
+ ZnCombineData *combine_list;
+ int type;
+} ZnTess;
+
+ZnList ZnWorkPoints;
+ZnList ZnWorkXPoints;
+ZnList ZnWorkStrings;
+ZnTess ZnTesselator;
+
#ifdef GL
typedef struct _ZnGLContextEntry {
ZnGLContext context;
@@ -67,7 +87,10 @@ typedef struct _ZnGLContextEntry {
ZnReal max_line_width;
ZnReal max_point_width;
unsigned int max_tex_size;
-#ifdef WIN
+#ifdef _WIN32
+ PIXELFORMATDESCRIPTOR pfd;
+ int ipixel;
+ HWND hwnd; /* Temporary storage between MakeCurrent and Release */
HDC hdc;
#else
XVisualInfo *visual; /* Should these two be managed by screen ? */
@@ -77,8 +100,12 @@ typedef struct _ZnGLContextEntry {
} ZnGLContextEntry;
ZnGLContextEntry *ZnGetGLContext(Display *dpy);
-void ZnGLMakeCurrent(Display *dpy, Tk_Window win);
-void ZnGLSwapBuffers(Display *dpy, Tk_Window win);
+ZnGLContextEntry *ZnGLMakeCurrent(Display *dpy, Tk_Window win);
+#ifdef _WIN32
+void ZnGLReleaseContext(ZnGLContextEntry *ce);
+#else
+#define ZnGLReleaseContext(ce)
+#endif
#endif
int ZnParseCoordList(ZnWInfo *wi, Tcl_Obj *arg, ZnPoint **pts,