mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-06 18:26:22 +03:00
0026359: Revolution shape of Parabola Curve has no triangles
Adaptor3d_IsoCurve::Circle() - prevent parallel check with NULL-vector Test case for issue CR26359
This commit is contained in:
parent
f978241fb6
commit
34fbe24917
@ -766,14 +766,15 @@ gp_Circ Adaptor3d_IsoCurve::Circle() const
|
|||||||
case GeomAbs_SurfaceOfRevolution:
|
case GeomAbs_SurfaceOfRevolution:
|
||||||
{
|
{
|
||||||
if (myIso == GeomAbs_IsoV) {
|
if (myIso == GeomAbs_IsoV) {
|
||||||
gp_Ax1 Ax1 = mySurface->AxeOfRevolution();
|
const gp_Pnt aVal0 = Value (0.0);
|
||||||
gp_Vec DX(Ax1.Location(), Value(0));
|
gp_Ax1 Ax1 = mySurface->AxeOfRevolution();
|
||||||
if(DX.IsParallel(Ax1.Direction(),Precision::Angular())) {
|
if (gp_Lin (Ax1).Contains (aVal0, Precision::Confusion())) {
|
||||||
return gp_Circ(gp_Ax2(Value(0), Ax1.Direction()),0);
|
return gp_Circ(gp_Ax2(aVal0, Ax1.Direction()),0);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
gp_Vec DX(Ax1.Location(), aVal0);
|
||||||
axes = gp_Ax3(Ax1.Location(), Ax1.Direction(), DX);
|
axes = gp_Ax3(Ax1.Location(), Ax1.Direction(), DX);
|
||||||
computeHR(axes,Value(0),h,radius);
|
computeHR(axes,aVal0,h,radius);
|
||||||
gp_Vec VT = axes.Direction();
|
gp_Vec VT = axes.Direction();
|
||||||
axes.Translate(VT * h);
|
axes.Translate(VT * h);
|
||||||
return gp_Circ(axes.Ax2(),radius);
|
return gp_Circ(axes.Ax2(),radius);
|
||||||
|
36
tests/bugs/moddata_3/bug26359
Executable file
36
tests/bugs/moddata_3/bug26359
Executable file
@ -0,0 +1,36 @@
|
|||||||
|
puts "============"
|
||||||
|
puts "CR26359"
|
||||||
|
puts "============"
|
||||||
|
puts ""
|
||||||
|
###################################################################################
|
||||||
|
# Revolution shape of Parabola Curve has no triangles
|
||||||
|
###################################################################################
|
||||||
|
|
||||||
|
vinit View1
|
||||||
|
vclear
|
||||||
|
vaxo
|
||||||
|
vsetdispmode 1
|
||||||
|
|
||||||
|
restore [locate_data_file bug26359_parabola.brep] p
|
||||||
|
|
||||||
|
vdisplay p
|
||||||
|
vfit
|
||||||
|
|
||||||
|
set trinfo_s [trinfo p]
|
||||||
|
regexp {([0-9]+) triangles} ${trinfo_s} str nbtri_s
|
||||||
|
regexp {([0-9]+) nodes} ${trinfo_s} str nbnod_s
|
||||||
|
regexp {deflection ([0-9.+e-]+)} ${trinfo_s} str defl_s
|
||||||
|
|
||||||
|
if { ${nbtri_s} == 0 } {
|
||||||
|
puts "Error: shape contains 0 triangles"
|
||||||
|
}
|
||||||
|
|
||||||
|
if { ${nbnod_s} == 0 } {
|
||||||
|
puts "Error: shape contains 0 nodes"
|
||||||
|
}
|
||||||
|
|
||||||
|
if { ${defl_s} == 0 } {
|
||||||
|
puts "Error: deflection is 0"
|
||||||
|
}
|
||||||
|
|
||||||
|
vdump ${imagedir}/${casename}.png
|
Loading…
x
Reference in New Issue
Block a user