BOPTools.GeneralFuseResult.GeneralFuseResult Class Reference

Public Member Functions

def explodeCompounds (self)
 
def indexOfPiece (self, piece_shape)
 
def indexOfSource (self, source_shape)
 
def largestOverlapCount (self)
 
def makeSplitPieces (self, shape)
 
def parse (self)
 
def parse_elements (self)
 
def piecesFromSource (self, source_shape)
 
def sourcesOfPiece (self, piece_shape)
 
def splitAggregates (self, pieces_to_split=None)
 

Public Attributes

 gfa_return
 
 pieces
 
 source_shapes
 

Detailed Description

class GeneralFuseResult: helper object for obtaining info from results of
Part.Shape.generalFuse() method.

Usage:
def myCustomFusionRoutine(list_of_shapes):
generalFuse_return = list_of_shapes[0].generalFuse(list_of_shapes[1:])
ao = GeneralFuseResult(list_of_shapes, generalFuse_return)
... (use attributes and methods of ao) ...

Member Function Documentation

◆ explodeCompounds()

def BOPTools.GeneralFuseResult.GeneralFuseResult.explodeCompounds (   self)
explodeCompounds(): if any of self.pieces is a compound, the compound is exploded.
After running this, 'self' is filled with new data, where pieces are updated to
contain the stuff extracted from compounds.

References BOPTools.GeneralFuseResult.GeneralFuseResult._sources_of_piece, BOPTools.GeneralFuseResult.GeneralFuseResult.gfa_return, BOPTools.GeneralFuseResult.GeneralFuseResult.parse(), Gui::SelectionFilter.parse(), App::Expression.parse(), Base::Quantity.parse(), App::ObjectIdentifier.parse(), BOPTools.GeneralFuseResult.GeneralFuseResult.pieces, and BOPTools.GeneralFuseResult.GeneralFuseResult.source_shapes.

◆ indexOfPiece()

def BOPTools.GeneralFuseResult.GeneralFuseResult.indexOfPiece (   self,
  piece_shape 
)

References BOPTools.GeneralFuseResult.GeneralFuseResult._piece_to_index.

Referenced by BOPTools.GeneralFuseResult.GeneralFuseResult.parse(), and BOPTools.GeneralFuseResult.GeneralFuseResult.sourcesOfPiece().

◆ indexOfSource()

def BOPTools.GeneralFuseResult.GeneralFuseResult.indexOfSource (   self,
  source_shape 
)

References BOPTools.GeneralFuseResult.GeneralFuseResult._source_to_index.

Referenced by BOPTools.GeneralFuseResult.GeneralFuseResult.parse(), and BOPTools.GeneralFuseResult.GeneralFuseResult.piecesFromSource().

◆ largestOverlapCount()

def BOPTools.GeneralFuseResult.GeneralFuseResult.largestOverlapCount (   self)
largestOverlapCount(self): returns the largest overlap count. For example, if three
spheres intersect and have some volume common to all three, largestOverlapCount
returns 3.

Note: the return value may be incorrect if some of the pieces are wires/shells/
compsolids/compounds. Please use explodeCompounds and splitAggregates before using this function.

References BOPTools.GeneralFuseResult.GeneralFuseResult._sources_of_piece.

◆ makeSplitPieces()

def BOPTools.GeneralFuseResult.GeneralFuseResult.makeSplitPieces (   self,
  shape 
)
makeSplitPieces(self, shape): splits a shell, wire or compsolid into pieces where
it intersects with other shapes.

Returns list of split pieces. If no splits were done, returns list containing the
original shape.

References BOPTools.GeneralFuseResult.GeneralFuseResult._element_to_source, and BOPTools.GeneralFuseResult.GeneralFuseResult.gfa_return.

Referenced by BOPTools.GeneralFuseResult.GeneralFuseResult.splitAggregates().

◆ parse()

def BOPTools.GeneralFuseResult.GeneralFuseResult.parse (   self)
Parses the result of generalFuse recorded into self.gfa_return. Recovers missing
information. Fills in data structures.

It is called automatically by class constructor.

References BOPTools.GeneralFuseResult.GeneralFuseResult.__define_attributes(), AttachmentEditor.TaskAttachmentEditor.AttachmentEditorTaskPanel.__define_attributes(), BOPTools.GeneralFuseResult.GeneralFuseResult._piece_to_index, BOPTools.GeneralFuseResult.GeneralFuseResult._pieces_of_source, BOPTools.GeneralFuseResult.GeneralFuseResult._source_to_index, BOPTools.GeneralFuseResult.GeneralFuseResult._sources_of_piece, BOPTools.GeneralFuseResult.GeneralFuseResult.gfa_return, BOPTools.GeneralFuseResult.GeneralFuseResult.indexOfPiece(), BOPTools.GeneralFuseResult.GeneralFuseResult.indexOfSource(), BOPTools.GeneralFuseResult.GeneralFuseResult.pieces, and BOPTools.GeneralFuseResult.GeneralFuseResult.source_shapes.

Referenced by BOPTools.GeneralFuseResult.GeneralFuseResult.explodeCompounds(), and BOPTools.GeneralFuseResult.GeneralFuseResult.splitAggregates().

◆ parse_elements()

def BOPTools.GeneralFuseResult.GeneralFuseResult.parse_elements (   self)
Fills element-to-source map. Potentially slow, so separated from general parse.
Needed for splitAggregates; called automatically from splitAggregates.

References BOPTools.GeneralFuseResult.GeneralFuseResult._element_to_source, BOPTools.GeneralFuseResult.GeneralFuseResult._sources_of_piece, and BOPTools.GeneralFuseResult.GeneralFuseResult.pieces.

Referenced by BOPTools.GeneralFuseResult.GeneralFuseResult.splitAggregates().

◆ piecesFromSource()

def BOPTools.GeneralFuseResult.GeneralFuseResult.piecesFromSource (   self,
  source_shape 
)
piecesFromSource(source_shape): returns list of pieces (shapes) that came from
given source shape.

Note: aggregate pieces (e.g. wire, shell, compound) always have only one source - the
shape they came directly from. Only after executing splitAggregates and
explodeCompounds the source lists become completely populated.

References BOPTools.GeneralFuseResult.GeneralFuseResult._pieces_of_source, BOPTools.GeneralFuseResult.GeneralFuseResult.indexOfSource(), and BOPTools.GeneralFuseResult.GeneralFuseResult.pieces.

◆ sourcesOfPiece()

def BOPTools.GeneralFuseResult.GeneralFuseResult.sourcesOfPiece (   self,
  piece_shape 
)
sourcesOfPiece(piece_shape): returns list of source shapes given piece came from.

Note: aggregate pieces (e.g. wire, shell, compound) always have only one source - the
shape they came directly from. Only after executing splitAggregates and
explodeCompounds the source lists become completely populated.

References BOPTools.GeneralFuseResult.GeneralFuseResult._sources_of_piece, BOPTools.GeneralFuseResult.GeneralFuseResult.indexOfPiece(), and BOPTools.GeneralFuseResult.GeneralFuseResult.source_shapes.

◆ splitAggregates()

def BOPTools.GeneralFuseResult.GeneralFuseResult.splitAggregates (   self,
  pieces_to_split = None 
)
splitAggregates(pieces_to_split = None): splits aggregate shapes (wires, shells,
compsolids) in pieces of GF result as cut by intersections. Also splits aggregates
inside compounds. After running this, 'self' is replaced with new data, where the
pieces_to_split are split.

'pieces_to_split': list of shapes (from self.pieces), that are to be processed. If
None, all pieces will be split if possible.

Notes:
* this routine is very important to functioning of Connect on shells and wires.
* Warning: convoluted and slow.

References BOPTools.GeneralFuseResult.GeneralFuseResult._sources_of_piece, BOPTools.GeneralFuseResult.GeneralFuseResult._splitInCompound(), BOPTools.GeneralFuseResult.GeneralFuseResult.gfa_return, BOPTools.GeneralFuseResult.GeneralFuseResult.makeSplitPieces(), BOPTools.GeneralFuseResult.GeneralFuseResult.parse(), Gui::SelectionFilter.parse(), App::Expression.parse(), Base::Quantity.parse(), App::ObjectIdentifier.parse(), BOPTools.GeneralFuseResult.GeneralFuseResult.parse_elements(), BOPTools.GeneralFuseResult.GeneralFuseResult.pieces, and BOPTools.GeneralFuseResult.GeneralFuseResult.source_shapes.

Member Data Documentation

◆ gfa_return

◆ pieces

◆ source_shapes


The documentation for this class was generated from the following file:
  • src/Mod/Part/BOPTools/GeneralFuseResult.py