12#ifndef ARCANE_GEOMETRIC_GEOMSHAPEVIEW_H
13#define ARCANE_GEOMETRIC_GEOMSHAPEVIEW_H
17#include "arcane/utils/ITraceMng.h"
18#include "arcane/utils/ArrayView.h"
19#include "arcane/utils/Real3.h"
21#include "arcane/Item.h"
23#include "arcane/geometric/GeometricConnectic.h"
24#include "arcane/geometric/GeomElement.h"
25#include "arcane/geometric/CellConnectivity.h"
26#include "arcane/geometric/GeomShapeMutableView.h"
31namespace Arcane::geometric
58class ARCANE_CEA_GEOMETRIC_EXPORT GeomShapeView
60 friend class GeomShapeMng;
61 friend class GeomShape;
62 friend class GeomShapeConnectivity;
67 static GeomShapeConnectivity* global_connectivity;
71 static void initializeConnectivity();
76 : m_node_ptr(0), m_face_ptr(0), m_center_ptr(0),
77 m_cell_connectivity(global_cell_connectivity[IT_NullType]),
84#include "arcane/geometric/GeneratedGeomShapeViewDeclarations.h"
96 ARCANE_DEPRECATED_122
void initFromHexa(HexaElementConstView hexa,GeomShape& geom_cell);
100 ARCANE_DEPRECATED_122
void initFromQuad(QuadElementConstView hexa,GeomShape& geom_cell);
111 return m_node_ptr[i];
117 return m_face_ptr[i];
123 return *m_center_ptr;
129 return 0.5 * (
node(m_cell_connectivity->m_edge_direct_connectic[(i*2)]) +
node(m_cell_connectivity->m_edge_direct_connectic[(i*2)+1]));
142 void _setArray(
const Real3* node_ptr,
const Real3* face_ptr,
const Real3* center_ptr)
144 m_node_ptr = node_ptr;
145 m_face_ptr = face_ptr;
146 m_center_ptr = center_ptr;
151 ARCANE_RESTRICT
const Real3* m_node_ptr;
152 ARCANE_RESTRICT
const Real3* m_face_ptr;
153 ARCANE_RESTRICT
const Real3* m_center_ptr;
175 return m_cell_connectivity->nodeConnectic()[i];
181 return m_cell_connectivity->edgeConnectic()[i];
187 return m_cell_connectivity->faceConnectic()[i];
193 return m_cell_connectivity->nbSubZone();
199 return m_cell_connectivity->nbSubZoneFace();
205 return m_cell_connectivity->nodeAssociation()[i];
210 return m_cell_connectivity->SCVFaceConnectic()[i];
216 return m_cell_connectivity->m_edge_node_sub_zone_id[i];
221 return m_cell_connectivity->m_face_node_sub_zone_id[i];
235 return m_cell_connectivity->cellType();
242 m_cell_connectivity = global_cell_connectivity[
item.type()];
243 m_item_internal = ItemCompatibility::_itemInternal(
item);
246 void _setNullItem(
int item_type)
248 m_item_internal = ItemInternal::nullItem();
249 m_cell_connectivity = global_cell_connectivity[item_type];
278:
public GeomShapeView
282 explicit GeomShape3DView(
const GeomShapeView& rhs) : GeomShapeView(rhs){}
291#include "arcane/geometric/GeneratedGeomShapeView.h"
302#include "arcane/geometric/GeomShape.h"
Classe de base d'un élément de maillage.
Classe gérant un vecteur de réel de dimension 3.
Informations sur la connectivité d'une maille.
Vue sur forme géométrique 2D.
Vue constante sur une forme géométrique GeomShape.
const EdgeConnectic & edgeConnectic(Integer i) const
Informations de connectivité aux arêtes.
const Real3 node(Integer i) const
Position du ième noeud de la forme.
Integer edgeNodeSubZoneId(Integer i) const
Numéro locaux dans le sous-volumes de contrôle.
const Real3 face(Integer i) const
Position du centre de la ième face de la forme.
GeomType geomType() const
Type géométrique de la forme.
Cell cell() const
Maille associée (null si aucune)
Integer nbSvcFace() const
Nombre de sous faces internes SVC.
ARCANE_DEPRECATED_122 void initFromHexa(HexaElementConstView hexa, GeomShape &geom_cell)
const Real3 edge(Integer i) const
Position du centre de la i-ème arête de la forme.
ARCANE_DEPRECATED_122 void initFromQuad(QuadElementConstView hexa, GeomShape &geom_cell)
Integer nbSubZone() const
Nombre de sous volume de controle.
Face face() const
Face associée (null si aucune)
const Real3 center() const
Position du centre de la forme.
const NodeConnectic & nodeConnectic(Integer i) const
Informations de connectivité aux noeuds.
const FaceConnectic & faceConnectic(Integer i) const
Informations de connectivité aux faces.
void fillSubZoneElement(HexaElementView hexa, Integer i)
Remplit hexa avec les informations du i-ème sous-volume de contrôle.
Integer nodeAssociation(Integer i) const
Numéro local du sommet associé au sous volume de controle.
Item item() const
Entité associée (null si aucune)
Enumération spécifiant le type de polygone ou polyèdre associé à un élément ou une forme géométrique.
Int32 Integer
Type représentant un entier.
Structures de connectique locale des mailles.
Structure de connectique locale.
Structures de connectique locale des mailles.
Structures de connectique locale des mailles et svc.