2024-03-13 14:22:22 -07:00
---
title: "patternCircular3d"
excerpt: "A circular pattern on a 3D model."
layout: manual
---
A circular pattern on a 3D model.
2024-03-13 15:43:42 -07:00
```js
2024-06-17 13:35:44 -07:00
patternCircular3d(data: CircularPattern3dData, extrude_group_set: ExtrudeGroupSet) -> [ExtrudeGroup]
2024-03-13 14:22:22 -07:00
```
### Examples
2024-03-13 15:43:42 -07:00
```js
2024-05-22 09:15:38 -07:00
const exampleSketch = startSketchOn('XZ')
2024-05-14 17:10:47 -07:00
|> circle([0, 0], 1, %)
const example = extrude(-5, exampleSketch)
2024-03-13 14:22:22 -07:00
|> patternCircular3d({
2024-05-14 17:10:47 -07:00
axis: [1, -1, 0],
center: [10, -20, 0],
2024-03-13 14:22:22 -07:00
repetitions: 10,
arcDegrees: 360,
rotateDuplicates: true
}, %)
```
2024-07-17 15:55:59 -07:00

2024-03-13 15:43:42 -07:00
```js
2024-03-13 14:22:22 -07:00
{
// The arc angle (in degrees) to place the repetitions. Must be greater than 0.
arcDegrees: number,
// The axis around which to make the pattern. This is a 3D vector.
axis: [number, number, number],
2024-04-09 11:51:41 -07:00
// The center about which to make the pattern. This is a 3D vector.
2024-03-13 14:22:22 -07:00
center: [number, number, number],
// The number of repetitions. Must be greater than 0. This excludes the original entity. For example, if `repetitions` is 1, the original entity will be copied once.
repetitions: number,
// Whether or not to rotate the duplicates as they are copied.
rotateDuplicates: string,
}
```
2024-06-17 13:35:44 -07:00
* `extrude_group_set` : `ExtrudeGroupSet` - A extrude group or a group of extrude groups. (REQUIRED)
2024-03-13 15:43:42 -07:00
```js
2024-03-13 14:22:22 -07:00
{
// The id of the extrusion end cap
endCapId: uuid,
2024-06-23 19:19:24 -07:00
// Chamfers or fillets on this extrude group.
filletOrChamfers: [{
// The engine id of the edge to fillet.
2024-07-29 13:18:55 -07:00
edgeId: uuid,
2024-06-23 19:19:24 -07:00
// The id of the engine command that called this fillet.
id: uuid,
radius: number,
2024-07-28 00:30:04 -07:00
tag: {
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
end: number,
start: number,
value: string,
},
2024-06-23 19:19:24 -07:00
type: "fillet",
} |
{
// The engine id of the edge to chamfer.
2024-07-29 13:18:55 -07:00
edgeId: uuid,
2024-06-23 19:19:24 -07:00
// The id of the engine command that called this chamfer.
id: uuid,
length: number,
2024-06-24 14:45:07 -07:00
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-06-23 19:19:24 -07:00
type: "chamfer",
}],
2024-03-13 14:22:22 -07:00
// The height of the extrude group.
height: number,
// The id of the extrude group.
id: uuid,
2024-06-21 23:50:30 -07:00
// The sketch group.
sketchGroup: {
2024-07-29 21:30:25 -07:00
// The id of the sketch group (this will change when the engine's reference to it changes.
2024-06-21 23:50:30 -07:00
id: uuid,
// What the sketch is on (can be a plane or a face).
on: {
// The id of the plane.
id: uuid,
// Origin of the plane.
origin: {
x: number,
y: number,
z: number,
},
type: "plane",
// Type for a plane.
value: "XY" | "XZ" | "YZ" | "Custom",
// What should the plane’ s X axis be?
xAxis: {
x: number,
y: number,
z: number,
},
// What should the plane’ s Y axis be?
yAxis: {
x: number,
y: number,
z: number,
},
// The z-axis (normal).
zAxis: {
x: number,
y: number,
z: number,
},
} |
{
2024-06-23 19:19:24 -07:00
// The extrude group the face is on.
extrudeGroup: {
// The id of the extrusion end cap
endCapId: uuid,
// Chamfers or fillets on this extrude group.
filletOrChamfers: [{
// The engine id of the edge to fillet.
2024-07-29 13:18:55 -07:00
edgeId: uuid,
2024-06-23 19:19:24 -07:00
// The id of the engine command that called this fillet.
id: uuid,
radius: number,
2024-07-28 00:30:04 -07:00
tag: {
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
end: number,
start: number,
value: string,
},
2024-06-23 19:19:24 -07:00
type: "fillet",
} |
{
// The engine id of the edge to chamfer.
2024-07-29 13:18:55 -07:00
edgeId: uuid,
2024-06-23 19:19:24 -07:00
// The id of the engine command that called this chamfer.
id: uuid,
length: number,
2024-06-24 14:45:07 -07:00
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-06-23 19:19:24 -07:00
type: "chamfer",
}],
// The height of the extrude group.
height: number,
// The id of the extrude group.
id: uuid,
// The sketch group.
sketchGroup: SketchGroup,
// The id of the extrusion start cap
startCapId: uuid,
// The extrude surfaces.
value: [{
// The face id for the extrude plane.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
2024-06-24 14:45:07 -07:00
// The tag.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-06-23 19:19:24 -07:00
type: "extrudePlane",
} |
{
// The face id for the extrude plane.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
2024-06-24 14:45:07 -07:00
// The tag.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-06-23 19:19:24 -07:00
type: "extrudeArc",
2024-07-28 00:30:04 -07:00
} |
{
// The id for the chamfer surface.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
// The tag.
tag: {
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
end: number,
start: number,
value: string,
},
type: "chamfer",
} |
{
// The id for the fillet surface.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
// The tag.
tag: {
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
end: number,
start: number,
value: string,
},
type: "fillet",
2024-06-23 19:19:24 -07:00
}],
},
2024-06-21 23:50:30 -07:00
// The id of the face.
id: uuid,
type: "face",
// The tag of the face.
value: string,
// What should the face’ s X axis be?
xAxis: {
x: number,
y: number,
z: number,
},
// What should the face’ s Y axis be?
yAxis: {
x: number,
y: number,
z: number,
},
// The z-axis (normal).
zAxis: {
x: number,
y: number,
z: number,
},
},
// The starting path.
start: {
// The from point.
from: [number, number],
2024-06-24 14:45:07 -07:00
// The tag of the path.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-06-21 23:50:30 -07:00
// The to point.
to: [number, number],
2024-07-05 16:53:13 -07:00
},
// Tag identifiers that have been declared in this sketch group.
tags: {
2024-06-21 23:50:30 -07:00
},
// The paths in the sketch group.
value: [{
2024-03-13 14:22:22 -07:00
// The from point.
from: [number, number],
2024-06-24 14:45:07 -07:00
// The tag of the path.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
// The to point.
to: [number, number],
type: "ToPoint",
} |
{
// arc's direction
ccw: string,
// the arc's center
center: [number, number],
// The from point.
from: [number, number],
2024-06-24 14:45:07 -07:00
// The tag of the path.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
// The to point.
to: [number, number],
type: "TangentialArcTo",
} |
{
// The from point.
from: [number, number],
2024-06-24 14:45:07 -07:00
// The tag of the path.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
// The to point.
to: [number, number],
type: "TangentialArc",
} |
{
// The from point.
from: [number, number],
2024-06-24 14:45:07 -07:00
// The tag of the path.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
// The to point.
to: [number, number],
type: "Horizontal",
// The x coordinate.
x: number,
} |
{
// The from point.
from: [number, number],
2024-06-24 14:45:07 -07:00
// The tag of the path.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
// The to point.
to: [number, number],
type: "AngledLineTo",
// The x coordinate.
x: number,
// The y coordinate.
y: number,
} |
{
// The from point.
from: [number, number],
2024-06-24 14:45:07 -07:00
// The tag of the path.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
// The to point.
to: [number, number],
type: "Base",
}],
2024-06-21 23:50:30 -07:00
},
2024-03-13 14:22:22 -07:00
// The id of the extrusion start cap
startCapId: uuid,
2024-06-17 13:35:44 -07:00
type: "extrudeGroup",
2024-03-13 14:22:22 -07:00
// The extrude surfaces.
value: [{
// The face id for the extrude plane.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
2024-06-24 14:45:07 -07:00
// The tag.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
type: "extrudePlane",
} |
{
// The face id for the extrude plane.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
2024-06-24 14:45:07 -07:00
// The tag.
tag: {
2024-07-09 12:24:42 -04:00
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
2024-06-24 14:45:07 -07:00
end: number,
start: number,
value: string,
},
2024-03-13 14:22:22 -07:00
type: "extrudeArc",
2024-07-28 00:30:04 -07:00
} |
{
// The id for the chamfer surface.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
// The tag.
tag: {
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
end: number,
start: number,
value: string,
},
type: "chamfer",
} |
{
// The id for the fillet surface.
faceId: uuid,
// The id of the geometry.
id: uuid,
// The source range.
sourceRange: [number, number],
// The tag.
tag: {
digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number],
end: number,
start: number,
value: string,
},
type: "fillet",
2024-03-13 14:22:22 -07:00
}],
2024-06-17 13:35:44 -07:00
} |
{
type: "extrudeGroups",
2024-03-13 14:22:22 -07:00
}
```
### Returns
`[ExtrudeGroup]`