You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							220 lines
						
					
					
						
							7.5 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							220 lines
						
					
					
						
							7.5 KiB
						
					
					
				| // Created on: 2022-05-11 | |
| // Copyright (c) 2022 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 _KI_XCAFDoc_AssemblyGraph_HeaderFile | |
| #define _KI_XCAFDoc_AssemblyGraph_HeaderFile | |
|  | |
| #include <NCollection_DataMap.hxx> | |
| #include <NCollection_IndexedMap.hxx> | |
| #include <Standard.hxx> | |
| #include <Standard_Type.hxx> | |
| #include <TCollection_AsciiString.hxx> | |
| #include <TColStd_PackedMapOfInteger.hxx> | |
| #include <TDF_LabelIndexedMap.hxx> | |
|  | |
| class TDF_Label; | |
| class TDocStd_Document; | |
| class XCAFDoc_ShapeTool; | |
| 
 | |
| class KI_XCAFDoc_AssemblyGraph; | |
| DEFINE_STANDARD_HANDLE(KI_XCAFDoc_AssemblyGraph, Standard_Transient) | |
| 
 | |
| // Assembly graph. | |
| class KI_XCAFDoc_AssemblyGraph : public Standard_Transient | |
| { | |
| public: | |
| 
 | |
|   //! \brief Type of the graph node. | |
|   enum NodeType | |
|   { | |
|     NodeType_UNDEFINED = 0, //!< Undefined node type. | |
|     NodeType_AssemblyRoot,  //!< Root node. | |
|     NodeType_Subassembly,   //!< Intermediate node. | |
|     NodeType_Occurrence,    //!< Assembly/part occurrence node. | |
|     NodeType_Part,          //!< Leaf node to represent parts. | |
|     NodeType_Subshape       //!< Subshape node. | |
|   }; | |
| 
 | |
|   //! \brief Type definition for graph adjacency matrix.  | |
|   //! This is how parent-component links are realized in the assembly graph. | |
|   typedef NCollection_DataMap<Standard_Integer, TColStd_PackedMapOfInteger> AdjacencyMap; | |
| 
 | |
| public: | |
| 
 | |
|   //! \brief Graph iterator. | |
|   class Iterator | |
|   { | |
|   public: | |
| 
 | |
|     //! \brief Accepting the assembly graph and starting node to iterate. | |
|     //! Iteration starts from the specified node. | |
|     //! \param [in] theGraph - assembly graph to iterate. | |
|     //! \param [in] theNode  - graph node ID. | |
|     Standard_EXPORT Iterator(const Handle(KI_XCAFDoc_AssemblyGraph)& theGraph, | |
|                              const Standard_Integer               theNode = 1); | |
| 
 | |
|     //! Checks if there are more graph nodes to iterate. | |
|     //! \return true/false. | |
|     Standard_Boolean More() const | |
|     { | |
|       return myCurrentIndex <= myGraph->NbNodes(); | |
|     } | |
| 
 | |
|     //! \return 1-based ID of the current node. | |
|     Standard_Integer Current() const | |
|     { | |
|       return myCurrentIndex; | |
|     } | |
| 
 | |
|     //! Moves iterator to the next position. | |
|     void Next() | |
|     { | |
|       ++myCurrentIndex; | |
|     } | |
| 
 | |
|   private: | |
| 
 | |
|     Handle(KI_XCAFDoc_AssemblyGraph) myGraph;        //!< Assembly graph to iterate. | |
|     Standard_Integer              myCurrentIndex; //!< Current 1-based node ID. | |
|  | |
|   }; | |
| 
 | |
| public: | |
| 
 | |
|   //! \brief Constructs graph from XCAF document. | |
|   //! Construction of a formal graph will be done immediately. | |
|   //! \param [in] theDoc - document to iterate. | |
|   Standard_EXPORT KI_XCAFDoc_AssemblyGraph(const Handle(TDocStd_Document)& theDoc); | |
| 
 | |
|   //! \brief Constructs graph from XCAF label. | |
|   //! Construction of a formal graph will be done immediately. The specified | |
|   //! label is used as a starting position. | |
|   //! \param [in] theDoc   - document to iterate. | |
|   //! \param [in] theLabel - starting position. | |
|   Standard_EXPORT KI_XCAFDoc_AssemblyGraph(const TDF_Label& theLabel); | |
| 
 | |
|   //! \return Document shape tool. | |
|   const Handle(XCAFDoc_ShapeTool)& GetShapeTool() const | |
|   { | |
|     return myShapeTool; | |
|   } | |
| 
 | |
|   //! \brief Returns IDs of the root nodes. | |
|   //! \return IDs of the root nodes. | |
|   const TColStd_PackedMapOfInteger& GetRoots() const | |
|   { | |
|     return myRoots; | |
|   } | |
| 
 | |
|   //! \brief Checks whether the assembly graph contains (n1, n2) directed link. | |
|   //! \param [in] theNode1 - one-based ID of the first node. | |
|   //! \param [in] theNode2 - one-based ID of the second node. | |
|   //! \return true/false. | |
|   Standard_EXPORT Standard_Boolean IsDirectLink(const Standard_Integer theNode1, | |
|                                                 const Standard_Integer theNode2) const; | |
| 
 | |
|   //! \brief Checks whether direct children exist for the given node. | |
|   //! \param [in] theNode - one-based node ID. | |
|   //! \return true/false. | |
|   Standard_Boolean HasChildren(const Standard_Integer theNode) const | |
|   { | |
|     return myAdjacencyMap.IsBound(theNode); | |
|   } | |
| 
 | |
|   //! \brief Returns IDs of child nodes for the given node. | |
|   //! \param [in] theNode - one-based node ID. | |
|   //! \return set of child IDs. | |
|   const TColStd_PackedMapOfInteger& GetChildren(const Standard_Integer theNode) const | |
|   { | |
|     return myAdjacencyMap(theNode); | |
|   } | |
| 
 | |
|   //! \brief Returns the node type from \ref NodeType enum. | |
|   //! \param [in] theNode - one-based node ID. | |
|   //! \return node type. | |
|   //! \sa NodeType | |
|   Standard_EXPORT NodeType GetNodeType(const Standard_Integer theNode) const; | |
| 
 | |
|   //! \brief returns object ID by node ID. | |
|   //! \param [in] theNode - one-based node ID. | |
|   //! \return persistent ID. | |
|   const TDF_Label& GetNode(const Standard_Integer theNode) const | |
|   { | |
|     return myNodes(theNode); | |
|   } | |
| 
 | |
|   //! \brief Returns the unordered set of graph nodes. | |
|   //! \return graph nodes. | |
|   const TDF_LabelIndexedMap& GetNodes() const | |
|   { | |
|     return myNodes; | |
|   } | |
| 
 | |
|   //! \brief Returns the number of graph nodes. | |
|   //! \return number of graph nodes. | |
|   Standard_Integer NbNodes() const | |
|   { | |
|     return myNodes.Extent(); | |
|   } | |
| 
 | |
|   //! \brief Returns the collection of graph links in the form of adjacency matrix. | |
|   //! \return graph links. | |
|   const AdjacencyMap& GetLinks() const | |
|   { | |
|     return myAdjacencyMap; | |
|   } | |
| 
 | |
|   //! \brief Returns the number of graph links. | |
|   //! \return number of graph links. | |
|   Standard_EXPORT Standard_Integer NbLinks() const; | |
| 
 | |
|   //! Returns quantity of part usage occurrences. | |
|   //! \param [in] theNode - one-based part ID. | |
|   //! \return usage occurrence quantity. | |
|   Standard_EXPORT Standard_Integer NbOccurrences(const Standard_Integer theNode) const; | |
| 
 | |
| private: | |
| 
 | |
|   //! Builds graph out of OCAF XDE structure. | |
|   //! \param [in] theLabel - optional starting position. | |
|   Standard_EXPORT void buildGraph(const TDF_Label& theLabel); | |
| 
 | |
|   //! Adds components for the given parent to the graph structure. | |
|   //! \param [in] theParent   - OCAF label of the parent object. | |
|   //! \param [in] theParentId - ID of the already registered node representing | |
|   //!                           the parent object in the assembly graph | |
|   //!                           being populated. | |
|   Standard_EXPORT void addComponents(const TDF_Label&       theParent, | |
|                                      const Standard_Integer theParentId); | |
| 
 | |
|   //! Adds node into the graph. | |
|   //! \param [in] theLabel    - label at insertion level. | |
|   //! \param [in] theParentId - parent one-based node IDS. | |
|   //! \return one-based internal ID of the node. | |
|   Standard_EXPORT Standard_Integer addNode(const TDF_Label&       theLabel, | |
|                                            const Standard_Integer theParentId); | |
| 
 | |
| private: | |
| 
 | |
|   Handle(XCAFDoc_ShapeTool)                       myShapeTool;    //!< Document shape tool. | |
|   TColStd_PackedMapOfInteger                      myRoots;        //!< IDs of the root nodes. | |
|   TDF_LabelIndexedMap                             myNodes;        //!< Maps assembly/part entries to graph node IDs. | |
|   AdjacencyMap                                    myAdjacencyMap; //!< "Part-of" relations. | |
|   NCollection_DataMap<Standard_Integer, NodeType> myNodeTypes;    //!< Node types. | |
|   NCollection_DataMap<Standard_Integer,  | |
|                       Standard_Integer>           myUsages;       //!< Occurrences usage. | |
|  | |
| }; | |
| 
 | |
| #endif // _KI_XCAFDoc_AssemblyGraph_HeaderFile
 |