Lines
There are a few components for lines, depending on how you want to construct them.
Line segment
import { Mafs, Line, Coordinates, useMovablePoint } from "mafs"
const $default = function LineSegmentExample() {
const point1 = useMovablePoint([-2, -1])
const point2 = useMovablePoint([2, 1])
return (
<Mafs viewBox={{ x: [-2, 2], y: [-1, 1] }}>
<Coordinates.Cartesian />
<Line.Segment
point1={point1.point}
point2={point2.point}
/>
{point1.element}
{point2.element}
</Mafs>
)
}
TSXProps
<Line.Segment ... />
Name | Description | Default |
---|
point1 | | β |
point2 | | β |
color | | var(--mafs-fg) |
opacity | | 1 |
weight | | 2 |
style | "solid" | "dashed" | undefined
| solid |
Line through two points
import { Mafs, Line, Coordinates, useMovablePoint } from "mafs"
const $default = function LineThroughPointsExample() {
const point1 = useMovablePoint([-2, -1])
const point2 = useMovablePoint([2, 1])
return (
<Mafs viewBox={{ x: [-2, 2], y: [-1, 1] }}>
<Coordinates.Cartesian />
<Line.ThroughPoints
point1={point1.point}
point2={point2.point}
/>
{point1.element}
{point2.element}
</Mafs>
)
}
TSXProps
<Line.ThroughPoints ... />
Name | Description | Default |
---|
point1 | | β |
point2 | | β |
color | | var(--mafs-fg) |
opacity | | 1 |
weight | | 2 |
style | "solid" | "dashed" | undefined
| solid |
Point and slope
import { Mafs, Line, Coordinates, useMovablePoint } from "mafs"
const $default = function LinePointSlopeExample() {
const point = useMovablePoint([-1, -1])
const slope = useMovablePoint([0, 1], {
constrain: "vertical",
})
return (
<Mafs viewBox={{ x: [-1, 1], y: [-1, 1] }}>
<Coordinates.Cartesian />
<Line.PointSlope
point={point.point}
slope={slope.y}
/>
{point.element}
{slope.element}
</Mafs>
)
}
TSXProps
<Line.PointSlope ... />
Name | Description | Default |
---|
point | | β |
slope | | β |
color | | β |
opacity | | β |
weight | | β |
style | "solid" | "dashed" | undefined
| β |
Point and angle
import { Mafs, Line, Coordinates, useMovablePoint } from "mafs"
const $default = function LinePointAngleExample() {
const point = useMovablePoint([0, 0])
return (
<Mafs viewBox={{ x: [-1, 1], y: [-1, 1] }}>
<Coordinates.Cartesian />
<Line.PointAngle
point={point.point}
angle={Math.PI / 6}
/>
{point.element}
</Mafs>
)
}
TSXProps
<Line.PointAngle ... />
Name | Description | Default |
---|
point | | β |
angle | | β |
color | | β |
opacity | | β |
weight | | β |
style | "solid" | "dashed" | undefined
| β |