1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-05 18:16:23 +03:00

0025436: Visualization - AIS_InteractiveContext::HilightPreviousDetected() should switch from first value in the list to the last

This commit is contained in:
isk 2014-11-12 14:27:50 +03:00 committed by bugmaster
parent 8cf06aa236
commit 4ca4bbe8bd
4 changed files with 84 additions and 1 deletions

View File

@ -1455,9 +1455,10 @@ Standard_Integer AIS_LocalContext::HilightPreviousDetected (const Handle(V3d_Vie
return 0; return 0;
} }
const Standard_Integer aLen = myDetectedSeq.Length();
if (--myCurDetected < 1) if (--myCurDetected < 1)
{ {
myCurDetected = 1; myCurDetected = aLen;
} }
Handle(SelectMgr_EntityOwner) anOwner = myMainVS->Picked (myDetectedSeq (myCurDetected)); Handle(SelectMgr_EntityOwner) anOwner = myMainVS->Picked (myDetectedSeq (myCurDetected));
if (anOwner.IsNull()) if (anOwner.IsNull())

View File

@ -4256,6 +4256,51 @@ static Standard_Integer VSetSelectionMode (Draw_Interpretor& /*di*/,
return 0; return 0;
} }
//===============================================================================================
//function : VSelectionNext
//purpose :
//===============================================================================================
static Standard_Integer VSelectionNext(Draw_Interpretor& /*theDI*/,
Standard_Integer /*theArgsNb*/,
const char** /*theArgVec*/)
{
// Check errors
Handle(AIS_InteractiveContext) anAISContext = ViewerTest::GetAISContext();
Handle(V3d_View) aView = ViewerTest::CurrentView();
if (anAISContext.IsNull())
{
std::cerr << "Call vinit before!" << std::endl;
return 1;
}
anAISContext->HilightNextDetected(aView);
return 0;
}
//===============================================================================================
//function : VSelectionPrevious
//purpose :
//===============================================================================================
static Standard_Integer VSelectionPrevious(Draw_Interpretor& /*theDI*/,
Standard_Integer /*theArgsNb*/,
const char** /*theArgVec*/)
{
// Check errors
Handle(AIS_InteractiveContext) anAISContext = ViewerTest::GetAISContext();
Handle(V3d_View) aView = ViewerTest::CurrentView();
if (anAISContext.IsNull())
{
std::cerr << "Call vinit before!" << std::endl;
return 1;
}
anAISContext->HilightPreviousDetected(aView);
return 0;
}
//========================================================================== //==========================================================================
//class : Triangle //class : Triangle
//purpose : creates Triangle based on AIS_InteractiveObject. //purpose : creates Triangle based on AIS_InteractiveObject.
@ -5983,6 +6028,14 @@ void ViewerTest::ObjectCommands(Draw_Interpretor& theCommands)
" 0 if mode is to be switched off\n", " 0 if mode is to be switched off\n",
__FILE__, VSetSelectionMode, group); __FILE__, VSetSelectionMode, group);
theCommands.Add("vselnext",
"vselnext : hilight next detected",
__FILE__, VSelectionNext, group);
theCommands.Add("vselprev",
"vselnext : hilight previous detected",
__FILE__, VSelectionPrevious, group);
theCommands.Add("vtriangle", theCommands.Add("vtriangle",
"vtriangle Name PointName PointName PointName", "vtriangle Name PointName PointName PointName",
__FILE__, VTriangle,group); __FILE__, VTriangle,group);

View File

@ -2013,6 +2013,16 @@ static LRESULT WINAPI ViewerWindowProc( HWND hwnd,
{ {
c[0] = THE_KEY_DELETE; c[0] = THE_KEY_DELETE;
} }
// comma
else if (wParam == VK_OEM_COMMA)
{
c[0] = ',';
}
// dot
else if (wParam == VK_OEM_PERIOD)
{
c[0] = '.';
}
VT_ProcessKeyPress (c); VT_ProcessKeyPress (c);
} }
break; break;

19
tests/v3d/edge/A10 Normal file
View File

@ -0,0 +1,19 @@
puts "============"
puts "CR25436"
puts "Test case check work of the new commands vselnext and vselprev"
puts "============"
puts ""
box b 10 10 10
vdisplay b
vfit
vselmode 2 1
vmoveto 30 101
vselnext
vselnext
vselnext
vselprev
vselprev
vselprev