smesh/src/SMESH_I/SMESH_Pattern_i.hxx
2016-03-18 20:10:28 +03:00

110 lines
3.8 KiB
C++

// Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This library 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
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
//
// SMESH SMESH_I : idl implementation based on 'SMESH' unit's calsses
// File : SMESH_Pattern_i.hxx
// Created : Fri Aug 20 16:03:15 2004
// Author : Edward AGAPOV (eap)
// $Header:
//
#ifndef SMESH_Pattern_I_HeaderFile
#define SMESH_Pattern_I_HeaderFile
#include "SMESH.hxx"
#include "SALOMEconfig.h"
#include CORBA_SERVER_HEADER(SMESH_Pattern)
#include CORBA_SERVER_HEADER(SMESH_Mesh)
#include CORBA_CLIENT_HEADER(GEOM_Gen)
#include <TopoDS_Shape.hxx>
#include "SMESH_Pattern.hxx"
class SMESH_Gen_i;
class SMESH_Mesh;
class SMESH_I_EXPORT SMESH_Pattern_i:
public virtual POA_SMESH::SMESH_Pattern
{
public:
SMESH_Pattern_i (SMESH_Gen_i* theGen_i);
CORBA::Boolean LoadFromFile(const char* theFileContents);
CORBA::Boolean LoadFromFace(SMESH::SMESH_Mesh_ptr theMesh,
GEOM::GEOM_Object_ptr theFace,
CORBA::Boolean theProject);
CORBA::Boolean LoadFrom3DBlock(SMESH::SMESH_Mesh_ptr theMesh,
GEOM::GEOM_Object_ptr theBlock);
SMESH::point_array* ApplyToFace(GEOM::GEOM_Object_ptr theFace,
GEOM::GEOM_Object_ptr theVertexOnKeyPoint1,
CORBA::Boolean theReverse);
SMESH::point_array* ApplyTo3DBlock(GEOM::GEOM_Object_ptr theBlock,
GEOM::GEOM_Object_ptr theVertex000,
GEOM::GEOM_Object_ptr theVertex001);
SMESH::point_array* ApplyToMeshFaces(SMESH::SMESH_Mesh_ptr theMesh,
const SMESH::long_array& theFacesIDs,
CORBA::Long theNodeIndexOnKeyPoint1,
CORBA::Boolean theReverse);
SMESH::point_array* ApplyToHexahedrons(SMESH::SMESH_Mesh_ptr theMesh,
const SMESH::long_array& theVolumesIDs,
CORBA::Long theNode000Index,
CORBA::Long theNode001Index);
//for omniORB conflict compilation
/*CORBA::Boolean MakeMesh (SMESH::SMESH_Mesh_ptr theMesh,
const CORBA::Boolean CreatePolygons,
const CORBA::Boolean CreatePolyedrs);*/
CORBA::Boolean MakeMesh (SMESH::SMESH_Mesh_ptr theMesh,
CORBA::Boolean CreatePolygons,
CORBA::Boolean CreatePolyedrs);
SMESH::SMESH_Pattern::ErrorCode GetErrorCode();
char* GetString();
CORBA::Boolean Is2D();
SMESH::point_array* GetPoints();
SMESH::long_array* GetKeyPoints();
SMESH::array_of_long_array* GetElementPoints(CORBA::Boolean applied);
private:
::SMESH_Mesh* getMesh( SMESH::SMESH_Mesh_ptr & theMesh );
::SMESH_Pattern myPattern;
SMESH_Gen_i* myGen;
};
#endif