mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0033746: Visualization - Unexpected moving with AIS_ViewCube
Fixed angle calculation for view rotation. Added draw command vmousebutton to test mouse button events.
This commit is contained in:
parent
76df27830b
commit
fd4f248da9
@ -1827,12 +1827,26 @@ void AIS_ViewController::handleViewRotation (const Handle(V3d_View)& theView,
|
|||||||
}
|
}
|
||||||
if (myGL.ViewRotation.ToStart)
|
if (myGL.ViewRotation.ToStart)
|
||||||
{
|
{
|
||||||
|
gp_Dir aCamDirection = aCam->Direction();
|
||||||
|
if (aCam->OrthogonalizedUp().IsParallel (gp::DY(), Precision::Angular()))
|
||||||
|
{
|
||||||
|
aCamDirection = aCamDirection.Dot (gp::DZ()) > 0
|
||||||
|
? gp::DZ()
|
||||||
|
: gp::DZ().Reversed();
|
||||||
|
}
|
||||||
|
|
||||||
gp_Trsf aTrsf;
|
gp_Trsf aTrsf;
|
||||||
aTrsf.SetTransformation (gp_Ax3 (gp::Origin(), aCam->OrthogonalizedUp(), aCam->Direction()),
|
aTrsf.SetTransformation (gp_Ax3 (gp::Origin(), aCam->OrthogonalizedUp(), aCamDirection),
|
||||||
gp_Ax3 (gp::Origin(), gp::DZ(), gp::DX()));
|
gp_Ax3 (gp::Origin(), gp::DZ(), gp::DX()));
|
||||||
const gp_Quaternion aRot = aTrsf.GetRotation();
|
const gp_Quaternion aRot = aTrsf.GetRotation();
|
||||||
double aRollDummy = 0.0;
|
double aRollDummy = 0.0;
|
||||||
aRot.GetEulerAngles (gp_YawPitchRoll, myRotateStartYawPitchRoll[0], myRotateStartYawPitchRoll[1], aRollDummy);
|
aRot.GetEulerAngles (gp_YawPitchRoll, myRotateStartYawPitchRoll[0], myRotateStartYawPitchRoll[1], aRollDummy);
|
||||||
|
if (aCamDirection.IsParallel (gp::DZ(), Precision::Angular()))
|
||||||
|
{
|
||||||
|
myRotateStartYawPitchRoll[0] = aCamDirection.IsEqual (gp::DZ(), Precision::Angular())
|
||||||
|
? aRollDummy
|
||||||
|
: -aRollDummy;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (toRotateAnyway)
|
if (toRotateAnyway)
|
||||||
{
|
{
|
||||||
|
@ -857,7 +857,7 @@ public:
|
|||||||
const Graphic3d_BufferType& theBufferType = Graphic3d_BT_RGB,
|
const Graphic3d_BufferType& theBufferType = Graphic3d_BT_RGB,
|
||||||
const Standard_Boolean theToAdjustAspect = Standard_True,
|
const Standard_Boolean theToAdjustAspect = Standard_True,
|
||||||
const Graphic3d_ZLayerId theTargetZLayerId = Graphic3d_ZLayerId_BotOSD,
|
const Graphic3d_ZLayerId theTargetZLayerId = Graphic3d_ZLayerId_BotOSD,
|
||||||
const Standard_Integer theIsSingleLayer = Standard_False,
|
const Standard_Boolean theIsSingleLayer = Standard_False,
|
||||||
const V3d_StereoDumpOptions theStereoOptions = V3d_SDO_MONO,
|
const V3d_StereoDumpOptions theStereoOptions = V3d_SDO_MONO,
|
||||||
const Standard_CString theLightName = "")
|
const Standard_CString theLightName = "")
|
||||||
{
|
{
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// Created on: 1998-09-01
|
// Created on: 1998-09-01
|
||||||
// Created by: Robert COUBLANC
|
// Created by: Robert COUBLANC
|
||||||
// Copyright (c) 1998-1999 Matra Datavision
|
// Copyright (c) 1998-1999 Matra Datavision
|
||||||
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
||||||
@ -6547,6 +6547,106 @@ static Standard_Integer VMoveTo (Draw_Interpretor& theDI,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=======================================================================
|
||||||
|
//function : VMouseButton
|
||||||
|
//purpose : Emulates mouse button event
|
||||||
|
//=======================================================================
|
||||||
|
static Standard_Integer VMouseButton (Draw_Interpretor& /*theDI*/,
|
||||||
|
Standard_Integer theNbArgs,
|
||||||
|
const char** theArgVec)
|
||||||
|
{
|
||||||
|
const Handle(AIS_InteractiveContext)& aContext = ViewerTest::GetAISContext();
|
||||||
|
const Handle(V3d_View)& aView = ViewerTest::CurrentView();
|
||||||
|
if (aContext.IsNull())
|
||||||
|
{
|
||||||
|
Message::SendFail ("Error: no active viewer");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (theNbArgs < 6)
|
||||||
|
{
|
||||||
|
Message::SendFail ("Syntax error: wrong number arguments");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
Aspect_VKeyMouse aButton = Aspect_VKeyMouse_LeftButton;
|
||||||
|
Standard_Boolean isPressButton = false;
|
||||||
|
|
||||||
|
Graphic3d_Vec2i aMousePos (IntegerLast(), IntegerLast());
|
||||||
|
for (Standard_Integer anArgIter = 1; anArgIter < theNbArgs; ++anArgIter)
|
||||||
|
{
|
||||||
|
TCollection_AsciiString anArgStr (theArgVec[anArgIter]);
|
||||||
|
anArgStr.LowerCase();
|
||||||
|
if (anArgStr == "-button")
|
||||||
|
{
|
||||||
|
if (anArgIter + 1 < theNbArgs)
|
||||||
|
{
|
||||||
|
++anArgIter;
|
||||||
|
TCollection_AsciiString aButtonStr (theArgVec[anArgIter]);
|
||||||
|
if (aButtonStr == "left")
|
||||||
|
{
|
||||||
|
aButton = Aspect_VKeyMouse_LeftButton;
|
||||||
|
}
|
||||||
|
else if (aButtonStr == "right")
|
||||||
|
{
|
||||||
|
aButton = Aspect_VKeyMouse_RightButton;
|
||||||
|
}
|
||||||
|
else if (aButtonStr == "middle")
|
||||||
|
{
|
||||||
|
aButton = Aspect_VKeyMouse_MiddleButton;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (anArgStr == "-up")
|
||||||
|
{
|
||||||
|
isPressButton = false;
|
||||||
|
}
|
||||||
|
else if (anArgStr == "-down")
|
||||||
|
{
|
||||||
|
isPressButton = true;
|
||||||
|
}
|
||||||
|
else if (aMousePos.x() == IntegerLast()
|
||||||
|
&& anArgStr.IsIntegerValue())
|
||||||
|
{
|
||||||
|
aMousePos.x() = anArgStr.IntegerValue();
|
||||||
|
}
|
||||||
|
else if (aMousePos.y() == IntegerLast()
|
||||||
|
&& anArgStr.IsIntegerValue())
|
||||||
|
{
|
||||||
|
aMousePos.y() = anArgStr.IntegerValue();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Message::SendFail() << "Syntax error at '" << theArgVec[anArgIter] << "'";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (aMousePos.x() == IntegerLast()
|
||||||
|
|| aMousePos.y() == IntegerLast())
|
||||||
|
{
|
||||||
|
Message::SendFail ("Syntax error: wrong number of arguments");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isPressButton)
|
||||||
|
{
|
||||||
|
ViewerTest::CurrentEventManager()->ResetPreviousMoveTo();
|
||||||
|
ViewerTest::CurrentEventManager()->PressMouseButton (aMousePos, aButton, Aspect_VKeyFlags_NONE, false);
|
||||||
|
ViewerTest::CurrentEventManager()->UpdateMousePosition (aMousePos, Aspect_VKeyMouse_NONE, Aspect_VKeyFlags_NONE, false);
|
||||||
|
ViewerTest::CurrentEventManager()->FlushViewEvents (ViewerTest::GetAISContext(), aView, true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ViewerTest::CurrentEventManager()->UpdateMousePosition (aMousePos, Aspect_VKeyMouse_NONE, Aspect_VKeyFlags_NONE, false);
|
||||||
|
ViewerTest::CurrentEventManager()->FlushViewEvents (ViewerTest::GetAISContext(), aView, true);
|
||||||
|
ViewerTest::CurrentEventManager()->ReleaseMouseButton (aMousePos, aButton, Aspect_VKeyFlags_NONE, false);
|
||||||
|
ViewerTest::CurrentEventManager()->FlushViewEvents (ViewerTest::GetAISContext(), aView, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : VSelectByAxis
|
//function : VSelectByAxis
|
||||||
//purpose :
|
//purpose :
|
||||||
@ -14515,6 +14615,14 @@ Emulate cursor movement to pixel position (x,y).
|
|||||||
-reset resets current highlighting.
|
-reset resets current highlighting.
|
||||||
)" /* [vmoveto] */);
|
)" /* [vmoveto] */);
|
||||||
|
|
||||||
|
addCmd("vmousebutton", VMouseButton, /* [vmousebutton] */ R"(
|
||||||
|
vmousebutton x y -button right|left|middle -up|-down
|
||||||
|
Emulate mouse button events.
|
||||||
|
-button choose button;
|
||||||
|
-down press button;
|
||||||
|
-up release button.
|
||||||
|
)" /* [vmousebutton] */);
|
||||||
|
|
||||||
addCmd ("vselaxis", VSelectByAxis, /* [vselaxis] */ R"(
|
addCmd ("vselaxis", VSelectByAxis, /* [vselaxis] */ R"(
|
||||||
vselaxis x y z dx dy dz [-onlyTop 0|1] [-display Name] [-showNormal 0|1]"
|
vselaxis x y z dx dy dz [-onlyTop 0|1] [-display Name] [-showNormal 0|1]"
|
||||||
Provides intersection by given axis and print result intersection points.
|
Provides intersection by given axis and print result intersection points.
|
||||||
|
30
tests/v3d/bugs/bug33746
Normal file
30
tests/v3d/bugs/bug33746
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
puts "============"
|
||||||
|
puts "0033746: Visualization - Unexpected moving with AIS_ViewCube"
|
||||||
|
puts "============"
|
||||||
|
puts ""
|
||||||
|
|
||||||
|
pload MODELING VISUALIZATION
|
||||||
|
vclear
|
||||||
|
vinit View1
|
||||||
|
|
||||||
|
box b 0 0 -100 100 20 10
|
||||||
|
vdisplay -dispMode 1 b
|
||||||
|
|
||||||
|
vviewcube c
|
||||||
|
vcamera -navmode fly
|
||||||
|
|
||||||
|
vtop
|
||||||
|
vfit
|
||||||
|
vmousebutton 200 200 -button left -down
|
||||||
|
vmousebutton 201 200 -button left -up
|
||||||
|
if { [vreadpixel 100 200 -rgb -name] == "BLACK" } { puts "Error: wrong transformation" }
|
||||||
|
|
||||||
|
vdump $::imagedir/${::casename}_top.png
|
||||||
|
|
||||||
|
vbottom
|
||||||
|
vfit
|
||||||
|
vmousebutton 200 200 -button left -down
|
||||||
|
vmousebutton 201 200 -button left -up
|
||||||
|
if { [vreadpixel 100 200 -rgb -name] == "BLACK" } { puts "Error: wrong transformation" }
|
||||||
|
|
||||||
|
vdump $::imagedir/${::casename}_bottom.png
|
Loading…
x
Reference in New Issue
Block a user