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)
|
||||
{
|
||||
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;
|
||||
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()));
|
||||
const gp_Quaternion aRot = aTrsf.GetRotation();
|
||||
double aRollDummy = 0.0;
|
||||
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)
|
||||
{
|
||||
|
@ -857,7 +857,7 @@ public:
|
||||
const Graphic3d_BufferType& theBufferType = Graphic3d_BT_RGB,
|
||||
const Standard_Boolean theToAdjustAspect = Standard_True,
|
||||
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 Standard_CString theLightName = "")
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
// Created on: 1998-09-01
|
||||
// Created on: 1998-09-01
|
||||
// Created by: Robert COUBLANC
|
||||
// Copyright (c) 1998-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
||||
@ -6547,6 +6547,106 @@ static Standard_Integer VMoveTo (Draw_Interpretor& theDI,
|
||||
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
|
||||
//purpose :
|
||||
@ -14515,6 +14615,14 @@ Emulate cursor movement to pixel position (x,y).
|
||||
-reset resets current highlighting.
|
||||
)" /* [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"(
|
||||
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.
|
||||
|
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