mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0025484: Visualization - group sub-shapes with the same style in XCAFPrs_AISObject::Compute()
This commit is contained in:
parent
e159a66863
commit
3ea0a91b70
@ -447,6 +447,30 @@ Standard_Boolean AIS_ColoredShape::dispatchColors (const TopoDS_Shape& th
|
|||||||
return isOverriden || isSubOverride;
|
return isOverriden || isSubOverride;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//! Function to check if specified compound is sub-shape of another one
|
||||||
|
inline Standard_Boolean isContainCompound (const TopoDS_Shape& theShape,
|
||||||
|
const TopoDS_Compound& theCompound)
|
||||||
|
{
|
||||||
|
if (theShape.ShapeType() != TopAbs_COMPOUND)
|
||||||
|
{
|
||||||
|
return Standard_False;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (TopoDS_Iterator aSubShapeIter (theShape); aSubShapeIter.More(); aSubShapeIter.Next())
|
||||||
|
{
|
||||||
|
if (aSubShapeIter.Value().ShapeType() != TopAbs_COMPOUND)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else if (aSubShapeIter.Value() == theCompound
|
||||||
|
|| isContainCompound (aSubShapeIter.Value(), theCompound))
|
||||||
|
{
|
||||||
|
return Standard_True;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Standard_False;
|
||||||
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : dispatchColors
|
//function : dispatchColors
|
||||||
//purpose :
|
//purpose :
|
||||||
@ -460,11 +484,11 @@ void AIS_ColoredShape::dispatchColors (const TopoDS_Shape& theBaseShape,
|
|||||||
// This needed when colored shape is not part of <theBaseShape>
|
// This needed when colored shape is not part of <theBaseShape>
|
||||||
// (but subshapes are) and actually container for subshapes.
|
// (but subshapes are) and actually container for subshapes.
|
||||||
DataMapOfShapeShape aSubshapeKeyshapeMap;
|
DataMapOfShapeShape aSubshapeKeyshapeMap;
|
||||||
for (DataMapOfShapeColor::Iterator anIt (theKeyshapeColorMap);
|
for (DataMapOfShapeColor::Iterator aKeyShapeIter (theKeyshapeColorMap);
|
||||||
anIt.More(); anIt.Next())
|
aKeyShapeIter.More(); aKeyShapeIter.Next())
|
||||||
{
|
{
|
||||||
const TopoDS_Shape& aSh = anIt.Key();
|
const TopoDS_Shape& aKeySh = aKeyShapeIter.Key();
|
||||||
TopAbs_ShapeEnum aType = aSh.ShapeType();
|
const TopAbs_ShapeEnum aType = aKeySh.ShapeType();
|
||||||
TopAbs_ShapeEnum aSubType = (aType == TopAbs_SOLID || aType == TopAbs_SHELL)
|
TopAbs_ShapeEnum aSubType = (aType == TopAbs_SOLID || aType == TopAbs_SHELL)
|
||||||
? TopAbs_FACE
|
? TopAbs_FACE
|
||||||
: (aType == TopAbs_WIRE ? TopAbs_EDGE : TopAbs_SHAPE);
|
: (aType == TopAbs_WIRE ? TopAbs_EDGE : TopAbs_SHAPE);
|
||||||
@ -472,16 +496,30 @@ void AIS_ColoredShape::dispatchColors (const TopoDS_Shape& theBaseShape,
|
|||||||
{
|
{
|
||||||
case TopAbs_SHAPE:
|
case TopAbs_SHAPE:
|
||||||
{
|
{
|
||||||
aSubshapeKeyshapeMap.Bind (aSh, aSh);
|
if (aType == TopAbs_COMPOUND
|
||||||
|
&& !isContainCompound (theBaseShape, TopoDS::Compound (aKeySh)))
|
||||||
|
{
|
||||||
|
for (TopoDS_Iterator aSubShapeIter (aKeySh); aSubShapeIter.More(); aSubShapeIter.Next())
|
||||||
|
{
|
||||||
|
if (!aSubshapeKeyshapeMap.IsBound (aSubShapeIter.Value()))
|
||||||
|
{
|
||||||
|
aSubshapeKeyshapeMap.Bind (aSubShapeIter.Value(), aKeySh);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
aSubshapeKeyshapeMap.Bind (aKeySh, aKeySh);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
for (TopExp_Explorer anExp (aSh, aSubType); anExp.More(); anExp.Next())
|
for (TopExp_Explorer anExp (aKeySh, aSubType); anExp.More(); anExp.Next())
|
||||||
{
|
{
|
||||||
if (!aSubshapeKeyshapeMap.IsBound (anExp.Current()))
|
if (!aSubshapeKeyshapeMap.IsBound (anExp.Current()))
|
||||||
{
|
{
|
||||||
aSubshapeKeyshapeMap.Bind (anExp.Current(), aSh);
|
aSubshapeKeyshapeMap.Bind (anExp.Current(), aKeySh);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -66,24 +66,6 @@ is
|
|||||||
-- shape - style correspondence
|
-- shape - style correspondence
|
||||||
-- The location <loc> is for internal use, it
|
-- The location <loc> is for internal use, it
|
||||||
-- should be Null location for external call
|
-- should be Null location for external call
|
||||||
|
|
||||||
DispatchStyles (shape: Shape from TopoDS;
|
|
||||||
settings: DataMapOfShapeStyle from XCAFPrs;
|
|
||||||
items: in out DataMapOfStyleShape from XCAFPrs;
|
|
||||||
DefStyle: Style from XCAFPrs;
|
|
||||||
force: Boolean = Standard_True;
|
|
||||||
context: ShapeEnum from TopAbs = TopAbs_SHAPE)
|
|
||||||
returns Boolean;
|
|
||||||
---Purpose: Iterates on shape (recursively) and splits it
|
|
||||||
-- on parts each of which has its own style
|
|
||||||
-- (basing on settings collected by CollectStyleSettings())
|
|
||||||
-- The DefStyle is default style applied to a shape if
|
|
||||||
-- no specific style assignment is applied to it
|
|
||||||
-- If force is True, the <shape> is added to a map
|
|
||||||
-- even if no styles are redefined for it or its
|
|
||||||
-- subshapes
|
|
||||||
-- The context is for internal use, it indicates
|
|
||||||
-- the type of the shape to which <shape> belongs
|
|
||||||
|
|
||||||
SetViewNameMode ( viewNameMode: Boolean from Standard);
|
SetViewNameMode ( viewNameMode: Boolean from Standard);
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#include <TopLoc_IndexedMapOfLocation.hxx>
|
#include <TopLoc_IndexedMapOfLocation.hxx>
|
||||||
#include <TDF_AttributeSequence.hxx>
|
#include <TDF_AttributeSequence.hxx>
|
||||||
#include <XCAFDoc_GraphNode.hxx>
|
#include <XCAFDoc_GraphNode.hxx>
|
||||||
|
#include <XCAFPrs_Style.hxx>
|
||||||
|
|
||||||
static Standard_Boolean viewnameMode = Standard_False;
|
static Standard_Boolean viewnameMode = Standard_False;
|
||||||
|
|
||||||
@ -212,75 +213,6 @@ void XCAFPrs::CollectStyleSettings (const TDF_Label &L,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
|
||||||
//function : DispatchStyles
|
|
||||||
//purpose : fill items map (style - shape)
|
|
||||||
//=======================================================================
|
|
||||||
|
|
||||||
// merge style with father (to reflect inheritance)
|
|
||||||
static Standard_Boolean MergeStyles (XCAFPrs_Style &style, const XCAFPrs_Style &father)
|
|
||||||
{
|
|
||||||
if ( ! style.IsSetColorCurv() && father.IsSetColorCurv() )
|
|
||||||
style.SetColorCurv ( father.GetColorCurv() );
|
|
||||||
if ( ! style.IsSetColorSurf() && father.IsSetColorSurf() )
|
|
||||||
style.SetColorSurf ( father.GetColorSurf() );
|
|
||||||
return style == father;
|
|
||||||
}
|
|
||||||
|
|
||||||
Standard_Boolean XCAFPrs::DispatchStyles (const TopoDS_Shape &shape,
|
|
||||||
const XCAFPrs_DataMapOfShapeStyle &settings,
|
|
||||||
XCAFPrs_DataMapOfStyleShape &items,
|
|
||||||
const XCAFPrs_Style &DefStyle,
|
|
||||||
const Standard_Boolean force,
|
|
||||||
const TopAbs_ShapeEnum context)
|
|
||||||
{
|
|
||||||
const XCAFPrs_Style *style = &DefStyle;
|
|
||||||
XCAFPrs_Style ownstyle;
|
|
||||||
|
|
||||||
// check own setting of current shape
|
|
||||||
Standard_Boolean overriden = Standard_False;
|
|
||||||
if ( settings.IsBound ( shape ) ) {
|
|
||||||
ownstyle = settings.Find ( shape );
|
|
||||||
if ( ! MergeStyles ( ownstyle, DefStyle ) ) {
|
|
||||||
overriden = Standard_True;
|
|
||||||
style = &ownstyle;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// iterate on subshapes
|
|
||||||
BRep_Builder B;
|
|
||||||
TopoDS_Shape copy = shape.EmptyCopied();
|
|
||||||
copy.Closed (shape.Closed());
|
|
||||||
Standard_Boolean suboverride = Standard_False;
|
|
||||||
Standard_Integer nbDef = 0;
|
|
||||||
for ( TopoDS_Iterator it(shape); it.More(); it.Next() ) {
|
|
||||||
if ( DispatchStyles ( it.Value(), settings, items, *style, Standard_False, shape.ShapeType() ) ) {
|
|
||||||
suboverride = Standard_True;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
B.Add ( copy, it.Value() );
|
|
||||||
nbDef++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ( shape.ShapeType() == TopAbs_FACE || ! suboverride )
|
|
||||||
copy = shape;
|
|
||||||
else if ( ! nbDef ) return overriden || suboverride; // avoid empty compounds
|
|
||||||
|
|
||||||
// if any of styles is overriden regarding to default one, add rest to map
|
|
||||||
if ( overriden || force ||
|
|
||||||
( suboverride && context != TopAbs_FACE ) ) { // avoid drawing edges of the same color as face
|
|
||||||
TopoDS_Compound C;
|
|
||||||
if ( items.IsBound ( *style ) )
|
|
||||||
C = TopoDS::Compound ( items.Find ( *style ) );
|
|
||||||
else {
|
|
||||||
B.MakeCompound ( C );
|
|
||||||
items.Bind ( *style, C );
|
|
||||||
}
|
|
||||||
B.Add ( C, copy );
|
|
||||||
}
|
|
||||||
return overriden || suboverride;
|
|
||||||
}
|
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : SetViewNameMode
|
//function : SetViewNameMode
|
||||||
//purpose :
|
//purpose :
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
#include <XCAFPrs_AISObject.hxx>
|
#include <XCAFPrs_AISObject.hxx>
|
||||||
|
|
||||||
#include <AIS_DisplayMode.hxx>
|
#include <AIS_DisplayMode.hxx>
|
||||||
|
#include <BRep_Builder.hxx>
|
||||||
#include <BRepBndLib.hxx>
|
#include <BRepBndLib.hxx>
|
||||||
#include <gp_Pnt.hxx>
|
#include <gp_Pnt.hxx>
|
||||||
#include <Graphic3d_AspectFillArea3d.hxx>
|
#include <Graphic3d_AspectFillArea3d.hxx>
|
||||||
@ -151,11 +152,40 @@ void XCAFPrs_AISObject::Compute (const Handle(PrsMgr_PresentationManager3d)& the
|
|||||||
|
|
||||||
SetColors (myDrawer, aColorCurv, aColorSurf);
|
SetColors (myDrawer, aColorCurv, aColorSurf);
|
||||||
|
|
||||||
// Set colors etc. for current shape according to style
|
// collect sub-shapes with the same style into compounds
|
||||||
for (XCAFPrs_DataMapIteratorOfDataMapOfShapeStyle anIter( aSettings ); anIter.More(); anIter.Next())
|
BRep_Builder aBuilder;
|
||||||
|
NCollection_DataMap<XCAFPrs_Style, TopoDS_Compound, XCAFPrs_Style> aStyleGroups;
|
||||||
|
for (XCAFPrs_DataMapIteratorOfDataMapOfShapeStyle aStyledShapeIter (aSettings);
|
||||||
|
aStyledShapeIter.More(); aStyledShapeIter.Next())
|
||||||
{
|
{
|
||||||
Handle(AIS_ColoredDrawer) aDrawer = CustomAspects (anIter.Key());
|
TopoDS_Compound aComp;
|
||||||
const XCAFPrs_Style& aStyle = anIter.Value();
|
if (aStyleGroups.Find (aStyledShapeIter.Value(), aComp))
|
||||||
|
{
|
||||||
|
aBuilder.Add (aComp, aStyledShapeIter.Key());
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
aBuilder.MakeCompound (aComp);
|
||||||
|
aBuilder.Add (aComp, aStyledShapeIter.Key());
|
||||||
|
aStyleGroups.Bind (aStyledShapeIter.Value(), aComp);
|
||||||
|
}
|
||||||
|
aSettings.Clear();
|
||||||
|
|
||||||
|
// assign custom aspects
|
||||||
|
for (NCollection_DataMap<XCAFPrs_Style, TopoDS_Compound, XCAFPrs_Style>::Iterator aStyleGroupIter (aStyleGroups);
|
||||||
|
aStyleGroupIter.More(); aStyleGroupIter.Next())
|
||||||
|
{
|
||||||
|
const TopoDS_Compound& aComp = aStyleGroupIter.Value();
|
||||||
|
TopoDS_Iterator aShapeIter (aComp);
|
||||||
|
TopoDS_Shape aShape = aShapeIter.Value();
|
||||||
|
aShapeIter.Next();
|
||||||
|
if (aShapeIter.More())
|
||||||
|
{
|
||||||
|
aShape = aComp;
|
||||||
|
}
|
||||||
|
|
||||||
|
Handle(AIS_ColoredDrawer) aDrawer = CustomAspects (aShape);
|
||||||
|
const XCAFPrs_Style& aStyle = aStyleGroupIter.Key();
|
||||||
aDrawer->SetHidden (!aStyle.IsVisible());
|
aDrawer->SetHidden (!aStyle.IsVisible());
|
||||||
|
|
||||||
aColorCurv = aStyle.IsSetColorCurv() ? aStyle.GetColorCurv() : aDefStyle.GetColorCurv();
|
aColorCurv = aStyle.IsSetColorCurv() ? aStyle.GetColorCurv() : aDefStyle.GetColorCurv();
|
||||||
@ -163,6 +193,7 @@ void XCAFPrs_AISObject::Compute (const Handle(PrsMgr_PresentationManager3d)& the
|
|||||||
|
|
||||||
SetColors (aDrawer, aColorCurv, aColorSurf);
|
SetColors (aDrawer, aColorCurv, aColorSurf);
|
||||||
}
|
}
|
||||||
|
aStyleGroups.Clear();
|
||||||
|
|
||||||
AIS_ColoredShape::Compute (thePresentationManager, thePrs, theMode);
|
AIS_ColoredShape::Compute (thePresentationManager, thePrs, theMode);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user