Skip to content

Latest commit

 

History

History
 
 

conic

@pixi-essentials/conic

This package is a display-object library for drawing conic sections (or any quadric curve) in two dimensions.

Any quadratic curve can be represented in the form k2 - lm = 0, where k, l, m are linear functionals (of form ax + by + c = 0). l and m are tangents to the curve, while k is the chord joining the points of tangency. The Conic shape exploits this representation to store quadric curves.

Installation 📦

npm install @pixi-essentials/conic

Usage 📄

import { Conic, ConicDisplay } from '@pixi-essentials/conic';

const circleShape = Conic.createCircle(.5);
const circleDisplay = new ConicDisplay(circleShape);

circleDisplay.drawRect(0, 0, 1, 1);
circleDisplay.scale.set(100, 100);
circleDisplay.position.set(10, 10);

The snippet creates a circular curve centered at (0.5, 0.5) of radius 0.5. Then, a graphic is used to display the curve in a rectangle (0, 0, 1, 1), upscaled at 100x resolution.

The linear functionals & the produced curves can be seen here: https://www.desmos.com/calculator/bbeizcgnhl

Control points & bezier curves

By default, a conic is a bezier. You can set the local control points on the conic-display to draw a bezier curve.

import { Point } from 'pixi.js';
import { Conic, ConicDisplay } from '@pixi-essentials/conic`;

const bezierShape = new Conic();
const bezierDisplay = new ConicDisplay(bezierShape);

bezierDisplay
    .drawControlPoints()
    .setControlPoints(
        new Point(10, 10),
        new Point(200, 500),
        new Point(800, 20)
    );

This snippet will draw a quadratic bezier curve with control points (10,10), (200,500), (800,20).

Antialiasing

The conic shader uses a hardware-based derivatives to antialias pixels on the edge of the curve.