1*df85ffc0SBarry Smith /* $Id: draw.h,v 1.37 1996/11/22 14:43:26 curfman Exp bsmith $ */ 243e6b640SBarry Smith /* 343e6b640SBarry Smith Public include file for all of the PETSc graphics routines 443e6b640SBarry Smith */ 51eb62cbbSBarry Smith #if !defined(__DRAW_PACKAGE) 61eb62cbbSBarry Smith #define __DRAW_PACKAGE 7d6dfbf8fSBarry Smith #include "petsc.h" 843e6b640SBarry Smith 99e25ed09SBarry Smith #define DRAW_COOKIE PETSC_COOKIE+6 10f0479e8cSBarry Smith 11d6dfbf8fSBarry Smith /* types of draw contexts */ 126d4a8577SBarry Smith #define DRAW_XWINDOW 0 136d4a8577SBarry Smith #define DRAW_NULLWINDOW 1 146d4a8577SBarry Smith #define DRAW_VRML 2 15d6dfbf8fSBarry Smith 16d7e8b826SBarry Smith typedef struct _Draw* Draw; 1743e6b640SBarry Smith 1820563c6bSBarry Smith #define DRAW_WHITE 0 1920563c6bSBarry Smith #define DRAW_BLACK 1 2020563c6bSBarry Smith #define DRAW_RED 2 21f8d5e24aSBarry Smith #define DRAW_GREEN 3 22f8d5e24aSBarry Smith #define DRAW_CYAN 4 23f8d5e24aSBarry Smith #define DRAW_BLUE 5 24f8d5e24aSBarry Smith #define DRAW_MAGENTA 6 25f8d5e24aSBarry Smith #define DRAW_AQUAMARINE 7 26f8d5e24aSBarry Smith #define DRAW_FORESTGREEN 8 27f8d5e24aSBarry Smith #define DRAW_ORANGE 9 28f8d5e24aSBarry Smith #define DRAW_VIOLET 10 29f8d5e24aSBarry Smith #define DRAW_BROWN 11 30f8d5e24aSBarry Smith #define DRAW_PINK 12 31f8d5e24aSBarry Smith #define DRAW_CORAL 13 32f8d5e24aSBarry Smith #define DRAW_GRAY 14 33f8d5e24aSBarry Smith #define DRAW_YELLOW 15 3420563c6bSBarry Smith 35d7e8b826SBarry Smith extern int DrawOpenX(MPI_Comm,char *,char *,int,int,int,int,Draw*); 36e340e5c6SBarry Smith extern int DrawOpenVRML( MPI_Comm, char *, char *, Draw * ); 37e340e5c6SBarry Smith 38d7e8b826SBarry Smith extern int DrawOpenNull(MPI_Comm,Draw *); 39d7e8b826SBarry Smith extern int DrawDestroy(Draw); 4019bcc07fSBarry Smith extern int DrawIsNull(Draw,PetscTruth*); 4143e6b640SBarry Smith 42d4fbbf0eSBarry Smith extern int DrawCreatePopUp(Draw,Draw*); 43d4fbbf0eSBarry Smith extern int DrawCheckResizedWindow(Draw); 44d4fbbf0eSBarry Smith 45bcd2baecSBarry Smith extern int ViewerDrawGetDraw(Viewer, Draw*); 46*df85ffc0SBarry Smith extern int DrawScalePopup(Draw,double min,double max); 475311e20fSBarry Smith 48d7e8b826SBarry Smith extern int DrawLine(Draw,double,double,double,double,int); 49d7e8b826SBarry Smith extern int DrawLineSetWidth(Draw,double); 509a28b0a6SLois Curfman McInnes extern int DrawLineGetWidth(Draw,double*); 5143e6b640SBarry Smith 52d7e8b826SBarry Smith extern int DrawPoint(Draw,double,double,int); 53d7e8b826SBarry Smith extern int DrawPointSetSize(Draw,double); 548ed539a5SBarry Smith 55d7e8b826SBarry Smith extern int DrawRectangle(Draw,double,double,double,double,int,int,int,int); 56d7e8b826SBarry Smith extern int DrawTriangle(Draw,double,double,double,double,double,double,int,int,int); 578ed539a5SBarry Smith 58d7e8b826SBarry Smith extern int DrawText(Draw,double,double,int,char*); 59d7e8b826SBarry Smith extern int DrawTextVertical(Draw,double,double,int,char*); 60d7e8b826SBarry Smith extern int DrawTextSetSize(Draw,double,double); 61d7e8b826SBarry Smith extern int DrawTextGetSize(Draw,double*,double*); 62d6dfbf8fSBarry Smith 63d7e8b826SBarry Smith extern int DrawSetViewPort(Draw,double,double,double,double); 64d7e8b826SBarry Smith extern int DrawSetCoordinates(Draw,double,double,double,double); 65d7e8b826SBarry Smith extern int DrawGetCoordinates(Draw,double*,double*,double*,double*); 669e25ed09SBarry Smith 67d4fbbf0eSBarry Smith extern int DrawSetTitle(Draw,char *); 68d4fbbf0eSBarry Smith extern int DrawAppendTitle(Draw,char *); 69d4fbbf0eSBarry Smith extern int DrawGetTitle(Draw,char **); 70d4fbbf0eSBarry Smith 71d7e8b826SBarry Smith extern int DrawSetPause(Draw,int); 7277c4ece6SBarry Smith extern int DrawGetPause(Draw,int*); 7377c4ece6SBarry Smith extern int DrawPause(Draw); 74d7e8b826SBarry Smith extern int DrawSetDoubleBuffer(Draw); 75d7e8b826SBarry Smith extern int DrawFlush(Draw); 76d7e8b826SBarry Smith extern int DrawSyncFlush(Draw); 77d7e8b826SBarry Smith extern int DrawClear(Draw); 781a20e397SBarry Smith extern int DrawSyncClear(Draw); 79e340e5c6SBarry Smith extern int DrawBOP(Draw); 80e340e5c6SBarry Smith extern int DrawEOP(Draw); 81cddf8d76SBarry Smith 82cddf8d76SBarry Smith typedef enum {BUTTON_NONE, BUTTON_LEFT, BUTTON_CENTER, BUTTON_RIGHT } DrawButton; 83d7e8b826SBarry Smith extern int DrawGetMouseButton(Draw,DrawButton *,double*,double *,double *,double *); 8420563c6bSBarry Smith 85d69bd51fSBarry Smith /* 86d69bd51fSBarry Smith Routines for drawing X-Y axises in a Draw object 87d69bd51fSBarry Smith */ 88d7e8b826SBarry Smith typedef struct _DrawAxis* DrawAxis; 896d4a8577SBarry Smith #define DRAWAXIS_COOKIE PETSC_COOKIE+16 90d7e8b826SBarry Smith extern int DrawAxisCreate(Draw,DrawAxis *); 91d7e8b826SBarry Smith extern int DrawAxisDestroy(DrawAxis); 92d7e8b826SBarry Smith extern int DrawAxisDraw(DrawAxis); 93d7e8b826SBarry Smith extern int DrawAxisSetLimits(DrawAxis,double,double,double,double); 94d7e8b826SBarry Smith extern int DrawAxisSetColors(DrawAxis,int,int,int); 95d7e8b826SBarry Smith extern int DrawAxisSetLabels(DrawAxis,char*,char*,char*); 9620563c6bSBarry Smith 97d69bd51fSBarry Smith /* 98d69bd51fSBarry Smith Routines to draw line curves in X-Y space 99d69bd51fSBarry Smith */ 100d7e8b826SBarry Smith typedef struct _DrawLG* DrawLG; 1016d4a8577SBarry Smith #define DRAWLG_COOKIE PETSC_COOKIE+7 102d7e8b826SBarry Smith extern int DrawLGCreate(Draw,int,DrawLG *); 103d7e8b826SBarry Smith extern int DrawLGDestroy(DrawLG); 104d7e8b826SBarry Smith extern int DrawLGAddPoint(DrawLG,double*,double*); 105d7e8b826SBarry Smith extern int DrawLGAddPoints(DrawLG,int,double**,double**); 106d7e8b826SBarry Smith extern int DrawLGDraw(DrawLG); 107d7e8b826SBarry Smith extern int DrawLGReset(DrawLG); 1085311e20fSBarry Smith extern int DrawLGSetDimension(DrawLG,int); 109d7e8b826SBarry Smith extern int DrawLGGetAxis(DrawLG,DrawAxis *); 110d7e8b826SBarry Smith extern int DrawLGGetDraw(DrawLG,Draw *); 111d7e8b826SBarry Smith extern int DrawLGIndicateDataPoints(DrawLG); 112d7e8b826SBarry Smith extern int DrawLGSetLimits(DrawLG,double,double,double,double); 11343e6b640SBarry Smith 114d69bd51fSBarry Smith /* 115d69bd51fSBarry Smith Routines to draw scatter plots in complex space 116d69bd51fSBarry Smith */ 117d4fbbf0eSBarry Smith typedef struct _DrawSP* DrawSP; 118d4fbbf0eSBarry Smith #define DRAWSP_COOKIE PETSC_COOKIE+27 119d4fbbf0eSBarry Smith extern int DrawSPCreate(Draw,int,DrawSP *); 120d4fbbf0eSBarry Smith extern int DrawSPDestroy(DrawSP); 121d4fbbf0eSBarry Smith extern int DrawSPAddPoint(DrawSP,double*,double*); 122d4fbbf0eSBarry Smith extern int DrawSPAddPoints(DrawSP,int,double**,double**); 123d4fbbf0eSBarry Smith extern int DrawSPDraw(DrawSP); 124d4fbbf0eSBarry Smith extern int DrawSPReset(DrawSP); 125d4fbbf0eSBarry Smith extern int DrawSPSetDimension(DrawSP,int); 126d4fbbf0eSBarry Smith extern int DrawSPGetAxis(DrawSP,DrawAxis *); 127d4fbbf0eSBarry Smith extern int DrawSPGetDraw(DrawSP,Draw *); 128d4fbbf0eSBarry Smith extern int DrawSPSetLimits(DrawSP,double,double,double,double); 129d4fbbf0eSBarry Smith 1305311e20fSBarry Smith extern int ViewerDrawGetDrawLG(Viewer, DrawLG*); 1315311e20fSBarry Smith 1327aa781d9SBarry Smith #if defined(__VEC_PACKAGE) 133d7e8b826SBarry Smith int DrawTensorContour(Draw,int,int,double*,double*,Vec); 1347aa781d9SBarry Smith #endif 13512d3fcd6SBarry Smith 136d557673fSLois Curfman McInnes /* Mesh management routines */ 137d557673fSLois Curfman McInnes typedef struct _DrawMesh* DrawMesh; 138d557673fSLois Curfman McInnes int DrawMeshCreate( DrawMesh *, 139d557673fSLois Curfman McInnes double *, double *, double *, 140d557673fSLois Curfman McInnes int, int, int, int, int, int, int, int, int, 141d557673fSLois Curfman McInnes int, int, int, int, double *, int ); 142d557673fSLois Curfman McInnes int DrawMeshCreateSimple( DrawMesh *, double *, double *, double *, 143d557673fSLois Curfman McInnes int, int, int, int, double *, int ); 144d557673fSLois Curfman McInnes int DrawMeshDestroy( DrawMesh * ); 145d557673fSLois Curfman McInnes 146d557673fSLois Curfman McInnes /* Color spectrum managment */ 147d557673fSLois Curfman McInnes typedef void (*VRMLGetHue_fcn)( double, void *, int, double *, double *, 148d557673fSLois Curfman McInnes double * ); 149d557673fSLois Curfman McInnes 150d557673fSLois Curfman McInnes void *VRMLFindHue_setup( DrawMesh, int ); 151d557673fSLois Curfman McInnes void VRMLFindHue( double, void *, int, double *, double *, double * ); 152d557673fSLois Curfman McInnes void VRMLFindHue_destroy( void * ); 153d557673fSLois Curfman McInnes void *VRMLGetHue_setup( DrawMesh, int ); 154d557673fSLois Curfman McInnes void VRMLGetHue( double, void *, int, double *, double *, double * ); 155d557673fSLois Curfman McInnes void VRMLGetHue_destroy( void * ); 156d557673fSLois Curfman McInnes 157d557673fSLois Curfman McInnes 158d557673fSLois Curfman McInnes int DrawTensorSurfaceContour(Draw,DrawMesh,VRMLGetHue_fcn, void *, int ); 159d557673fSLois Curfman McInnes int DrawTensorMapMesh( Draw, DrawMesh, double, double, double, int, int ); 160d557673fSLois Curfman McInnes int DrawTensorMapSurfaceContour(Draw,DrawMesh,double,double,double, 161d557673fSLois Curfman McInnes int,int, VRMLGetHue_fcn, void *, int,double); 162d557673fSLois Curfman McInnes int DrawTensorSurface(Draw, DrawMesh, int); 163d557673fSLois Curfman McInnes /*int DrawTensorMapSurfaceContourAndMesh_VRML(Draw,DrawMesh,int); */ 164d557673fSLois Curfman McInnes 1654316758fSBarry Smith 16643e6b640SBarry Smith #endif 167