/*! \page create_extrusion_alongpath_page Pipe Construction To generate a \b Pipe in the <b>Main Menu</b> select <b>New Entity - > Generation - > Extrusion along a path</b> \n Firstly, to create an extruded \b Pipe shape, you can define the <b>Base Object</b> (vertex, edge, planar wire, face or shell), which will be extruded and the <b>Path Object</b> (edge or wire) along which the <b>Base Object</b> will be extruded.<br> It is possible to select in GUI several Base Objects to make several pipes (using Shift button). \n In this mode the default pipe generation algorithm is used. The pipe is created so that the <b>angle between the normal vector</b> to the base shape <b>and the tangent to the path</b> wire remains constant at any point of the given path. \n <b>Select unpublished edges</b> checkbox - if checked, allows to select an edge of any other shape as the path object. \n The \b Result of the operation will be a GEOM_Object (edge, face, shell, solid or compsolid). \n <b>TUI Command:</b> <em>geompy.MakePipe(baseShape, pathShape)</em> \n <b>Arguments:</b> Name + 1 shape (vertex, edge, planar wire, face or shell) serving as base object + 1 shape (edge or wire) for definition of the path. \n <b>Advanced options</b> \ref preview_anchor "Preview" \image html pipe.png <b>Example:</b> \image html pipe_wire_edgesn.png "Extrusion of a wire" \n Secondly, you can define the <b>Base Object</b> (edge, planar wire or face), which will be extruded, the <b>Path Object</b> (edge or wire) along which the <b>Base Object</b> will be extruded and the <b>BiNormal Vector</b> (edge or wire). \n In contrast to the default mode, in this mode the pipe is generated to preserve the constant <b>angle between the normal vector</b> to the base shape <b>and the BiNormal vector</b> given as the third argument. \n <b>Select unpublished edges</b> checkbox - if checked, allows to select an edge of any other shape as the path object. \n The \b Result of the operation will be a GEOM_Object (edge, face, shell, solid or compsolid). \n <b>TUI Command:</b> <em>geompy.MakePipeBiNormalAlongVector(baseShape, pathShape, binormalShape)</em> \n <b>Arguments:</b> Name + 1 shape (edge, planar wire or face) serving as base object + 1 shape (edge or wire) for definition of the path + 1 shape (edge or wire) to set a fixed BiNormal direction to perform the extrusion. \image html pipe2.png <b>Example:</b> \image html pipebinormalsn.png "Extrusion of a face with BiNormal parameter" \n Thirdly, it is possible to additionally select profiles of the pipe object to be built. For this, you can define the following parameters: - <b>Base Object</b> or a list of objects (edges, planar wires, faces or shells), which will be extruded; - <b>Locations</b> - a vertex or a list of vertices that specify the locations of extruded <b>Base Objects</b> on the resulting <b>Path Object</b>. The number of Base Objects should be equal to the number of <b>Locations</b>. - <b>Path Object</b> (edge or wire), along which the <b>Base Object</b> will be extruded. Additional controls: - If <b>With contact</b> is checked, the section is translated in contact with the spine. - If <b>With correction</b> is checked, the section is rotated to be orthogonal to the spine tangent in the corresponding point. \n The \b Result of the operation will be a shell or a solid. \n <b>TUI Command:</b> <em>geompy.MakePipeWithDifferentSections(baseShape, locations, pathShape, withContact, withCorrection)</em> \n <b>Arguments:</b> Name + list of shapes (edges, planar wires, faces or shells) serving as base object + list of locations (vertices) on the path corresponding specified list of the shapes + 1 shape (edge or wire) for definition of the path + 2 Boolean parameters (withContact, withCorrection). \n <b>Advanced options</b> \ref preview_anchor "Preview" \image html pipe3.png <b>Example:</b> \image html pipe3_init.png "Base objects and Location vertices" \image html pipe3_res.png "Extrusion of the profile shapes along the path shape" Our <b>TUI Scripts</b> provide you with useful examples of creation of \ref tui_creation_pipe "Complex Geometric Objects". */