mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-02 17:46:22 +03:00
0032116: Visualization - AIS_Manipulator is unusable when attaching to objects with Graphic3d_TMF_ZoomPers
Recalculation of manipulator position if attached object has zooom transform persistence as well as set its anchor point in Transformation.
This commit is contained in:
parent
2889518f7a
commit
9339c7e335
@ -331,6 +331,15 @@ void AIS_Manipulator::EnableMode(const AIS_ManipulatorMode theMode)
|
|||||||
|
|
||||||
//=================================================================================================
|
//=================================================================================================
|
||||||
|
|
||||||
|
void AIS_Manipulator::attachToPoint(const gp_Pnt& thePoint)
|
||||||
|
{
|
||||||
|
gp_Ax2 aPosition = gp::XOY();
|
||||||
|
aPosition.SetLocation(thePoint);
|
||||||
|
SetPosition(aPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
//=================================================================================================
|
||||||
|
|
||||||
void AIS_Manipulator::attachToBox(const Bnd_Box& theBox)
|
void AIS_Manipulator::attachToBox(const Bnd_Box& theBox)
|
||||||
{
|
{
|
||||||
if (theBox.IsVoid())
|
if (theBox.IsVoid())
|
||||||
@ -392,7 +401,15 @@ void AIS_Manipulator::Attach(const Handle(AIS_ManipulatorObjectSequence)& theObj
|
|||||||
|
|
||||||
if (theOptions.AdjustPosition)
|
if (theOptions.AdjustPosition)
|
||||||
{
|
{
|
||||||
attachToBox(aBox);
|
const Handle(Graphic3d_TransformPers)& aTransPers = aCurObject->TransformPersistence();
|
||||||
|
if (!aTransPers.IsNull() && (aTransPers->IsZoomOrRotate() || aTransPers->IsAxial()))
|
||||||
|
{
|
||||||
|
attachToPoint(aTransPers->AnchorPoint());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
attachToBox(aBox);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (theOptions.AdjustSize)
|
if (theOptions.AdjustSize)
|
||||||
@ -746,9 +763,18 @@ void AIS_Manipulator::Transform(const gp_Trsf& theTrsf)
|
|||||||
NCollection_Sequence<gp_Trsf>::Iterator aTrsfIter(myStartTrsfs);
|
NCollection_Sequence<gp_Trsf>::Iterator aTrsfIter(myStartTrsfs);
|
||||||
for (; anObjIter.More(); anObjIter.Next(), aTrsfIter.Next())
|
for (; anObjIter.More(); anObjIter.Next(), aTrsfIter.Next())
|
||||||
{
|
{
|
||||||
const Handle(AIS_InteractiveObject)& anObj = anObjIter.ChangeValue();
|
const Handle(AIS_InteractiveObject)& anObj = anObjIter.ChangeValue();
|
||||||
const gp_Trsf& anOldTrsf = aTrsfIter.Value();
|
const Handle(Graphic3d_TransformPers)& aTransPers = anObj->TransformPersistence();
|
||||||
const Handle(TopLoc_Datum3D)& aParentTrsf = anObj->CombinedParentTransformation();
|
if (!aTransPers.IsNull() && (aTransPers->IsZoomOrRotate() || aTransPers->IsAxial()))
|
||||||
|
{
|
||||||
|
gp_XYZ aNewAnchorPoint = aTransPers->AnchorPoint().XYZ() - myPosition.Location().XYZ();
|
||||||
|
aNewAnchorPoint += myStartPosition.Location().Transformed(theTrsf).XYZ();
|
||||||
|
aTransPers->SetAnchorPoint(aNewAnchorPoint);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
const gp_Trsf& anOldTrsf = aTrsfIter.Value();
|
||||||
|
const Handle(TopLoc_Datum3D)& aParentTrsf = anObj->CombinedParentTransformation();
|
||||||
if (!aParentTrsf.IsNull() && aParentTrsf->Form() != gp_Identity)
|
if (!aParentTrsf.IsNull() && aParentTrsf->Form() != gp_Identity)
|
||||||
{
|
{
|
||||||
// recompute local transformation relative to parent transformation
|
// recompute local transformation relative to parent transformation
|
||||||
|
@ -416,6 +416,8 @@ protected:
|
|||||||
Standard_EXPORT Handle(Graphic3d_Group) getGroup(const Standard_Integer theIndex,
|
Standard_EXPORT Handle(Graphic3d_Group) getGroup(const Standard_Integer theIndex,
|
||||||
const AIS_ManipulatorMode theMode) const;
|
const AIS_ManipulatorMode theMode) const;
|
||||||
|
|
||||||
|
Standard_EXPORT void attachToPoint(const gp_Pnt& thePoint);
|
||||||
|
|
||||||
Standard_EXPORT void attachToBox(const Bnd_Box& theBox);
|
Standard_EXPORT void attachToBox(const Bnd_Box& theBox);
|
||||||
|
|
||||||
Standard_EXPORT void adjustSize(const Bnd_Box& theBox);
|
Standard_EXPORT void adjustSize(const Bnd_Box& theBox);
|
||||||
|
@ -12083,7 +12083,8 @@ static int VManipulator(Draw_Interpretor& theDi, Standard_Integer theArgsNb, con
|
|||||||
NCollection_Sequence<ManipAxisModeOnOff> aParts;
|
NCollection_Sequence<ManipAxisModeOnOff> aParts;
|
||||||
gp_XYZ aLocation(RealLast(), RealLast(), RealLast()), aVDir, anXDir;
|
gp_XYZ aLocation(RealLast(), RealLast(), RealLast()), aVDir, anXDir;
|
||||||
//
|
//
|
||||||
bool toDetach = false;
|
bool toDetach = false;
|
||||||
|
bool toAddObject = false;
|
||||||
AIS_Manipulator::OptionsForAttach anAttachOptions;
|
AIS_Manipulator::OptionsForAttach anAttachOptions;
|
||||||
Handle(AIS_InteractiveObject) anAttachObject;
|
Handle(AIS_InteractiveObject) anAttachObject;
|
||||||
Handle(V3d_View) aViewAffinity;
|
Handle(V3d_View) aViewAffinity;
|
||||||
@ -12273,6 +12274,10 @@ static int VManipulator(Draw_Interpretor& theDi, Standard_Integer theArgsNb, con
|
|||||||
aTrsf.SetRotation(gp_Ax1(gp_Pnt(aRotPnt), gp_Dir(aRotAxis)), aTmpReal);
|
aTrsf.SetRotation(gp_Ax1(gp_Pnt(aRotPnt), gp_Dir(aRotAxis)), aTmpReal);
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
|
else if (anArg == "-addobject")
|
||||||
|
{
|
||||||
|
toAddObject = true;
|
||||||
|
}
|
||||||
else if (anArg == "-detach")
|
else if (anArg == "-detach")
|
||||||
{
|
{
|
||||||
toDetach = true;
|
toDetach = true;
|
||||||
@ -12430,7 +12435,16 @@ static int VManipulator(Draw_Interpretor& theDi, Standard_Integer theArgsNb, con
|
|||||||
|
|
||||||
if (!anAttachObject.IsNull())
|
if (!anAttachObject.IsNull())
|
||||||
{
|
{
|
||||||
aManipulator->Attach(anAttachObject, anAttachOptions);
|
if (toAddObject && aManipulator->IsAttached())
|
||||||
|
{
|
||||||
|
Handle(AIS_ManipulatorObjectSequence) anAttachObjects = aManipulator->Objects();
|
||||||
|
anAttachObjects->Append(anAttachObject);
|
||||||
|
aManipulator->Attach(anAttachObjects, anAttachOptions);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
aManipulator->Attach(anAttachObject, anAttachOptions);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (!aViewAffinity.IsNull())
|
if (!aViewAffinity.IsNull())
|
||||||
{
|
{
|
||||||
@ -14490,6 +14504,7 @@ Options:
|
|||||||
'-enableModes {0|1}' enable modes when attaching
|
'-enableModes {0|1}' enable modes when attaching
|
||||||
'-view {active | [name of view]}' display manipulator only in defined view,
|
'-view {active | [name of view]}' display manipulator only in defined view,
|
||||||
by default it is displayed in all views of the current viewer
|
by default it is displayed in all views of the current viewer
|
||||||
|
'-addObject allows attach manipulator to multiple objects (replace by default)
|
||||||
'-detach' detach manipulator
|
'-detach' detach manipulator
|
||||||
'-startTransform mouse_x mouse_y' - invoke start of transformation
|
'-startTransform mouse_x mouse_y' - invoke start of transformation
|
||||||
'-transform mouse_x mouse_y' - invoke transformation
|
'-transform mouse_x mouse_y' - invoke transformation
|
||||||
|
41
tests/v3d/bugs/bug32116
Normal file
41
tests/v3d/bugs/bug32116
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
puts "============"
|
||||||
|
puts "0032116: Visualization - AIS_Manipulator is unusable when attaching to objects with Graphic3d_TMF_ZoomPers"
|
||||||
|
puts "============"
|
||||||
|
puts ""
|
||||||
|
|
||||||
|
pload MODELING VISUALIZATION
|
||||||
|
|
||||||
|
box b1 10 10 10 10 20 30
|
||||||
|
box b2 50 50 50 10 20 30
|
||||||
|
|
||||||
|
vinit View1
|
||||||
|
vdisplay b1 -dispmode 1 -trsfPers zoom -trsfPersPos 0 0 0
|
||||||
|
vdisplay b2 -dispmode 1 -trsfPers zoom -trsfPersPos 10 10 10
|
||||||
|
vfit
|
||||||
|
|
||||||
|
vmanipulator m -attach b1 -addObject
|
||||||
|
vmanipulator m -attach b2 -addObject
|
||||||
|
|
||||||
|
set mouse_pick {90 225}
|
||||||
|
set mouse_drag {90 150}
|
||||||
|
|
||||||
|
vmoveto {*}$mouse_pick
|
||||||
|
vselect {*}$mouse_pick
|
||||||
|
vmanipulator m -startTransform {*}$mouse_pick
|
||||||
|
vmanipulator m -transform {*}$mouse_drag
|
||||||
|
vmanipulator m -stopTransform
|
||||||
|
vmoveto {*}$mouse_drag
|
||||||
|
|
||||||
|
if { [vreadpixel {*}$mouse_drag -rgb -name] != "CYAN" } { puts "Error: wrong manipulator position" }
|
||||||
|
if { [vreadpixel 115 170 -rgb -name] != "DARKGOLDENROD" } { puts "Error: wrong b1 tranformation" }
|
||||||
|
if { [vreadpixel 400 10 -rgb -name] != "DARKGOLDENROD" } { puts "Error: wrong b2 tranformation" }
|
||||||
|
|
||||||
|
vdump ${imagedir}/${casename}_1.png
|
||||||
|
|
||||||
|
vmoveto 0 0
|
||||||
|
vzoom 0.2
|
||||||
|
|
||||||
|
if { [vreadpixel 210 170 -rgb -name] != "DARKGOLDENROD" } { puts "Error: wrong b1 tranformation" }
|
||||||
|
if { [vreadpixel 310 120 -rgb -name] != "DARKGOLDENROD" } { puts "Error: wrong b2 tranformation" }
|
||||||
|
|
||||||
|
vdump ${imagedir}/${casename}_2.png
|
Loading…
x
Reference in New Issue
Block a user