mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
1. There has been implemented calculation of all possible types of continuity for shared edges: * G1 is set if tangential planes are the same for connected faces in each control points through the edge; * C1 is set in addition to G1 conditions if derivatives, orthogonal to the edge on each face, are equal vectors; * G2 is set in addition to G1 if the centers of principal curvatures are the same for connected faces in each control points through the edge; * C2 is set in addition to C1 and G2 if directions of principal curvatures are equal; * CN continuity is set only if both connected faces are based on elementary surfaces (the conditions for this case are similar to C2 continuity). 2. ShapeFix::EncodeRegularity() is merged into BRepLib::EncodeRegularity(). 3. Implemented several test cases to check correct handling of regularity. 4. Fix incorrect usage of BRepLib::EncodeRegularity() in BRepBuilderAPI_Sewing. 5. Implement a method for calculation of regularity on the given list of edges. 6. Documentation updates
41 lines
952 B
Plaintext
41 lines
952 B
Plaintext
puts "========"
|
|
puts "0027383: Modeling - improve handling of regularity on edges"
|
|
puts "========"
|
|
puts ""
|
|
#################################################################
|
|
# Check regularity setting on edges between cylinder and a plane
|
|
#################################################################
|
|
|
|
pload MODELING
|
|
plane p 0 2 0 0 1 0
|
|
mkface pln p 0 10 -2 0
|
|
pcylinder cyl 2 10 90
|
|
explode cyl F
|
|
sewing r cyl_1 pln
|
|
encoderegularity r
|
|
|
|
set cont "G1"
|
|
|
|
explode r F
|
|
explode r_1 E
|
|
if { ! [regexp "${cont}" [getedgeregularity r_1_2 r_1 r_2]] } {
|
|
puts "Error: Invalid regularity of the edge, expected ${cont}"
|
|
}
|
|
|
|
nurbsconvert ncyl cyl_1
|
|
sewing r ncyl pln
|
|
encoderegularity r
|
|
|
|
explode r F
|
|
explode r_1 E
|
|
if { ! [regexp "${cont}" [getedgeregularity r_1_2 r_1 r_2]] } {
|
|
puts "Error: Invalid regularity of the edge, expected ${cont}"
|
|
}
|
|
|
|
# make image in HLR mode as illustration
|
|
pload VISUALIZATION
|
|
vdisplay r
|
|
vfit
|
|
vhlr on
|
|
vdump ${imagedir}/${test_image}.png
|