mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-06 18:26:22 +03:00
0023951: Visibility of free, simple shapes not saved when writing XCAF Document into STEP
Delete check for top-level shape during writing invisibility property. Added QA command OCC23951. Fix crash in QA command OCC23951: initialize document, initialize shape. Added test case bugs/xde/bug23951 Modified QABugs/QABugs_19.cxx to avoid warnings
This commit is contained in:
parent
70167e6982
commit
574d723693
@ -1735,6 +1735,38 @@ struct QABugs_NHandleClass
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#include <XCAFDoc_ColorTool.hxx>
|
||||||
|
#include <STEPControl_StepModelType.hxx>
|
||||||
|
#include <STEPCAFControl_Writer.hxx>
|
||||||
|
static Standard_Integer OCC23951 (Draw_Interpretor& di, Standard_Integer argc, const char ** argv)
|
||||||
|
{
|
||||||
|
if (argc != 1) {
|
||||||
|
di << "Usage: " << argv[0] << " invalid number of arguments" << "\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
Handle(TDocStd_Document) aDoc = new TDocStd_Document("dummy");;
|
||||||
|
TopoDS_Shape s1 = BRepPrimAPI_MakeBox(1,1,1).Shape();
|
||||||
|
TDF_Label lab1 = XCAFDoc_DocumentTool::ShapeTool (aDoc->Main ())->NewShape();
|
||||||
|
XCAFDoc_DocumentTool::ShapeTool (aDoc->Main ())->SetShape(lab1, s1);
|
||||||
|
TDataStd_Name::Set(lab1, "Box1");
|
||||||
|
|
||||||
|
Quantity_Color yellow(1,1,0, Quantity_TOC_RGB);
|
||||||
|
XCAFDoc_DocumentTool::ColorTool (aDoc->Main())->SetColor(lab1, yellow, XCAFDoc_ColorGen);
|
||||||
|
XCAFDoc_DocumentTool::ColorTool(aDoc->Main())->SetVisibility(lab1, 0);
|
||||||
|
|
||||||
|
STEPControl_StepModelType mode = STEPControl_AsIs;
|
||||||
|
STEPCAFControl_Writer writer;
|
||||||
|
if ( ! writer.Transfer (aDoc, mode ) )
|
||||||
|
{
|
||||||
|
di << "The document cannot be translated or gives no result" << "\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
writer.Write("test_box.step");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : OCC24622
|
//function : OCC24622
|
||||||
//purpose : The command tests sourcing Image_PixMap to AIS_TexturedShape
|
//purpose : The command tests sourcing Image_PixMap to AIS_TexturedShape
|
||||||
@ -2277,6 +2309,7 @@ void QABugs::Commands_19(Draw_Interpretor& theCommands) {
|
|||||||
theCommands.Add ("OCC24565", "OCC24565 FileNameIGS FileNameSTOR", __FILE__, OCC24565, group);
|
theCommands.Add ("OCC24565", "OCC24565 FileNameIGS FileNameSTOR", __FILE__, OCC24565, group);
|
||||||
theCommands.Add ("OCC24755", "OCC24755", __FILE__, OCC24755, group);
|
theCommands.Add ("OCC24755", "OCC24755", __FILE__, OCC24755, group);
|
||||||
theCommands.Add ("OCC24834", "OCC24834", __FILE__, OCC24834, group);
|
theCommands.Add ("OCC24834", "OCC24834", __FILE__, OCC24834, group);
|
||||||
|
theCommands.Add ("OCC23951", "OCC23951", __FILE__, OCC23951, group);
|
||||||
theCommands.Add ("OCC24931", "OCC24931", __FILE__, OCC24931, group);
|
theCommands.Add ("OCC24931", "OCC24931", __FILE__, OCC24931, group);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1079,7 +1079,7 @@ Standard_Boolean STEPCAFControl_Writer::WriteColors (const Handle(XSControl_Work
|
|||||||
TDF_Label lab = seq.Value(j);
|
TDF_Label lab = seq.Value(j);
|
||||||
XCAFPrs_Style style;
|
XCAFPrs_Style style;
|
||||||
Quantity_Color C;
|
Quantity_Color C;
|
||||||
if ( isComponent && lab == L ) {
|
if ( lab == L ) {
|
||||||
// check for invisible status of object on label
|
// check for invisible status of object on label
|
||||||
if ( !CTool->IsVisible( lab ) ) {
|
if ( !CTool->IsVisible( lab ) ) {
|
||||||
isVisible = Standard_False;
|
isVisible = Standard_False;
|
||||||
@ -1167,28 +1167,28 @@ Standard_Boolean STEPCAFControl_Writer::WriteColors (const Handle(XSControl_Work
|
|||||||
newItems->SetValue( el++, Handle(StepRepr_RepresentationItem)::DownCast(Styles.Style(si)));
|
newItems->SetValue( el++, Handle(StepRepr_RepresentationItem)::DownCast(Styles.Style(si)));
|
||||||
// WP->Model()->AddWithRefs ( Handle(StepRepr_RepresentationItem)::DownCast (Styles.Style(si)));
|
// WP->Model()->AddWithRefs ( Handle(StepRepr_RepresentationItem)::DownCast (Styles.Style(si)));
|
||||||
}
|
}
|
||||||
if ( !isVisible ) {
|
|
||||||
// create invisibility item and refer for stiledItem
|
|
||||||
Handle(StepVisual_Invisibility) Invsblt = new StepVisual_Invisibility();
|
|
||||||
Handle(StepVisual_HArray1OfInvisibleItem) HInvsblItm =
|
|
||||||
new StepVisual_HArray1OfInvisibleItem (1,Styles.NbStyles());
|
|
||||||
// put all style item into the harray
|
|
||||||
for ( si=1; si <= Styles.NbStyles(); si++ ) {
|
|
||||||
Handle(StepRepr_RepresentationItem) styledItm =
|
|
||||||
Handle(StepRepr_RepresentationItem)::DownCast(Styles.Style(si));
|
|
||||||
StepVisual_InvisibleItem anInvItem;
|
|
||||||
anInvItem.SetValue( styledItm );
|
|
||||||
HInvsblItm->SetValue( si, anInvItem );
|
|
||||||
}
|
|
||||||
// set the invisibility of items
|
|
||||||
Invsblt->Init( HInvsblItm );
|
|
||||||
WS->Model()->AddWithRefs( Invsblt );
|
|
||||||
}
|
|
||||||
|
|
||||||
if (newItems->Length() > 0)
|
if (newItems->Length() > 0)
|
||||||
aMDGPR->SetItems( newItems );
|
aMDGPR->SetItems( newItems );
|
||||||
} //end of work with CDSR
|
} //end of work with CDSR
|
||||||
}
|
}
|
||||||
|
if ( !isVisible ) {
|
||||||
|
// create invisibility item and refer for stiledItem
|
||||||
|
Handle(StepVisual_Invisibility) Invsblt = new StepVisual_Invisibility();
|
||||||
|
Handle(StepVisual_HArray1OfInvisibleItem) HInvsblItm =
|
||||||
|
new StepVisual_HArray1OfInvisibleItem (1,Styles.NbStyles());
|
||||||
|
// put all style item into the harray
|
||||||
|
for ( Standard_Integer si=1; si <= Styles.NbStyles(); si++ ) {
|
||||||
|
Handle(StepRepr_RepresentationItem) styledItm =
|
||||||
|
Handle(StepRepr_RepresentationItem)::DownCast(Styles.Style(si));
|
||||||
|
StepVisual_InvisibleItem anInvItem;
|
||||||
|
anInvItem.SetValue( styledItm );
|
||||||
|
HInvsblItm->SetValue( si, anInvItem );
|
||||||
|
}
|
||||||
|
// set the invisibility of items
|
||||||
|
Invsblt->Init( HInvsblItm );
|
||||||
|
WS->Model()->AddWithRefs( Invsblt );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return Standard_True;
|
return Standard_True;
|
||||||
|
23
tests/bugs/xde/bug23951
Normal file
23
tests/bugs/xde/bug23951
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
puts "=========="
|
||||||
|
puts "OCC23951"
|
||||||
|
puts "=========="
|
||||||
|
puts ""
|
||||||
|
#####################################################################################
|
||||||
|
# Visibility of free, simple shapes not saved when writing XCAF Document info STEP
|
||||||
|
#####################################################################################
|
||||||
|
|
||||||
|
pload QAcommands
|
||||||
|
|
||||||
|
set info [OCC23951]
|
||||||
|
|
||||||
|
if { [regexp "Write Done" $info] != 1 } {
|
||||||
|
puts "Error: file was not written"
|
||||||
|
} else {
|
||||||
|
puts "OK: file was written"
|
||||||
|
}
|
||||||
|
|
||||||
|
stepread test_box.step a *
|
||||||
|
axo
|
||||||
|
fit
|
||||||
|
|
||||||
|
set only_screen_axo 1
|
Loading…
x
Reference in New Issue
Block a user