67 lines
		
	
	
		
			157 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			157 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| title: "arc"
 | |
| excerpt: "Draw a curved line segment along an imaginary circle."
 | |
| layout: manual
 | |
| ---
 | |
| 
 | |
| Draw a curved line segment along an imaginary circle.
 | |
| 
 | |
| The arc is constructed such that the current position of the sketch is placed along an imaginary circle of the specified radius, at angleStart degrees. The resulting arc is the segment of the imaginary circle from that origin point to angleEnd, radius away from the center of the imaginary circle.
 | |
| 
 | |
| Unless this makes a lot of sense and feels like what you're looking for to construct your shape, you're likely looking for tangentialArc.
 | |
| 
 | |
| ```kcl
 | |
| arc(
 | |
|   sketch: Sketch,
 | |
|   angleStart?: number,
 | |
|   angleEnd?: number,
 | |
|   radius?: number,
 | |
|   interiorAbsolute?: Point2d,
 | |
|   endAbsolute?: Point2d,
 | |
|   tag?: TagDeclarator,
 | |
| ): Sketch
 | |
| ```
 | |
| 
 | |
| 
 | |
| ### Arguments
 | |
| 
 | |
| | Name | Type | Description | Required |
 | |
| |----------|------|-------------|----------|
 | |
| | `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes |
 | |
| | `angleStart` | [`number`](/docs/kcl/types/std-types-number) | Where along the circle should this arc start? | No |
 | |
| | `angleEnd` | [`number`](/docs/kcl/types/std-types-number) | Where along the circle should this arc end? | No |
 | |
| | `radius` | [`number`](/docs/kcl/types/std-types-number) | How large should the circle be? | No |
 | |
| | `interiorAbsolute` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Any point between the arc's start and end? Requires `endAbsolute`. Incompatible with `angleStart` or `angleEnd` | No |
 | |
| | `endAbsolute` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Where should this arc end? Requires `interiorAbsolute`. Incompatible with `angleStart` or `angleEnd` | No |
 | |
| | [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No |
 | |
| 
 | |
| ### Returns
 | |
| 
 | |
| [`Sketch`](/docs/kcl/types/std-types-Sketch)
 | |
| 
 | |
| 
 | |
| ### Examples
 | |
| 
 | |
| ```kcl
 | |
| exampleSketch = startSketchOn(XZ)
 | |
|   |> startProfile(at = [0, 0])
 | |
|   |> line(end = [10, 0])
 | |
|   |> arc(angleStart = 0, angleEnd = 280, radius = 16)
 | |
|   |> close()
 | |
| example = extrude(exampleSketch, length = 10)
 | |
| ```
 | |
| 
 | |
| 
 | |
| 
 | |
| ```kcl
 | |
| exampleSketch = startSketchOn(XZ)
 | |
|   |> startProfile(at = [0, 0])
 | |
|   |> arc(endAbsolute = [10, 0], interiorAbsolute = [5, 5])
 | |
|   |> close()
 | |
| example = extrude(exampleSketch, length = 10)
 | |
| ```
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 |