/******************************************************************************** * Volatile - Volume Visualization Software for SAGE * Copyright (C) 2004 Electronic Visualization Laboratory, * University of Illinois at Chicago * * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the distribution. * * Neither the name of the University of Illinois at Chicago nor * the names of its contributors may be used to endorse or promote * products derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * Direct questions, comments etc about Volatile to www.evl.uic.edu/cavern/forum *********************************************************************************/ #ifndef _V_GEOMETRY_H #define _V_GEOMETRY_H #include "global.h" #include "vPrimitive.h" //handles displaying geometry class vGeometry : public vPrimitive { public: vGeometry(); vGeometry(NetVertexBuffer* theGeom ); vGeometry(char* wildcard, char* serverName, float scale) ; virtual ~vGeometry(); void setCurFrame(int curFrame) ; void init(); void draw(); void next(); void prev(); //int select() ; void drawBoundBox() ; float angle; float axes[3]; cDataManagerClient* opClient; int* indexList; int numFrames, curFrame; vector cache; float initScale; //for the point buffer //NetPointBuffer* pb; //vGeometry(NetPointBuffer* thePoints ); /*virtual int key(unsigned char k, int x, int y); virtual int special(int k, int x, int y); virtual int mouse(int button, int state, int x, int y); virtual int move(int x, int y); virtual int release(); //tells widget it is done void setNext(vPrimitive *p); //set next in list vPrimitive *getNext(); //get next in list void remove(vPrimitive *p); //remove from list void setName(const char *PName); //just a name */ }; #endif