1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0028365: Visualization, AIS_InteractiveContext - apply selection filter in AddOrRemoveSelected at Neutral point

This commit is contained in:
nds 2017-01-26 17:16:09 +03:00 committed by apn
parent 650efe05be
commit 4d901cde7c
3 changed files with 87 additions and 0 deletions

View File

@ -1183,6 +1183,9 @@ void AIS_InteractiveContext::AddOrRemoveSelected (const Handle(SelectMgr_EntityO
if (theOwner.IsNull() || !theOwner->HasSelectable())
return;
if (!myFilters->IsOk(theOwner) && !theOwner->IsSelected())
return;
AIS_SelectStatus aSelStat = mySelection->Select (theOwner);
theOwner->SetSelected (aSelStat == AIS_SS_Added);
const Handle(AIS_InteractiveObject) anObj =

View File

@ -4947,6 +4947,62 @@ static int VPickShape( Draw_Interpretor& di, Standard_Integer argc, const char**
return 0;
}
//=======================================================================
//function : VSetFilter
//purpose :
//=======================================================================
static int VSetFilter(Draw_Interpretor& theDi, Standard_Integer theArgc,
const char** theArgv)
{
if (theArgc != 2)
{
theDi << theArgv[0] << " error : wrong number of parameters.\n";
return 1;
}
Handle(AIS_InteractiveContext) aContext = ViewerTest::GetAISContext();
if (aContext.IsNull())
{
std::cout << "Error: AIS context is not available.\n";
return 1;
}
TCollection_AsciiString anArg(theArgv[1]);
if (anArg.IsEqual("-clear")) {
aContext->RemoveFilters();
}
else {
TCollection_AsciiString aPName, aPValue;
if (!ViewerTest::SplitParameter (anArg, aPName, aPValue)) {
std::cout << "Error: wrong command attribute name" << std::endl;
return 1;
}
TopAbs_ShapeEnum aType = TopAbs_COMPOUND;
if(aPValue.IsEqual("VERTEX")) aType = TopAbs_VERTEX;
else if (aPValue.IsEqual("EDGE")) aType = TopAbs_EDGE;
else if (aPValue.IsEqual("WIRE")) aType = TopAbs_WIRE;
else if (aPValue.IsEqual("FACE")) aType = TopAbs_FACE;
else if(aPValue.IsEqual("SHAPE")) aType = TopAbs_SHAPE;
else if (aPValue.IsEqual("SHELL")) aType = TopAbs_SHELL;
else if (aPValue.IsEqual("SOLID")) aType = TopAbs_SOLID;
else {
std::cout << "Error: wrong command attribute value" << std::endl;
return 1;
}
if(aType==TopAbs_SHAPE){
Handle(AIS_TypeFilter) aFilter = new AIS_TypeFilter(AIS_KOI_Shape);
aContext->AddFilter(aFilter);
}
else{
Handle(StdSelect_ShapeTypeFilter) aFilter = new StdSelect_ShapeTypeFilter(aType);
aContext->AddFilter(aFilter);
}
}
return 0;
}
//=======================================================================
//function : VPickSelected
//purpose :
@ -5839,6 +5895,13 @@ void ViewerTest::Commands(Draw_Interpretor& theCommands)
"\n\t\t: Reads shape from BREP-format file and displays it in the viewer. ",
__FILE__,vr, group);
theCommands.Add("vsetfilter",
"vsetfilter [-type={VERTEX|EDGE|WIRE|FACE|SHAPE|SHELL|SOLID}] [-clear]"
"\nSets selection shape type filter in context or remove all filters."
"\n : Option -type set type of selection filter. Filters are applyed with Or combination."
"\n : Option -clear remove all filters in context",
__FILE__,VSetFilter,group);
theCommands.Add("vpickselected", "vpickselected [name]: extract selected shape.",
__FILE__, VPickSelected, group);

21
tests/bugs/vis/bug28365 Normal file
View File

@ -0,0 +1,21 @@
puts "==========="
puts "OCC28365"
puts "==========="
puts ""
##########################################################################
# Visualization, AIS_InteractiveContext - apply selection filter in
# AddOrRemoveSelected at Neutral point
##########################################################################
pload ALL
vinit
box b 10 10 10
vdisplay b
vfit
vsetfilter -type=VERTEX
vchangeselected b
set NbSelected1 [vnbselected]
if { ${NbSelected1} != 0 } {
puts "Error : Vertex filter was not applyed"
}