mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-06 18:26:22 +03:00
0030464: Visualization - unable to set sub-shape transparency using vaspects command
Added AIS_ColoredShape::SetCustomTransparency() for simple way for assigning sub-shape transparency.
This commit is contained in:
parent
82d23ad590
commit
c1197a1575
@ -27,6 +27,7 @@ public:
|
|||||||
AIS_ColoredDrawer (const Handle(Prs3d_Drawer)& theLink)
|
AIS_ColoredDrawer (const Handle(Prs3d_Drawer)& theLink)
|
||||||
: myIsHidden (false),
|
: myIsHidden (false),
|
||||||
myHasOwnColor (false),
|
myHasOwnColor (false),
|
||||||
|
myHasOwnTransp(false),
|
||||||
myHasOwnWidth (false)
|
myHasOwnWidth (false)
|
||||||
{
|
{
|
||||||
Link (theLink);
|
Link (theLink);
|
||||||
@ -34,9 +35,15 @@ public:
|
|||||||
|
|
||||||
bool IsHidden() const { return myIsHidden; }
|
bool IsHidden() const { return myIsHidden; }
|
||||||
void SetHidden (const bool theToHide) { myIsHidden = theToHide;}
|
void SetHidden (const bool theToHide) { myIsHidden = theToHide;}
|
||||||
|
|
||||||
bool HasOwnColor() const { return myHasOwnColor; }
|
bool HasOwnColor() const { return myHasOwnColor; }
|
||||||
void UnsetOwnColor() { myHasOwnColor = false; }
|
void UnsetOwnColor() { myHasOwnColor = false; }
|
||||||
void SetOwnColor (const Quantity_Color& /*theColor*/) { myHasOwnColor = true; }
|
void SetOwnColor (const Quantity_Color& /*theColor*/) { myHasOwnColor = true; }
|
||||||
|
|
||||||
|
bool HasOwnTransparency() const { return myHasOwnTransp; }
|
||||||
|
void UnsetOwnTransparency() { myHasOwnTransp = false; }
|
||||||
|
void SetOwnTransparency (Standard_Real /*theTransp*/) { myHasOwnTransp = true; }
|
||||||
|
|
||||||
bool HasOwnWidth() const { return myHasOwnWidth; }
|
bool HasOwnWidth() const { return myHasOwnWidth; }
|
||||||
void UnsetOwnWidth() { myHasOwnWidth = false; }
|
void UnsetOwnWidth() { myHasOwnWidth = false; }
|
||||||
void SetOwnWidth (const Standard_Real /*theWidth*/) { myHasOwnWidth = true; }
|
void SetOwnWidth (const Standard_Real /*theWidth*/) { myHasOwnWidth = true; }
|
||||||
@ -45,6 +52,7 @@ public: //! @name list of overridden properties
|
|||||||
|
|
||||||
bool myIsHidden;
|
bool myIsHidden;
|
||||||
bool myHasOwnColor;
|
bool myHasOwnColor;
|
||||||
|
bool myHasOwnTransp;
|
||||||
bool myHasOwnWidth;
|
bool myHasOwnWidth;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -187,6 +187,25 @@ void AIS_ColoredShape::SetCustomColor (const TopoDS_Shape& theShape,
|
|||||||
LoadRecomputable (AIS_Shaded);
|
LoadRecomputable (AIS_Shaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=======================================================================
|
||||||
|
//function : SetCustomTransparency
|
||||||
|
//purpose :
|
||||||
|
//=======================================================================
|
||||||
|
void AIS_ColoredShape::SetCustomTransparency (const TopoDS_Shape& theShape,
|
||||||
|
Standard_Real theTransparency)
|
||||||
|
{
|
||||||
|
if (theShape.IsNull())
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const Handle(AIS_ColoredDrawer)& aDrawer = CustomAspects (theShape);
|
||||||
|
setTransparency (aDrawer, theTransparency);
|
||||||
|
aDrawer->SetOwnTransparency (theTransparency);
|
||||||
|
LoadRecomputable (AIS_WireFrame);
|
||||||
|
LoadRecomputable (AIS_Shaded);
|
||||||
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : SetCustomWidth
|
//function : SetCustomWidth
|
||||||
//purpose :
|
//purpose :
|
||||||
@ -200,7 +219,7 @@ void AIS_ColoredShape::SetCustomWidth (const TopoDS_Shape& theShape,
|
|||||||
}
|
}
|
||||||
|
|
||||||
const Handle(AIS_ColoredDrawer)& aDrawer = CustomAspects (theShape);
|
const Handle(AIS_ColoredDrawer)& aDrawer = CustomAspects (theShape);
|
||||||
setWidth (CustomAspects (theShape), theLineWidth);
|
setWidth (aDrawer, theLineWidth);
|
||||||
aDrawer->SetOwnWidth (theLineWidth);
|
aDrawer->SetOwnWidth (theLineWidth);
|
||||||
LoadRecomputable (AIS_WireFrame);
|
LoadRecomputable (AIS_WireFrame);
|
||||||
LoadRecomputable (AIS_Shaded);
|
LoadRecomputable (AIS_Shaded);
|
||||||
@ -292,7 +311,12 @@ void AIS_ColoredShape::SetTransparency (const Standard_Real theValue)
|
|||||||
LoadRecomputable (AIS_Shaded);
|
LoadRecomputable (AIS_Shaded);
|
||||||
for (AIS_DataMapOfShapeDrawer::Iterator anIter (myShapeColors); anIter.More(); anIter.Next())
|
for (AIS_DataMapOfShapeDrawer::Iterator anIter (myShapeColors); anIter.More(); anIter.Next())
|
||||||
{
|
{
|
||||||
const Handle(Prs3d_Drawer)& aDrawer = anIter.Value();
|
const Handle(AIS_ColoredDrawer)& aDrawer = anIter.Value();
|
||||||
|
if (aDrawer->HasOwnTransparency())
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (aDrawer->HasOwnShadingAspect())
|
if (aDrawer->HasOwnShadingAspect())
|
||||||
{
|
{
|
||||||
aDrawer->ShadingAspect()->SetTransparency (theValue, myCurrentFacingModel);
|
aDrawer->ShadingAspect()->SetTransparency (theValue, myCurrentFacingModel);
|
||||||
@ -346,7 +370,7 @@ void AIS_ColoredShape::SetMaterial (const Graphic3d_MaterialAspect& theMaterial)
|
|||||||
//if (aDrawer->HasOwnMaterial()) continue;
|
//if (aDrawer->HasOwnMaterial()) continue;
|
||||||
if (aDrawer->HasOwnShadingAspect())
|
if (aDrawer->HasOwnShadingAspect())
|
||||||
{
|
{
|
||||||
setMaterial (aDrawer, theMaterial, aDrawer->HasOwnColor(), Standard_False); // aDrawer->IsTransparent()
|
setMaterial (aDrawer, theMaterial, aDrawer->HasOwnColor(), aDrawer->HasOwnTransparency());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -715,13 +739,29 @@ Standard_Boolean AIS_ColoredShape::dispatchColors (const Handle(AIS_ColoredDrawe
|
|||||||
{
|
{
|
||||||
const TopoDS_Shape& aFace = aFaceIter.Value();
|
const TopoDS_Shape& aFace = aFaceIter.Value();
|
||||||
Handle(AIS_ColoredDrawer) aFaceDrawer;
|
Handle(AIS_ColoredDrawer) aFaceDrawer;
|
||||||
if (aFace.ShapeType() == TopAbs_FACE
|
if (aFace.ShapeType() != TopAbs_FACE
|
||||||
&& theShapeDrawerMap.Find (aFace, aFaceDrawer)
|
|| !theShapeDrawerMap.Find (aFace, aFaceDrawer))
|
||||||
&& aFaceDrawer->IsHidden())
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (aFaceDrawer->IsHidden())
|
||||||
{
|
{
|
||||||
isClosedShell = Standard_False;
|
isClosedShell = Standard_False;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
else if (aFaceDrawer->HasOwnShadingAspect()
|
||||||
|
&& aFaceDrawer->ShadingAspect()->Aspect()->AlphaMode() != Graphic3d_AlphaMode_Opaque)
|
||||||
|
{
|
||||||
|
if (aFaceDrawer->ShadingAspect()->Aspect()->AlphaMode() != Graphic3d_AlphaMode_BlendAuto
|
||||||
|
|| aFaceDrawer->ShadingAspect()->Aspect()->FrontMaterial().Alpha() < 1.0f
|
||||||
|
|| (aFaceDrawer->ShadingAspect()->Aspect()->Distinguish()
|
||||||
|
&& aFaceDrawer->ShadingAspect()->Aspect()->BackMaterial().Alpha() < 1.0f))
|
||||||
|
{
|
||||||
|
isClosedShell = Standard_False;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,6 +56,10 @@ public: //! @name sub-shape aspects
|
|||||||
Standard_EXPORT void SetCustomColor (const TopoDS_Shape& theShape,
|
Standard_EXPORT void SetCustomColor (const TopoDS_Shape& theShape,
|
||||||
const Quantity_Color& theColor);
|
const Quantity_Color& theColor);
|
||||||
|
|
||||||
|
//! Customize transparency of specified sub-shape
|
||||||
|
Standard_EXPORT void SetCustomTransparency (const TopoDS_Shape& theShape,
|
||||||
|
Standard_Real theTransparency);
|
||||||
|
|
||||||
//! Customize line width of specified sub-shape
|
//! Customize line width of specified sub-shape
|
||||||
Standard_EXPORT void SetCustomWidth (const TopoDS_Shape& theShape,
|
Standard_EXPORT void SetCustomWidth (const TopoDS_Shape& theShape,
|
||||||
const Standard_Real theLineWidth);
|
const Standard_Real theLineWidth);
|
||||||
|
@ -1709,7 +1709,7 @@ struct ViewerTest_AspectsChangeSet
|
|||||||
}
|
}
|
||||||
|
|
||||||
//! @return true if properties are valid
|
//! @return true if properties are valid
|
||||||
Standard_Boolean Validate (const Standard_Boolean theIsSubPart) const
|
Standard_Boolean Validate() const
|
||||||
{
|
{
|
||||||
Standard_Boolean isOk = Standard_True;
|
Standard_Boolean isOk = Standard_True;
|
||||||
if (Visibility != 0 && Visibility != 1)
|
if (Visibility != 0 && Visibility != 1)
|
||||||
@ -1729,12 +1729,6 @@ struct ViewerTest_AspectsChangeSet
|
|||||||
std::cout << "Error: the transparency should be within [0; 1] range (specified " << Transparency << ")\n";
|
std::cout << "Error: the transparency should be within [0; 1] range (specified " << Transparency << ")\n";
|
||||||
isOk = Standard_False;
|
isOk = Standard_False;
|
||||||
}
|
}
|
||||||
if (theIsSubPart
|
|
||||||
&& ToSetTransparency != 0)
|
|
||||||
{
|
|
||||||
std::cout << "Error: the transparency can not be defined for sub-part of object!\n";
|
|
||||||
isOk = Standard_False;
|
|
||||||
}
|
|
||||||
if (ToSetAlphaMode == 1
|
if (ToSetAlphaMode == 1
|
||||||
&& (AlphaCutoff <= 0.0f || AlphaCutoff >= 1.0f))
|
&& (AlphaCutoff <= 0.0f || AlphaCutoff >= 1.0f))
|
||||||
{
|
{
|
||||||
@ -2498,15 +2492,13 @@ static Standard_Integer VAspects (Draw_Interpretor& /*theDI*/,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Standard_Boolean isFirst = Standard_True;
|
|
||||||
for (NCollection_Sequence<ViewerTest_AspectsChangeSet>::Iterator aChangesIter (aChanges);
|
for (NCollection_Sequence<ViewerTest_AspectsChangeSet>::Iterator aChangesIter (aChanges);
|
||||||
aChangesIter.More(); aChangesIter.Next())
|
aChangesIter.More(); aChangesIter.Next())
|
||||||
{
|
{
|
||||||
if (!aChangesIter.Value().Validate (!isFirst))
|
if (!aChangesIter.Value().Validate())
|
||||||
{
|
{
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
isFirst = Standard_False;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// special case for -defaults parameter.
|
// special case for -defaults parameter.
|
||||||
@ -2823,6 +2815,10 @@ static Standard_Integer VAspects (Draw_Interpretor& /*theDI*/,
|
|||||||
{
|
{
|
||||||
aColoredPrs->SetCustomColor (aSubShape, aChangeSet->Color);
|
aColoredPrs->SetCustomColor (aSubShape, aChangeSet->Color);
|
||||||
}
|
}
|
||||||
|
if (aChangeSet->ToSetTransparency == 1)
|
||||||
|
{
|
||||||
|
aColoredPrs->SetCustomTransparency (aSubShape, aChangeSet->Transparency);
|
||||||
|
}
|
||||||
if (aChangeSet->ToSetLineWidth == 1)
|
if (aChangeSet->ToSetLineWidth == 1)
|
||||||
{
|
{
|
||||||
aColoredPrs->SetCustomWidth (aSubShape, aChangeSet->LineWidth);
|
aColoredPrs->SetCustomWidth (aSubShape, aChangeSet->LineWidth);
|
||||||
|
@ -24,7 +24,7 @@ XShow D_First
|
|||||||
vfit
|
vfit
|
||||||
vsetdispmode 1
|
vsetdispmode 1
|
||||||
vdump $::imagedir/${::casename}_first.png
|
vdump $::imagedir/${::casename}_first.png
|
||||||
if { [vreadpixel 300 200 rgb name] != "GRAY14" } { puts "Error: wrong color in 3D Viewer" }
|
if { [vreadpixel 300 200 rgb name] != "DARKKHAKI" } { puts "Error: wrong color in 3D Viewer" }
|
||||||
|
|
||||||
# Write file
|
# Write file
|
||||||
SaveAs D_First ${imagedir}/bug28521.xbf
|
SaveAs D_First ${imagedir}/bug28521.xbf
|
||||||
@ -83,6 +83,6 @@ XShow D_Second
|
|||||||
vfit
|
vfit
|
||||||
vsetdispmode 1
|
vsetdispmode 1
|
||||||
vdump $::imagedir/${::casename}.png
|
vdump $::imagedir/${::casename}.png
|
||||||
if { [vreadpixel 300 200 rgb name] != "GRAY14" } { puts "Error: wrong color in 3D Viewer" }
|
if { [vreadpixel 300 200 rgb name] != "DARKKHAKI" } { puts "Error: wrong color in 3D Viewer" }
|
||||||
|
|
||||||
Close D_Second
|
Close D_Second
|
||||||
|
Loading…
x
Reference in New Issue
Block a user