承接 alto/bezier 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

alto/bezier

最新稳定版本:v1.0.0

Composer 安装命令:

composer require alto/bezier

包简介

Precision PHP toolkit for evaluating, splitting, and measuring quadratic, cubic, quintic and N-order Bezier curves

README 文档

README

Alto\Bezier is a precision PHP toolkit for evaluating, splitting, and measuring quadratic, cubic, quintic, and N-order Bézier curves using immutable value objects and a numerically stable De Casteljau core.

Features

  • Quadratic, cubic, quartic, quintic, and arbitrary N-order curves that all share the same API
  • Point evaluation: pointAt(t) and constant-speed pointAtDistance(distance) helpers
  • Curve subdivision with split(t) for tessellation or editing workflows
  • Differential geometry helpers: derivatives, tangents, normals
  • Arc-length calculation and arc-length parameterization with configurable sampling
  • Intersection detection between any two curves
  • Bounding boxes and evenly spaced point generators for export to SVG, canvas, or WebGL
  • Immutable, readonly classes with no external dependencies

Installation

composer require alto/bezier

Usage

Create and inspect a cubic curve

use Alto\Bezier\CubicCurve;
use Alto\Bezier\Point;

$curve = new CubicCurve(
    new Point(0, 0),
    new Point(40, 160),
    new Point(160, -40),
    new Point(200, 120)
);

$mid = $curve->pointAt(0.5);
[$left, $right] = $curve->split(0.4);
$heading = $curve->tangent(0.5);

Instantiate quadratic and N-order curves

use Alto\Bezier\QuadraticCurve;
use Alto\Bezier\NOrderCurve;
use Alto\Bezier\Point;

$quadratic = new QuadraticCurve(
    new Point(0, 0),
    new Point(50, 120),
    new Point(120, 0)
);

$wave = new NOrderCurve(...array_map(
    fn(int $i) => new Point($i * 20, sin($i / 2) * 40 + 60),
    range(0, 7)
));

Exporting control points to SVG

$path = sprintf(
    'M %s C %s %s %s',
    ...array_map(fn(Point $p) => $p->x.' '.$p->y, $curve->toArray())
);

Advanced

  • Arc length & constant-speed motion: length($samples) returns the numerical arc length, while pointAtDistance($distance, $samples) maps real distances back to coordinates.
  • Intersections: $curveA->intersections($curveB, tolerance: 0.25, maxDepth: 18) delivers intersection points along with their t parameters on each curve.
  • Numeric tuning: increase sampling (default 100) for long or intricate paths to improve accuracy for arc-length and parameterization routines.
  • Bounding boxes and grids: boundingBox() exposes width/height/corners, and points($interval) streams evenly spaced points for tessellation or hit-testing.

Testing

composer install
vendor/bin/phpstan analyse
vendor/bin/phpunit

License

This project is licensed under the MIT License.

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04