2 // Singleton : Var globales : Disposition sommets/aretes/faces d'un hexaedre
4 // Copyright (C) 2009-2013 CEA/DEN, EDF R&D
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/
21 // or email : webmaster.salome@opencascade.com
24 #ifndef _HEX_GLOBALE_H
25 #define _HEX_GLOBALE_H
27 #include "Hex_defines.hxx"
28 #include "hexa_base.hxx"
29 #include "HexDumpStudy.hxx"
30 #include "HexWitness.hxx"
32 /* -----------------------------------------------------
34 // ---- Numerotation des faces (%x)
36 6=bed +----bd-----+ bdf=7
40 4=bce +----bc-----+...|...bcf=5
44 2=ade...|...+----ad-|---+ adf=3 | y
48 0=ace +----ac-----+ acf=1 +-----> x
50 * ----------------------------------------------------- */
55 class HEXABLOCKENGINE_EXPORT Globale
58 static Globale* getInstance ();
60 int CoordVertex (int edge, EnumCoord dim)
61 { return coord_vertex [edge] [dim] ; }
63 EnumHVertex EdgeVertex (int edge, EnumVertex sens)
64 { return edge_vertex [edge] [sens] ; }
66 EnumHEdge QuadEdge (int face, EnumQuad cote)
67 { return quad_edge [face] [cote] ; }
69 cpchar namofHexaEdge (int arete) { return h_edge_name [arete] ; }
70 cpchar namofHexaVertex (int sommet) { return h_vertex_name [sommet]; }
71 cpchar namofHexaQuad (int face) { return h_quad_name [face]; }
73 EnumHQuad getOpposedQuad (int face) { return h_opposed_quad [face]; }
75 void setArgs (int nbargs, cpchar tabargs[]);
76 int findArg (cpchar opt);
77 bool isinArgs (cpchar opt) { return findArg (opt) >= 0; }
78 cpchar getArg (int nro) { return nro>=nbr_args ? NULL : tab_args[nro]; }
85 Globale (); // Constructeur prive
87 void setCoordVertex (EnumHVertex node, int px, int py, int pz);
88 void setEdgeVertex (EnumHEdge edge, EnumHVertex amont, EnumHVertex aval);
89 void setQuadEdge (EnumHQuad face, EnumHEdge c1, EnumHEdge c2,
90 EnumHEdge c3, EnumHEdge c4);
91 void setOpposedVertex (EnumHVertex lun, EnumHVertex lautre);
92 void setOpposedQuad (EnumHQuad lun, EnumHQuad lautre);
101 int coord_vertex [HV_MAXI] [DIM3];
102 EnumHVertex edge_vertex [HE_MAXI] [V_TWO];
103 EnumHEdge quad_edge [HQ_MAXI] [QUAD4];
105 cpchar h_edge_name [HE_MAXI];
106 cpchar h_vertex_name [HV_MAXI];
107 cpchar h_quad_name [HQ_MAXI];
109 EnumHVertex h_opposed_vertex [HV_MAXI];
110 EnumHQuad h_opposed_quad [HQ_MAXI];
112 static Globale* unique_instance;
114 // ===================================================== setArgs
115 inline void Globale::setArgs (int nbargs, cpchar tabargs[])
120 // ===================================================== findArg
121 inline int Globale::findArg (cpchar option)
123 for (int nro=1 ; nro<nbr_args ; nro++)
124 if (Cestegal (option, tab_args[nro]))