OpenCAX/entry/src/main/cpp/include/opencascade/HLRTopoBRep_Data.hxx
2026-02-19 19:05:41 +08:00

149 lines
5.1 KiB
C++

// Created on: 1994-10-24
// Created by: Christophe MARION
// Copyright (c) 1994-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and/or modify it under
// the terms of the GNU Lesser General Public License version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#ifndef _HLRTopoBRep_Data_HeaderFile
#define _HLRTopoBRep_Data_HeaderFile
#include "Standard.hxx"
#include "Standard_DefineAlloc.hxx"
#include "Standard_Handle.hxx"
#include "TopTools_DataMapOfShapeShape.hxx"
#include "TopTools_DataMapOfShapeListOfShape.hxx"
#include "HLRTopoBRep_DataMapOfShapeFaceData.hxx"
#include "TopTools_MapOfShape.hxx"
#include "HLRTopoBRep_DataMapIteratorOfMapOfShapeListOfVData.hxx"
#include "HLRTopoBRep_ListIteratorOfListOfVData.hxx"
#include "Standard_Boolean.hxx"
#include "TopTools_ListOfShape.hxx"
class TopoDS_Edge;
class TopoDS_Face;
class TopoDS_Shape;
class TopoDS_Vertex;
//! Stores the results of the OutLine and IsoLine
//! processes.
class HLRTopoBRep_Data
{
public:
DEFINE_STANDARD_ALLOC
Standard_EXPORT HLRTopoBRep_Data();
//! Clear of all the maps.
Standard_EXPORT void Clear();
//! Clear of all the data not needed during and after
//! the hiding process.
Standard_EXPORT void Clean();
//! Returns True if the Edge is split.
Standard_EXPORT Standard_Boolean EdgeHasSplE(const TopoDS_Edge& E) const;
//! Returns True if the Face has internal outline.
Standard_EXPORT Standard_Boolean FaceHasIntL(const TopoDS_Face& F) const;
//! Returns True if the Face has outlines on restriction.
Standard_EXPORT Standard_Boolean FaceHasOutL(const TopoDS_Face& F) const;
//! Returns True if the Face has isolines.
Standard_EXPORT Standard_Boolean FaceHasIsoL(const TopoDS_Face& F) const;
Standard_EXPORT Standard_Boolean IsSplEEdgeEdge(const TopoDS_Edge& E1,
const TopoDS_Edge& E2) const;
Standard_EXPORT Standard_Boolean IsIntLFaceEdge(const TopoDS_Face& F, const TopoDS_Edge& E) const;
Standard_EXPORT Standard_Boolean IsOutLFaceEdge(const TopoDS_Face& F, const TopoDS_Edge& E) const;
Standard_EXPORT Standard_Boolean IsIsoLFaceEdge(const TopoDS_Face& F, const TopoDS_Edge& E) const;
Standard_EXPORT TopoDS_Shape NewSOldS(const TopoDS_Shape& New) const;
//! Returns the list of the edges.
const TopTools_ListOfShape& EdgeSplE(const TopoDS_Edge& E) const;
//! Returns the list of the internal OutLines.
const TopTools_ListOfShape& FaceIntL(const TopoDS_Face& F) const;
//! Returns the list of the OutLines on restriction.
const TopTools_ListOfShape& FaceOutL(const TopoDS_Face& F) const;
//! Returns the list of the IsoLines.
const TopTools_ListOfShape& FaceIsoL(const TopoDS_Face& F) const;
//! Returns True if V is an outline vertex on a
//! restriction.
Standard_Boolean IsOutV(const TopoDS_Vertex& V) const;
//! Returns True if V is an internal outline vertex.
Standard_Boolean IsIntV(const TopoDS_Vertex& V) const;
Standard_EXPORT void AddOldS(const TopoDS_Shape& NewS, const TopoDS_Shape& OldS);
Standard_EXPORT TopTools_ListOfShape& AddSplE(const TopoDS_Edge& E);
Standard_EXPORT TopTools_ListOfShape& AddIntL(const TopoDS_Face& F);
Standard_EXPORT TopTools_ListOfShape& AddOutL(const TopoDS_Face& F);
Standard_EXPORT TopTools_ListOfShape& AddIsoL(const TopoDS_Face& F);
void AddOutV(const TopoDS_Vertex& V);
void AddIntV(const TopoDS_Vertex& V);
Standard_EXPORT void InitEdge();
Standard_Boolean MoreEdge() const;
Standard_EXPORT void NextEdge();
const TopoDS_Edge& Edge() const;
//! Start an iteration on the vertices of E.
Standard_EXPORT void InitVertex(const TopoDS_Edge& E);
Standard_Boolean MoreVertex() const;
void NextVertex();
Standard_EXPORT const TopoDS_Vertex& Vertex() const;
Standard_EXPORT Standard_Real Parameter() const;
//! Insert before the current position.
Standard_EXPORT void InsertBefore(const TopoDS_Vertex& V, const Standard_Real P);
Standard_EXPORT void Append(const TopoDS_Vertex& V, const Standard_Real P);
protected:
private:
TopTools_DataMapOfShapeShape myOldS;
TopTools_DataMapOfShapeListOfShape mySplE;
HLRTopoBRep_DataMapOfShapeFaceData myData;
TopTools_MapOfShape myOutV;
TopTools_MapOfShape myIntV;
HLRTopoBRep_MapOfShapeListOfVData myEdgesVertices;
HLRTopoBRep_DataMapIteratorOfMapOfShapeListOfVData myEIterator;
HLRTopoBRep_ListIteratorOfListOfVData myVIterator;
HLRTopoBRep_ListOfVData* myVList;
};
#include "HLRTopoBRep_Data.lxx"
#endif // _HLRTopoBRep_Data_HeaderFile