Skip to content
Snippets Groups Projects
Select Git revision
  • 0949cd9b79a501949a1e56b338e639b965d38c49
  • master default
  • cgnsUnstructured
  • partitioning
  • poppler
  • HighOrderBLCurving
  • gmsh_3_0_4
  • gmsh_3_0_3
  • gmsh_3_0_2
  • gmsh_3_0_1
  • gmsh_3_0_0
  • gmsh_2_16_0
  • gmsh_2_15_0
  • gmsh_2_14_1
  • gmsh_2_14_0
  • gmsh_2_13_2
  • gmsh_2_13_1
  • gmsh_2_12_0
  • gmsh_2_11_0
  • gmsh_2_10_1
  • gmsh_2_10_0
  • gmsh_2_9_3
  • gmsh_2_9_2
  • gmsh_2_9_1
  • gmsh_2_9_0
  • gmsh_2_8_6
26 results

Context.h

Blame
  • Forked from gmsh / gmsh
    Source project has a limited visibility.
    PViewData.h 4.84 KiB
    #ifndef _PVIEW_DATA_H_
    #define _PVIEW_DATA_H_
    
    // Copyright (C) 1997-2008 C. Geuzaine, J.-F. Remacle
    //
    // This program is free software; you can redistribute it and/or modify
    // it under the terms of the GNU General Public License as published by
    // the Free Software Foundation; either version 2 of the License, or
    // (at your option) any later version.
    //
    // This program is distributed in the hope that it will be useful,
    // but WITHOUT ANY WARRANTY; without even the implied warranty of
    // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    // GNU General Public License for more details.
    //
    // You should have received a copy of the GNU General Public License
    // along with this program; if not, write to the Free Software
    // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
    // USA.
    // 
    // Please report all bugs and problems to <gmsh@geuz.org>.
    
    #include <string>
    #include <vector>
    #include "SBoundingBox3d.h"
    
    class nameData;
    
    // abstract interface to post-processing view data
    class PViewData {
     private:
      // flag to mark that the data is 'dirty' and should not be displayed
      bool _dirty;
      // name of the view
      std::string _name;
      // name of the file the data was loaded from
      std::string _filename;
      // index of the view in the file
      int _fileIndex;
     public:
      PViewData();
      virtual ~PViewData(){}
      virtual bool getDirty(){ return _dirty; }
      virtual void setDirty(bool val){ _dirty = val; }
      virtual bool finalize(){ _dirty = false; return true; }
      virtual std::string getName(){ return _name; }
      virtual void setName(std::string val){ _name = val; }
      virtual std::string getFileName(){ return _filename; }
      virtual void setFileName(std::string val){ _filename = val; }
      virtual int getFileIndex(){ return _fileIndex; }
      virtual void setFileIndex(int val){ _fileIndex = val; }
      virtual int getNumTimeSteps() = 0;
      virtual double getTime(int step){ return 0.; }
      virtual double getMin(int step=-1) = 0;
      virtual double getMax(int step=-1) = 0;
      virtual SBoundingBox3d getBoundingBox() = 0;
      virtual int getNumScalars(){ return 0; }
      virtual int getNumVectors(){ return 0; }
      virtual int getNumTensors(){ return 0; }
      virtual int getNumPoints(){ return 0; }
      virtual int getNumLines(){ return 0; }
      virtual int getNumTriangles(){ return 0; }
      virtual int getNumQuadrangles(){ return 0; }
      virtual int getNumTetrahedra(){ return 0; }
      virtual int getNumHexahedra(){ return 0; }
      virtual int getNumPrisms(){ return 0; }
      virtual int getNumPyramids(){ return 0; }
      // Returns the number of geometrical entities in the view
      virtual int getNumEntities() = 0;
      // Returns the number of elements in the ent-th entity, or the total
      // number of elements if ent < 0
      virtual int getNumElements(int ent=-1) = 0;
      // Returns the geometrical dimension of the ele-th element in the
      // ent-th entity
      virtual int getDimension(int ent, int ele) = 0;
      // Returns the number of nodes of the ele-th element in the ent-th
      // entity
      virtual int getNumNodes(int ent, int ele) = 0;
      // Returns the coordinates of the nod-th node from the ele-th element
      // in the ent-th entity
      virtual void getNode(int ent, int ele, int nod, double &x, double &y, double &z) = 0;
      // Returns the number of componts available for the ele-th element
      // in the ent-th entity
      virtual int getNumComponents(int ent, int ele) = 0;
      // Returns the comp-th component (at the step-th time step)
      // associated with the node-th node from the ele-th element in the
      // ent-th entity
      virtual void getValue(int ent, int ele, int node, int comp, int step, double &val) = 0;
      // Returns the number of edges of the ele-th element in the ent-th
      // entity
      virtual int getNumEdges(int ent, int ele) = 0;
      virtual int getNumStrings2D(){ return 0; }
      virtual int getNumStrings3D(){ return 0; }
      virtual void getString2D(int i, int step, std::string &str, 
    			   double &x, double &y, double &style){}
      virtual void getString3D(int i, int step, std::string &str, 
    			   double &x, double &y, double &z, double &style){}
      virtual bool empty();
      virtual void smooth(){}
      virtual bool combineTime(nameData &nd){ return false; }
      virtual bool combineSpace(nameData &nd){ return false; }
      virtual bool isAdaptive(){ return false; }
      virtual bool skipEntity(int ent){ return false; }
      virtual bool skipElement(int ent, int ele){ return false; }
    
      // I/O routines
      virtual bool writeSTL(std::string name);
      virtual bool writePOS(std::string name, bool binary=false, bool parsed=true,
    			bool append=false){ return false; }
      virtual bool writeTXT(std::string name){ return false; }
      virtual bool writeMSH(std::string name){ return false; }
    };
    
    class nameData{
     public:
      std::string name;
      std::vector<int> indices;
      std::vector<PViewData*> data;
    };
    
    class nameDataLessThan{
     public:
      bool operator()(const nameData &n1, const nameData &n2) const
      {
        return n1.name < n2.name;
      }
    };
    
    #endif