|Modification → Array tools → Polar array|
|Introduced in version|
|Draft OrthoArray, Draft CircularArray, Draft PathArray, Draft PathLinkArray, Draft PointArray, Draft PointLinkArray|
The Draft PolarArray command creates an array from a selected object by placing copies along a circumference. The command can optionally create a Link array, which is more efficient than a regular array.
The command can be used on 2D objects created with the Draft Workbench or Sketcher Workbench, but also on many 3D objects such as those created with the Part Workbench, PartDesign Workbench or Arch Workbench.
See also: Draft Snap.
- Optionally select one object.
- There are several ways to invoke the command:
- The Polar array task panel opens. See Options for more information.
- If you have not yet selected an object: select one object.
- Enter the required parameters in the task panel.
- To finish the command do one of the following:
- Pick a point in the 3D view for the Center of rotation.
- Press .
- Press the button.
- Enter the Polar angle to specify the total angle of the array. The angle is positive in the counter-clockwise direction.
- Enter the Number of elements. Must be at least
2. The maximum that can be entered in the task panel is
99, but higher values are possible by changing the DataNumber Polar property of the array.
- Pick a point in the 3D view, note that this will also finish the command, or type coordinates for the Center of rotation. The rotation axis of the array will pass through this point. It is advisable to move the pointer out of the 3D view before entering coordinates.
- Press the Reset point button to reset the Center of rotation to the origin.
- If the Fuse checkbox is checked overlapping elements in the array are fused. This does not work for Link arrays.
- If the Link array checkbox is checked a Link array instead of a regular array is created. A Link array is more efficient because its elements are App Link objects.
- Press or the button to abort the command.
- The default rotation axis for the array is the positive Z axis. This can be changed by editing its DataAxis property.
- A Draft PolarArray can be turned into a Draft OrthoArray or a Draft CircularArray by changing its DataArray Type property.
- A Link array cannot be turned into a regular array or vice versa. The type of array must be decided at creation time.
- To change the number of decimals used for the input of coordinates and angles: Edit → Preferences... → General → Units → Units settings → Number of decimals.
See Draft OrthoArray.
To create a parametric polar array use the
make_array method (introduced in version 0.19) of the Draft module. This method replaces the deprecated
makeArray method. The
make_array method can create Draft OrthoArrays, Draft PolarArrays and Draft CircularArrays. For each array type one or more wrappers are available.
The main method:
array = make_array(base_object, arg1, arg2, arg3, arg4=None, arg5=None, arg6=None, use_link=True)
The wrapper for polar arrays is:
array = make_polar_array(base_object, number=5, angle=360, center=App.Vector(0, 0, 0), use_link=True)
base_objectis the object to be arrayed. It can also be the
Label(string) of an object in the current document.
numberis the number of elements in the pattern, including the original object.
angleis the angle of the polar arc in degrees.
centeris the vector that defines the center of the pattern.
Truethe created elements are App Links instead of regular copies.
arrayis returned with the created array object.
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()
To create a non-parametric polar array use the
array method of the Draft module. This method returns
array(objectslist, center, angle, number)
import FreeCAD as App import Draft doc = App.newDocument() tri = Draft.make_polygon(3, 600) center = App.Vector(-1600, 0, 0) Draft.array(tri, center, 270, 8) doc.recompute()