|Modification → Array tools → Polar array|
|Introduced in version|
|Draft OrthoArray, Draft CircularArray, Draft PathArray, Draft PathLinkArray, Draft PointArray, Draft Clone|
Thetool creates an array from a selected object placing the copies along a circumference.
This tool can be used on any object that has a Part TopoShape, meaning 2D shapes created with the Draft Workbench, but also 3D solids created with other workbenches, for example, Part, PartDesign, or Arch. It can also create App Links instead of simple copies.
- To create orthogonal or circular arrays, use the corresponding and tools.
- To position copies along a path use or .
- To position copies at specified points use or .
- To create copies and manually place them use or .
- To create exact copies and manually place or scale them, use or .
A polar array of an object.
- Select the object that you wish to array.
- Press the button. If no object is selected, you will be invited to select one before proceeding.
- The task panel is launched where you can select the polar angle, the number of elements, and the center of the axis of rotation.
- You can click on the 3D view to simultaneously set the position of the center of rotation, and complete the command. Otherwise, just press or the button to complete the operation.
- By default, the axis of rotation is the positive Z axis
(0, 0, 1). This can be changed in the property editor after the object is created.
- Each element in the array is an exact clone of the original object, but the entire array is considered a single unit in terms of properties and appearance.
- This command creates the same parametric "Array" object as the one created with the DataArray Type property. and tools. Therefore, the array can be converted to orthogonal, polar, or circular by changing its
These are the options displayed in the task panel.
- Polar angle: the angle which determines where the last element of the array will be placed in the polar arrangement. The angle is positive in the counter-clockwise direction, and negative in the clockwise direction.
- Number of elements: the number of elements in the array. Minimum of 2, maximum of 99.
- Center of rotation: the coordinates through which the axis of rotation goes through.
- Reset point: it resets the center of rotation to the origin
(0, 0, 0).
- Fuse: if it is checked, the resulting objects in the array will fuse together if they touch each other. This only works if Link array is unchecked.
- Link array: if it is checked, the resulting array will be a "Link array". This array internally uses App Link objects, so it is more efficient when handling many copies of complex shapes. However, in this case, the objects cannot be fused together.
- Press or the button to abort the current command.
Note: if a Link array is created, this object cannot be converted to a regular array. And similarly, a regular array cannot be converted to a Link array. Therefore, you must choose the type of array that you want at creation time.
See the Orthogonal array and Circular array groups.tool for the complete description of the properties. All properties apply, except for those under the
array = makeArray(baseobject, center, totalangle, totalnum, use_link=False)
array = make_polar_array(base_object, number=5, angle=360, center=App.Vector(0, 0, 0), use_link=True)
- Creates an
"Array"object from the
numberis the number of copies in the polar pattern, including the original object.
angleis the angle of the polar arc in degrees.
centeris a vector that defines the center of the array pattern.
use_linkis the created copies will be App Links and not regular copies.
import FreeCAD as App import Draft doc = App.newDocument() tri = Draft.make_polygon(3, 600) center = App.Vector(-1600, 0, 0) array = Draft.make_polar_array(tri, 8, 270, center) doc.recompute()
Scripting, non-parametric array
When using the
"Array" object is created. This can be scripted as described in the previous section.
However, to obtain standalone copies of the base object, the simple
Draft.array function can be used. This will create simple copies, not a new parametric object.
To create a polar array, use it like this:
array_list = array(objectslist, center, angle, number)
- Creates an array from the objects contained in
objectslist, which can be a single object or a list of objects.
- In case of a polar array,
centerdefines the center of the array circle,
angleis the angle of the arc in degrees to cover with copies, and
numberis the number of copies to arrange on the circular arc, not including the original object.
array_listis returned with the new copies. It is either a single object or a list of objects, depending on the input
- In case of a polar array,
This function internally uses
import FreeCAD as App import Draft doc = App.newDocument() tri = Draft.make_polygon(3, 600) center = App.Vector(-3200, 0, 0) array_list = Draft.array(tri, center, 180, 5) doc.recompute()