mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0032388: Visualization - provide ray-picking interface with zero tolerance for rectangular frustum
This commit is contained in:
parent
807340d924
commit
0038de11f4
@ -50,7 +50,7 @@ public:
|
|||||||
//! Allows to manage sensitivity of a particular sensitive entity
|
//! Allows to manage sensitivity of a particular sensitive entity
|
||||||
void SetSensitivityFactor (const Standard_Integer theNewSens)
|
void SetSensitivityFactor (const Standard_Integer theNewSens)
|
||||||
{
|
{
|
||||||
Standard_ASSERT_RAISE (theNewSens > 0, "Error! Selection sensitivity have positive value.");
|
Standard_ASSERT_RAISE (theNewSens >= 0, "Error! Selection sensitivity should not be negative value.");
|
||||||
mySFactor = theNewSens;
|
mySFactor = theNewSens;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -364,8 +364,8 @@ Handle(SelectMgr_BaseIntersector) SelectMgr_RectangularFrustum::ScaleAndTransfor
|
|||||||
Standard_ASSERT_RAISE (mySelectionType == SelectMgr_SelectionType_Point || mySelectionType == SelectMgr_SelectionType_Box,
|
Standard_ASSERT_RAISE (mySelectionType == SelectMgr_SelectionType_Point || mySelectionType == SelectMgr_SelectionType_Box,
|
||||||
"Error! SelectMgr_RectangularFrustum::ScaleAndTransform() should be called after selection frustum initialization");
|
"Error! SelectMgr_RectangularFrustum::ScaleAndTransform() should be called after selection frustum initialization");
|
||||||
|
|
||||||
Standard_ASSERT_RAISE (theScaleFactor > 0,
|
Standard_ASSERT_RAISE (theScaleFactor >= 0,
|
||||||
"Error! Pixel tolerance for selection should be greater than zero");
|
"Error! Pixel tolerance for selection should not be negative");
|
||||||
|
|
||||||
Handle(SelectMgr_RectangularFrustum) aRes = new SelectMgr_RectangularFrustum();
|
Handle(SelectMgr_RectangularFrustum) aRes = new SelectMgr_RectangularFrustum();
|
||||||
const Standard_Boolean isToScale = theScaleFactor != 1;
|
const Standard_Boolean isToScale = theScaleFactor != 1;
|
||||||
|
@ -574,7 +574,7 @@ void SelectMgr_SelectionManager::SetSelectionSensitivity (const Handle(SelectMgr
|
|||||||
const Standard_Integer theMode,
|
const Standard_Integer theMode,
|
||||||
const Standard_Integer theNewSens)
|
const Standard_Integer theNewSens)
|
||||||
{
|
{
|
||||||
Standard_ASSERT_RAISE (theNewSens > 0, "Error! Selection sensitivity have positive value.");
|
Standard_ASSERT_RAISE (theNewSens >= 0, "Error! Selection sensitivity should not be negative value.");
|
||||||
if (theObject.IsNull())
|
if (theObject.IsNull())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
@ -78,7 +78,7 @@ void SelectMgr_ToleranceMap::Decrement (const Standard_Integer& theTolerance)
|
|||||||
if (theTolerance == myLargestKey
|
if (theTolerance == myLargestKey
|
||||||
&& *aFreq == 0)
|
&& *aFreq == 0)
|
||||||
{
|
{
|
||||||
myLargestKey = 0;
|
myLargestKey = -1;
|
||||||
for (NCollection_DataMap<Standard_Integer, Standard_Integer>::Iterator anIter (myTolerances); anIter.More(); anIter.Next())
|
for (NCollection_DataMap<Standard_Integer, Standard_Integer>::Iterator anIter (myTolerances); anIter.More(); anIter.Next())
|
||||||
{
|
{
|
||||||
if (anIter.Value() != 0)
|
if (anIter.Value() != 0)
|
||||||
|
@ -40,7 +40,7 @@ public:
|
|||||||
//! Returns a current tolerance that must be applied
|
//! Returns a current tolerance that must be applied
|
||||||
Standard_Integer Tolerance() const
|
Standard_Integer Tolerance() const
|
||||||
{
|
{
|
||||||
if (myLargestKey < Precision::Confusion())
|
if (myLargestKey < 0)
|
||||||
{
|
{
|
||||||
return 2; // default tolerance value
|
return 2; // default tolerance value
|
||||||
}
|
}
|
||||||
|
@ -1898,9 +1898,9 @@ struct ViewerTest_AspectsChangeSet
|
|||||||
Message::SendFail() << "Error: the max parameter value should be greater than zero (specified " << MaxParamValue << ")";
|
Message::SendFail() << "Error: the max parameter value should be greater than zero (specified " << MaxParamValue << ")";
|
||||||
isOk = Standard_False;
|
isOk = Standard_False;
|
||||||
}
|
}
|
||||||
if (Sensitivity <= 0 && ToSetSensitivity)
|
if (Sensitivity < 0 && ToSetSensitivity)
|
||||||
{
|
{
|
||||||
Message::SendFail() << "Error: sensitivity parameter value should be positive (specified " << Sensitivity << ")";
|
Message::SendFail() << "Error: sensitivity parameter value should not be negative (specified " << Sensitivity << ")";
|
||||||
isOk = Standard_False;
|
isOk = Standard_False;
|
||||||
}
|
}
|
||||||
if (ToSetHatch == 1 && StdHatchStyle < 0 && PathToHatchPattern == "")
|
if (ToSetHatch == 1 && StdHatchStyle < 0 && PathToHatchPattern == "")
|
||||||
|
55
tests/vselect/axis/A3
Normal file
55
tests/vselect/axis/A3
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
puts "========"
|
||||||
|
puts "0032388: Visualization - provide ray-picking interface with zero tolerance for rectangular frustum"
|
||||||
|
puts "========"
|
||||||
|
puts ""
|
||||||
|
|
||||||
|
pload MODELING VISUALIZATION
|
||||||
|
box b 100 200 300
|
||||||
|
vinit View1
|
||||||
|
puts "Display box"
|
||||||
|
vdisplay -dispMode 1 b
|
||||||
|
vfit
|
||||||
|
vselprops -pixtol 0
|
||||||
|
vaspects b -sensitivity 0 4
|
||||||
|
set box_sens4 [vmoveto 321 319]
|
||||||
|
vdump ${imagedir}/${casename}_box_sens4.png
|
||||||
|
regexp {([-0-9.+eE]+ [-0-9.+eE]+ [-0-9.+eE]+)} ${box_sens4} full p
|
||||||
|
checkpoint "box_sens4" $p {100 200 0} 0.001
|
||||||
|
vaspects b -sensitivity 0 0
|
||||||
|
set box_sens0_out [vmoveto 321 319]
|
||||||
|
vdump ${imagedir}/${casename}_box_sens0_out.png
|
||||||
|
if {[string first "e+308" $box_sens0_out] == -1} {
|
||||||
|
puts "Faulty : Selection of box with sensitivity 0"
|
||||||
|
}
|
||||||
|
set box_sens0_in [vmoveto 319 317]
|
||||||
|
vdump ${imagedir}/${casename}_box_sens0_in.png
|
||||||
|
regexp {([-0-9.+eE]+ [-0-9.+eE]+ [-0-9.+eE]+)} ${box_sens0_in} full p
|
||||||
|
checkpoint "box_sens0_in" $p {100.00000000000003 196.92152736525867 0.4127082000112523} 0.001
|
||||||
|
|
||||||
|
puts ""
|
||||||
|
puts "Display 2d point"
|
||||||
|
vpoint p 320 318 -2d
|
||||||
|
vaspects p -markerType .
|
||||||
|
set point_sens12_out [vmoveto 321 319]
|
||||||
|
vdump ${imagedir}/${casename}_point_sens12_out.png
|
||||||
|
regexp {([-0-9.+eE]+ [-0-9.+eE]+ [-0-9.+eE]+)} ${point_sens12_out} full p
|
||||||
|
checkpoint "point_sens12_out" $p {104.7974449617403 -102.98278630143884 -346.41016151377545} 0.001
|
||||||
|
set point_sens12_in [vmoveto 319 317]
|
||||||
|
vdump ${imagedir}/${casename}_point_sens12_in.png
|
||||||
|
regexp {([-0-9.+eE]+ [-0-9.+eE]+ [-0-9.+eE]+)} ${point_sens12_in} full p
|
||||||
|
checkpoint "point_sens12_in" $p {104.7974449617403 -102.98278630143884 -346.41016151377545} 0.001
|
||||||
|
vaspects p -sensitivity 0 0
|
||||||
|
set point_sens0_out [vmoveto 321 319]
|
||||||
|
vdump ${imagedir}/${casename}_point_sens0_out.png
|
||||||
|
if {[string first "e+308" $point_sens0_out] == -1} {
|
||||||
|
puts "Faulty : Selection of point with sensitivity 0"
|
||||||
|
}
|
||||||
|
set point_sens0_eq [vmoveto 320 318]
|
||||||
|
vdump ${imagedir}/${casename}_point_sens0_eq.png
|
||||||
|
if {[string first "e+308" $point_sens0_eq] == -1} {
|
||||||
|
puts "Faulty : Selection of point with sensitivity 0"
|
||||||
|
}
|
||||||
|
set point_sens0_in [vmoveto 319 317]
|
||||||
|
vdump ${imagedir}/${casename}_point_sens0_in.png
|
||||||
|
regexp {([-0-9.+eE]+ [-0-9.+eE]+ [-0-9.+eE]+)} ${point_sens0_in} full p
|
||||||
|
checkpoint "point_sens0_in" $p {100.00000000000003 196.92152736525867 0.41270820001116704} 0.001
|
Loading…
x
Reference in New Issue
Block a user