2017-08-07 22:22:11 +02:00
|
|
|
|
/* grTOGL2.c -
|
|
|
|
|
|
*
|
|
|
|
|
|
* Copyright 2003 Open Circuit Design, Inc., for MultiGiG Ltd.
|
|
|
|
|
|
*
|
|
|
|
|
|
* This file contains additional functions to manipulate an X
|
|
|
|
|
|
* color display. Included here are rectangle drawing and color map
|
|
|
|
|
|
* loading.
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
char *getenv();
|
|
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
/*
|
2017-08-07 22:22:11 +02:00
|
|
|
|
#include <GL/gl.h>
|
|
|
|
|
|
#include <GL/glx.h>
|
2017-08-08 21:00:19 +02:00
|
|
|
|
*/
|
2017-08-30 22:34:42 +02:00
|
|
|
|
#include <cairo/cairo-xlib.h>
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
|
|
|
|
|
#include "tcltk/tclmagic.h"
|
|
|
|
|
|
#include "utils/magic.h"
|
|
|
|
|
|
#include "textio/textio.h"
|
|
|
|
|
|
#include "utils/geometry.h"
|
|
|
|
|
|
#include "graphics/glyphs.h"
|
|
|
|
|
|
#include "windows/windows.h"
|
|
|
|
|
|
#include "graphics/graphics.h"
|
|
|
|
|
|
#include "graphics/graphicsInt.h"
|
2017-08-08 21:00:19 +02:00
|
|
|
|
//#include "grTOGLInt.h"
|
|
|
|
|
|
#include "grTCairoInt.h"
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-09-05 05:20:22 +02:00
|
|
|
|
#include "textio/txcommands.h"
|
|
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
extern char *DBWStyleType;
|
2017-08-30 22:34:42 +02:00
|
|
|
|
//extern GLXContext grXcontext;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
extern Display *grXdpy;
|
|
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
extern cairo_t *grCairoContext;
|
2017-09-05 05:20:22 +02:00
|
|
|
|
extern cairo_surface_t *grCairoSurface;
|
|
|
|
|
|
extern cairo_pattern_t *currentStipple;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------
|
|
|
|
|
|
* GrOGLSetCMap --
|
|
|
|
|
|
*
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* OpenGL uses RGB values as read from the colormap file,
|
|
|
|
|
|
* directly, so there is no need to install colors into a
|
|
|
|
|
|
* colormap. Therefore, this is a null routine.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Results: None.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
|
|
|
|
|
* Side Effects: None.
|
|
|
|
|
|
*
|
|
|
|
|
|
*---------------------------------------------------------
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
void
|
2017-08-18 20:15:12 +02:00
|
|
|
|
GrTCairoSetCMap ()
|
2017-08-07 22:22:11 +02:00
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
Rect grtcairoLines[TCAIRO_BATCH_SIZE];
|
|
|
|
|
|
int grtcairoNbLines = 0;
|
|
|
|
|
|
TCairoRect grtcairoRects[TCAIRO_BATCH_SIZE];
|
|
|
|
|
|
int grtcairoNbRects = 0;
|
|
|
|
|
|
Rect grtcairoDiagonal[TCAIRO_BATCH_SIZE];
|
|
|
|
|
|
int grtcairoNbDiagonal = 0;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------
|
|
|
|
|
|
* grtoglDrawLines:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* This routine draws a batch of lines.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Results: None.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
|
|
|
|
|
* Side Effects:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Draw a bunch of lines.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*---------------------------------------------------------
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
void
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoDrawLines(lines, nb)
|
|
|
|
|
|
Rect lines[];
|
|
|
|
|
|
int nb;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
{
|
2017-08-08 21:00:19 +02:00
|
|
|
|
/*
|
|
|
|
|
|
#ifdef OGL_SERVER_SIDE_ONLY
|
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
|
|
glBegin(GL_LINES);
|
|
|
|
|
|
for (i = 0; i < nb; i++)
|
|
|
|
|
|
{
|
|
|
|
|
|
glVertex2i(lines[i].r_ll.p_x, lines[i].r_ll.p_y);
|
|
|
|
|
|
glVertex2i(lines[i].r_ur.p_x, lines[i].r_ur.p_y);
|
|
|
|
|
|
}
|
|
|
|
|
|
glEnd();
|
|
|
|
|
|
#else
|
|
|
|
|
|
glVertexPointer(2, GL_INT, 0, (GLvoid *)lines);
|
|
|
|
|
|
glDrawArrays(GL_LINES, 0, nb << 1);
|
|
|
|
|
|
#endif
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
int i;
|
|
|
|
|
|
for (i = 0; i < nb; i++)
|
|
|
|
|
|
{
|
|
|
|
|
|
cairo_move_to(grCairoContext, lines[i].r_ll.p_x, lines[i].r_ll.p_y);
|
|
|
|
|
|
cairo_line_to(grCairoContext, lines[i].r_ur.p_x, lines[i].r_ur.p_y);
|
|
|
|
|
|
}
|
|
|
|
|
|
// cairo_set_source_rgba(grCairoContext, r, g, b, a);
|
|
|
|
|
|
// cairo_set_line_width(grCairoContext, width);
|
|
|
|
|
|
cairo_stroke(grCairoContext);
|
2017-08-07 22:22:11 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------
|
|
|
|
|
|
* grtoglDrawLine:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* This routine draws a line.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Results: None.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
|
|
|
|
|
* Side Effects:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Draw a line for (x1, y1) to (x2, y2) inclusive.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*---------------------------------------------------------
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
void
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoDrawLine (x1, y1, x2, y2)
|
|
|
|
|
|
int x1, y1; /* Screen coordinates of first point. */
|
|
|
|
|
|
int x2, y2; /* Screen coordinates of second point. */
|
2017-08-07 22:22:11 +02:00
|
|
|
|
{
|
2017-08-08 21:00:19 +02:00
|
|
|
|
/* Treat straight and diagonal lines separately. Some */
|
|
|
|
|
|
/* implementations of OpenGL make straight lines twice as thick */
|
|
|
|
|
|
/* when smoothing is enabled. */
|
|
|
|
|
|
|
|
|
|
|
|
if ((x1 == x2) || (y1 == y2))
|
|
|
|
|
|
{
|
|
|
|
|
|
if (grtcairoNbLines == TCAIRO_BATCH_SIZE) GR_TCAIRO_FLUSH_LINES();
|
|
|
|
|
|
grtcairoLines[grtcairoNbLines].r_ll.p_x = x1;
|
|
|
|
|
|
grtcairoLines[grtcairoNbLines].r_ll.p_y = y1;
|
|
|
|
|
|
grtcairoLines[grtcairoNbLines].r_ur.p_x = x2;
|
|
|
|
|
|
grtcairoLines[grtcairoNbLines].r_ur.p_y = y2;
|
|
|
|
|
|
grtcairoNbLines++;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
if (grtcairoNbDiagonal == TCAIRO_BATCH_SIZE) GR_TCAIRO_FLUSH_DIAGONAL();
|
|
|
|
|
|
grtcairoDiagonal[grtcairoNbDiagonal].r_ll.p_x = x1;
|
|
|
|
|
|
grtcairoDiagonal[grtcairoNbDiagonal].r_ll.p_y = y1;
|
|
|
|
|
|
grtcairoDiagonal[grtcairoNbDiagonal].r_ur.p_x = x2;
|
|
|
|
|
|
grtcairoDiagonal[grtcairoNbDiagonal].r_ur.p_y = y2;
|
|
|
|
|
|
grtcairoNbDiagonal++;
|
|
|
|
|
|
}
|
2017-08-07 22:22:11 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------
|
|
|
|
|
|
* grtoglFillRects:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* This routine draws a bunch of solid rectangles.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Results: None.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
|
|
|
|
|
* Side Effects:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Drawing.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*---------------------------------------------------------
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
void
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoFillRects(rects, nb)
|
|
|
|
|
|
TCairoRect rects[];
|
|
|
|
|
|
int nb;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
{
|
2017-08-08 21:00:19 +02:00
|
|
|
|
/*
|
|
|
|
|
|
#ifdef OGL_SERVER_SIDE_ONLY
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
int i;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
for (i = 0; i < nb; i++)
|
|
|
|
|
|
{
|
|
|
|
|
|
glRecti(rects[i].r_ll.p_x, rects[i].r_ll.p_y,
|
|
|
|
|
|
rects[i].r_ur.p_x, rects[i].r_ur.p_y);
|
|
|
|
|
|
}
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
#else
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
glVertexPointer(2, GL_INT, 0, (GLvoid *)rects);
|
|
|
|
|
|
glDrawArrays(GL_QUADS, 0, nb << 2);
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
*/
|
|
|
|
|
|
int i;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
for (i = 0; i < nb; i++)
|
|
|
|
|
|
{
|
2017-08-30 22:34:42 +02:00
|
|
|
|
cairo_rectangle(grCairoContext,
|
|
|
|
|
|
rects[i].r_ll.p_x, rects[i].r_ll.p_y,
|
2017-09-01 06:39:19 +02:00
|
|
|
|
rects[i].r_ur.p_x-rects[i].r_ll.p_x, rects[i].r_ur.p_y-rects[i].r_ll.p_y);
|
2017-09-05 05:20:22 +02:00
|
|
|
|
TxPrintf("%d %d %d %d \n", rects[i].r_ll.p_x, rects[i].r_ll.p_y, rects[i].r_ur.p_x-rects[i].r_ll.p_x, rects[i].r_ur.p_y-rects[i].r_ll.p_y);
|
2017-08-08 21:00:19 +02:00
|
|
|
|
}
|
2017-09-05 05:20:22 +02:00
|
|
|
|
cairo_clip(grCairoContext);
|
|
|
|
|
|
cairo_mask(grCairoContext, currentStipple);
|
|
|
|
|
|
|
|
|
|
|
|
//cairo_fill(grCairoContext);
|
2017-08-07 22:22:11 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------
|
|
|
|
|
|
* grtoglFillRect:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* This routine draws a solid rectangle.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Results: None.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
|
|
|
|
|
* Side Effects:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Drawing.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*---------------------------------------------------------
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
void
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoFillRect(r)
|
|
|
|
|
|
Rect *r; /* Address of a rectangle in screen
|
|
|
|
|
|
* coordinates.
|
|
|
|
|
|
*/
|
2017-08-07 22:22:11 +02:00
|
|
|
|
{
|
2017-08-08 21:00:19 +02:00
|
|
|
|
if (grtcairoNbRects == TCAIRO_BATCH_SIZE) GR_TCAIRO_FLUSH_RECTS();
|
|
|
|
|
|
grtcairoRects[grtcairoNbRects].r_ll.p_x = r->r_ll.p_x;
|
|
|
|
|
|
grtcairoRects[grtcairoNbRects].r_ll.p_y = r->r_ll.p_y;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoRects[grtcairoNbRects].r_ur.p_x = r->r_ur.p_x;
|
|
|
|
|
|
grtcairoRects[grtcairoNbRects].r_ur.p_y = r->r_ur.p_y;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
|
|
|
|
|
#ifndef OGL_SERVER_SIDE_ONLY
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoRects[grtcairoNbRects].r_ul.p_x = r->r_ll.p_x;
|
|
|
|
|
|
grtcairoRects[grtcairoNbRects].r_ul.p_y = r->r_ur.p_y;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoRects[grtcairoNbRects].r_lr.p_x = r->r_ur.p_x;
|
|
|
|
|
|
grtcairoRects[grtcairoNbRects].r_lr.p_y = r->r_ll.p_y;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
|
2017-08-08 21:00:19 +02:00
|
|
|
|
grtcairoNbRects++;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------
|
|
|
|
|
|
* grtoglFillPolygon:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* This routine draws a solid (convex) polygon
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*
|
|
|
|
|
|
* Results: None.
|
|
|
|
|
|
*
|
|
|
|
|
|
* Side Effects:
|
2017-08-08 21:00:19 +02:00
|
|
|
|
* Drawing.
|
2017-08-07 22:22:11 +02:00
|
|
|
|
*---------------------------------------------------------
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
void
|
2017-08-18 20:15:12 +02:00
|
|
|
|
grtcairoFillPolygon(tp, np)
|
2017-08-08 21:00:19 +02:00
|
|
|
|
Point *tp;
|
|
|
|
|
|
int np;
|
2017-08-07 22:22:11 +02:00
|
|
|
|
{
|
2017-08-08 21:00:19 +02:00
|
|
|
|
int i;
|
|
|
|
|
|
/*
|
|
|
|
|
|
glEnable(GL_POLYGON_SMOOTH);
|
|
|
|
|
|
glBegin(GL_POLYGON);
|
|
|
|
|
|
for (i = 0; i < np; i++)
|
|
|
|
|
|
glVertex2i(tp[i].p_x, tp[i].p_y);
|
|
|
|
|
|
glEnd();
|
|
|
|
|
|
glDisable(GL_POLYGON_SMOOTH);
|
|
|
|
|
|
*/
|
2017-08-30 22:34:42 +02:00
|
|
|
|
cairo_move_to(grCairoContext, tp[0].p_x, tp[0].p_y);
|
2017-08-08 21:00:19 +02:00
|
|
|
|
for (i = 1; i < np; i++)
|
2017-08-30 22:34:42 +02:00
|
|
|
|
cairo_line_to(grCairoContext, tp[i].p_x, tp[i].p_y);
|
2017-08-08 21:00:19 +02:00
|
|
|
|
cairo_close_path(grCairoContext);
|
2017-08-30 22:34:42 +02:00
|
|
|
|
cairo_fill(grCairoContext);
|
2017-08-07 22:22:11 +02:00
|
|
|
|
}
|
|
|
|
|
|
|