26#ifdef G4VIS_BUILD_OI_DRIVER
38#include <Inventor/errors/SoDebugError.h>
39#include <Inventor/misc/SoState.h>
40#include <Inventor/actions/SoGLRenderAction.h>
41#include <Inventor/nodes/SoPointSet.h>
43#include <Inventor/elements/SoCoordinateElement.h>
44#include <Inventor/elements/SoCacheElement.h>
45#include <Inventor/elements/SoLazyElement.h>
50static void drawMarker(SoAction*,
int);
51static GLubyte* getBitmap(
int,
int,
char []);
75static char plus_5_5[] = {
82static char asterisk_5_5[] = {
89static char cross_5_5[] = {
96static char star_5_5[] = {
103static char circle_line_5_5[] = {
110static char circle_filled_5_5[] = {
117static char triangle_up_line_5_5[] = {
124static char triangle_up_filled_5_5[] = {
131static char triangle_down_line_5_5[] = {
138static char triangle_down_filled_5_5[] = {
145static char david_star_line_5_5[] = {
152static char david_star_filled_5_5[] = {
159static char swiss_cross_line_5_5[] = {
166static char swiss_cross_filled_5_5[] = {
173static char diamond_line_5_5[] = {
180static char diamond_filled_5_5[] = {
187static char square_line_5_5[] = {
194static char square_filled_5_5[] = {
204static char plus_7_7[] = {
213static char asterisk_7_7[] = {
222static char cross_7_7[] = {
231static char star_7_7[] = {
240static char circle_line_7_7[] = {
249static char circle_filled_7_7[] = {
258static char triangle_up_line_7_7[] = {
267static char triangle_up_filled_7_7[] = {
276static char triangle_down_line_7_7[] = {
285static char triangle_down_filled_7_7[] = {
294static char david_star_line_7_7[] = {
303static char david_star_filled_7_7[] = {
312static char swiss_cross_line_7_7[] = {
321static char swiss_cross_filled_7_7[] = {
330static char diamond_line_7_7[] = {
339static char diamond_filled_7_7[] = {
348static char square_line_7_7[] = {
357static char square_filled_7_7[] = {
370static char plus_9_9[] = {
381static char asterisk_9_9[] = {
392static char cross_9_9[] = {
403static char star_9_9[] = {
414static char circle_line_9_9[] = {
425static char circle_filled_9_9[] = {
436static char triangle_up_line_9_9[] = {
447static char triangle_up_filled_9_9[] = {
458static char triangle_down_line_9_9[] = {
469static char triangle_down_filled_9_9[] = {
480static char david_star_line_9_9[] = {
491static char david_star_filled_9_9[] = {
502static char swiss_cross_line_9_9[] = {
513static char swiss_cross_filled_9_9[] = {
524static char diamond_line_9_9[] = {
535static char diamond_filled_9_9[] = {
546static char square_line_9_9[] = {
557static char square_filled_9_9[] = {
569static char* sFigures[54] = {
576 triangle_up_line_5_5,
577 triangle_up_filled_5_5,
578 triangle_down_line_5_5,
579 triangle_down_filled_5_5,
581 david_star_filled_5_5,
582 swiss_cross_line_5_5,
583 swiss_cross_filled_5_5,
594 triangle_up_line_7_7,
595 triangle_up_filled_7_7,
596 triangle_down_line_7_7,
597 triangle_down_filled_7_7,
599 david_star_filled_7_7,
600 swiss_cross_line_7_7,
601 swiss_cross_filled_7_7,
612 triangle_up_line_9_9,
613 triangle_up_filled_9_9,
614 triangle_down_line_9_9,
615 triangle_down_filled_9_9,
617 david_star_filled_9_9,
618 swiss_cross_line_9_9,
619 swiss_cross_filled_9_9,
643 SO_NODE_ADD_FIELD(markerIndex,(CROSS_5_5));
654 SoGLRenderAction* aAction
659 SoState* state = aAction->getState();
661 const SoCoordinateElement* coordinateElement =
662 SoCoordinateElement::getInstance(state);
663 if(coordinateElement==NULL)
return;
665 if(aAction->isOfType(SoGL2PSAction::getClassTypeId())) {
666 SoCacheElement::invalidate(state);
669 const SbColor& color = SoLazyElement::getDiffuse(aAction->getState(),0);
670 float red,green,blue;
671 color.getValue(red,green,blue);
675 int starti = startIndex.getValue();
676 int pointn = numPoints.getValue();
679 glPushAttrib( (GLbitfield)(GL_CURRENT_BIT | GL_ENABLE_BIT));
680 glDisable(GL_LIGHTING);
681 glColor3f(red,green,blue);
685 glDisable(GL_DEPTH_TEST);
688 glPixelStorei(GL_UNPACK_ALIGNMENT,1);
689 for(pointi=starti;pointi<pointn;pointi++){
690 const SbVec3f& vec = coordinateElement->get3(pointi);
691 glRasterPos3f(vec[0],vec[1],vec[2]);
699 drawMarker(aAction,mark);
713 GLfloat xorig = 0,yorig = 0;
714 GLfloat xmove = 0,ymove = 0;
716 if((aStyle>=0)&&(aStyle<18)) {
719 GLubyte* bitmap = getBitmap(w,h,sFigures[aStyle]);
720 glBitmap(w,h,xorig,yorig,0.,0.,bitmap);
722 }
else if((aStyle>=18)&&(aStyle<36)) {
725 GLubyte* bitmap = getBitmap(w,h,sFigures[aStyle]);
726 glBitmap(w,h,xorig,yorig,0.,0.,bitmap);
728 }
else if((aStyle>=36)&&(aStyle<54)) {
731 GLubyte* bitmap = getBitmap(w,h,sFigures[aStyle]);
732 glBitmap(w,h,xorig,yorig,0.,0.,bitmap);
738 if(aAction->isOfType(SoGL2PSAction::getClassTypeId())) {
739 ((
SoGL2PSAction*)aAction)->addBitmap(w,h,xorig,yorig,xmove,ymove);
753 GLubyte* bitmap =
new GLubyte[aW * aH + 1];
756 unsigned char byte = 0;
757 for (
int row = 0; row < aH; row++ ){
758 for (
int col = 0; col < aW; col++){
759 unsigned char c = aFigure[ichar];
764 byte += (1<<(7-ibit));
771 bitmap[index] = byte;
782 bitmap[index] = byte;
virtual void GLRender(SoGLRenderAction *)
virtual ~HEPVis_SoMarkerSet()