js绘制贝塞尔曲线(Bézier-Curve)

article/2025/11/9 17:49:09

贝塞尔曲线(Bézier curve),又称贝兹曲线或贝济埃曲线,是应用于二维图形应用程序的数学曲线。一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支点,线段像可伸缩的皮筋,我们在绘图工具上看到的钢笔工具就是来做这种矢量曲线的。贝塞尔曲线是计算机图形学中相当重要的参数曲线,在一些比较成熟的位图软件中也有贝塞尔曲线工具,如PhotoShop等。在Flash4中还没有完整的曲线工具,而在Flash5里面已经提供出贝塞尔曲线工具。
贝塞尔曲线于1962,由法国工程师皮埃尔·贝塞尔(Pierre Bézier)所广泛发表,他运用贝塞尔曲线来为汽车的主体进行设计。贝塞尔曲线最初由Paul de Casteljau于1959年运用de Casteljau演算法开发,以稳定数值的方法求出贝兹曲线。

下面我们展示用js绘制贝塞尔曲线(Bézier-Curve),效果图如下:

 在线demo地址

代码:BezierCurve.js


var canvas = document.querySelector('#canvas');
const ctx = canvas.getContext('2d');var width = canvas.clientWidth;
var height = canvas.clientHeight;// Setting the size of canvas when loading the page to fully fit it and draw
window.addEventListener('load', () => {canvas.height = canvas.clientHeight;canvas.width = canvas.clientWidth;draw(ctx);
})// Resizing canvas when page is resized 
window.addEventListener('resize', () => {canvas.height = canvas.clientHeight;canvas.width = canvas.clientWidth;width = canvas.clientWidth;height = canvas.clientHeight;draw(ctx);
})// UIlet settings = {t: 0.5,numPoints: 15,fill_lines: 1
}
webglLessonsUI.setupUI(document.querySelector('#ui'), settings, [{type: 'slider', key: 't', min: 0,    max: 1, step: 0.01, slide: (event, ui) => {settings.t = ui.value;ctx.clearRect(0, 0, canvas.width, canvas.height);draw();}},{type: 'slider', key: 'numPoints', name: 'Number of Points', min: 2,    max: 100, slide: (event, ui) => {settings.numPoints = ui.value;ctx.clearRect(0, 0, canvas.width, canvas.height);draw();}},{type: 'checkbox', key: 'fill_lines', name: 'Fill with lines', min: 2,    max: 100, change: (event, ui) => {ctx.clearRect(0, 0, canvas.width, canvas.height);draw();}}
]);// Setting variablesvar points = [[0.23 * width, 0.65 * height],[0.15 * width, 0.25 * height],[0.5 * width, 0.15 * height],[0.48 * width, 0.60 * height]
]var circle_width = 0.5;
var line_width = 1.5;
var radius = 4;
var move = 0;// Main function that will handle all drawings
function draw() {// Draws the control points and the linesfor (let i=0; i<4; i++) drawCircle(ctx, points[i], 0, circle_width, 'black', 6);drawLines(ctx, points, 4, line_width, 'black');let t = settings.t;// Each point in Q will be the corresponding t point between each pair of control pointslet Q = [];for (let i=0; i<3; i++) {Q.push([(1-t) * points[i][0] + t * points[i+1][0], (1-t) * points[i][1] + t * points[i+1][1]]);}for (let i=0; i<3; i++) drawCircle(ctx, Q[i], 1, circle_width, 'green', radius);drawLines(ctx, Q, 3, line_width, 'green');// We do the same for the resulting pointslet R = [];for (let i=0; i<2; i++) {R.push([(1-t) * Q[i][0] + t * Q[i+1][0], (1-t) * Q[i][1] + t * Q[i+1][1]]);}for (let i=0; i<2; i++) drawCircle(ctx, R[i], 1, circle_width, 'blue', radius);drawLines(ctx, R, 2, line_width, 'blue');// Finally we do the same for those 2 points and compute the t point between. That will be// be the point that belongs to the Bezier curvelet M = [(1-t) * R[0][0] + t * R[1][0], (1-t) * R[0][1] + t * R[1][1]];// Computes the specified number of points of the Bezier curve, draws them and// fills with lines between the points to generate an approximation of the curve.let bezier_pts = getPointsOnBezierCurve(points, settings.numPoints);for (let i=0; i<settings.numPoints; i++) drawCircle(ctx, bezier_pts[i], 1, circle_width, 'red', 2.5);if (settings.fill_lines) drawLines(ctx, bezier_pts, settings.numPoints, 3, 'red');// Draws M on top of the curvedrawCircle(ctx, M, 1, circle_width, 'blue', radius);
}// EVENTS:// Variable that will contain which point is clicked to move
var pt = 0;
document.addEventListener('mousedown', (event) => {let x = event.clientX;let y = event.clientY;// Checks which point is being pressedfor (let i=0; i<4; i++) {if(dist([x, y], points[i]) < 10) {move = 1;pt = i;}}
})// Sets move to 0 when the mouse button is up
document.addEventListener('mouseup', (event) => {move = 0;
})// Moves the selected point when the mouse button is pressed
document.addEventListener('mousemove', (event) => {let x = event.clientX;let y = event.clientY;if(move == 1) {points[pt] = [x, y];ctx.clearRect(0, 0, canvas.width, canvas.height);draw();}
})


http://chatgpt.dhexx.cn/article/UoN8TiKM.shtml

相关文章

Bezier曲线与B-Spline曲线

微分几何基础 微分集合是用微分的方法来研究曲线的局部性质&#xff0c;如曲线的弯曲程度等。 一条可以用参数表示的三维曲线是一个有界点集&#xff0c;可以写成一个带参数的、连续的、单值的数学函数&#xff1a; { x x ( t ) y y ( t ) z z ( t ) 0 ⩽ t ⩽ 1 p p ( t…

初识贝塞尔(bezier)曲线

文章目录 资料援引贝塞尔曲线的用途一阶贝塞尔&#xff08;bezier&#xff09;曲线二阶贝塞尔&#xff08;bezier&#xff09;曲线三阶贝塞尔&#xff08;bezier&#xff09;曲线高阶贝塞尔&#xff08;bezier&#xff09;曲线三阶贝塞尔曲线求插值&#xff08;Slerp&#xff0…

贝塞尔曲线(Bezier Curve)原理、公式推导及matlab代码实现

1. 定义 贝塞尔曲线(Bezier curve)&#xff0c;又称贝兹曲线或贝济埃曲线&#xff0c;是应用于二维图形应用程序的数学曲线。一般的矢量图形软件通过它来精确画出曲线&#xff0c;贝兹曲线由线段与节点组成&#xff0c;节点是可拖动的支点&#xff0c;线段像可伸缩的皮筋&#…

Bezier(贝塞尔曲线通用规律算法-DEMO)

之前也看过一些相关贝塞尔曲线的知识&#xff0c;但就是一直没有实践应用&#xff1b; 今天&#xff0c;听到有同事&#xff1a;程序、美术&#xff0c;在讨论相关的&#xff0c;人物的曲线路径行走的问题&#xff1b; 一些数学比较牛X的&#xff0c;说了用2阶&#xff0c;或…

bezier曲线原理(简单阐述)

原理和简单推导&#xff08;以三阶为例&#xff09;&#xff1a; 设P0、P02、P2是一条抛物线上顺序三个不同的点。过P0和P2点的两切线交于P1点&#xff0c;在P02点的切线交P0P1和P2P1于P01和P11&#xff0c;则如下比例成立&#xff1a; 这是所谓抛物线的三切线定理。 当P0&…

Bezier贝塞尔曲线

1.简介 Bezier曲线在图形学和游戏中经常使用&#xff0c;一般用的比较多的是4个控制点的贝塞尔曲线&#xff0c;这里手写了一个仅供参考&#xff08;注&#xff1a;理论上也可以写任意多个点&#xff08;3个及以上&#xff09;的贝塞尔&#xff0c;就是一个递归的过程&#xff…

java 贝塞尔曲线_在Java中绘制贝塞尔曲线

我需要创建一个简单的Java程序,通过任意数量的点逐个像素地绘制贝塞尔曲线.此刻,一切似乎都没问题,只是曲线总是在x 0 y 0坐标处结束. 截图1 截图2 我需要它在最后一点结束.我的大脑今天工作不太好,所以我正在寻求帮助. 这是我有的&#xff1a; private void drawScene(){ pr…

贝塞尔曲线(Bezier Curve)原理及公式推导

1. 定义 贝塞尔曲线(Bezier curve)&#xff0c;又称贝兹曲线或贝济埃曲线&#xff0c;是应用于二维图形应用程序的数学曲线。一般的矢量图形软件通过它来精确画出曲线&#xff0c;贝兹曲线由线段与节点组成&#xff0c;节点是可拖动的支点&#xff0c;线段像可伸缩的皮筋&#…

Bezier(贝塞尔)曲线小总结

在初学时&#xff0c;我发现Bezier曲线&#xff08;中文名贝塞尔曲线&#xff0c;想要了解历史发展等的可以看此百度百科&#xff1a;贝塞尔曲线_百度百科&#xff09;很难理解&#xff0c;故在此写了一篇自己的心得感悟。要理解它最重要的是理解Bernstein基函数。首先&#xf…

Bezier曲线原理—动态解释

Bezier曲线原理 贝塞尔曲线(Bzier curve)&#xff0c;又称贝兹曲线或贝济埃曲线&#xff0c;是应用于二维图形应用程序的数学曲线。一般的矢量图形软件通过它来精确画出曲线&#xff0c;贝兹曲线由线段与节点组成&#xff0c;节点是可拖动的支点&#xff0c;线段像可伸缩的皮…

正确的Bezier曲线的绘制

原文地址:http://blog.csdn.net/mylovestart/article/details/8434310 Bezier曲线是参数多项式曲线,它由一组控制多边形折线(控制多边形)的顶点唯一定义,在控制多边形的各顶点中,只有第一个和最后一个顶点在曲线上,其他的顶点则用以定义曲线的导数,阶次和形状 Bezier曲线的数…

根据Bezier曲线的定义公式实现Bezier曲线的绘制

Bezier曲线的定义公式 Pi是曲线上点的坐标&#xff08;x,y,(z0)&#xff09;&#xff0c; Bi,n(t)伯恩斯坦公式&#xff0c;绘制Bezier曲线的第一种方法是根据这个公式来绘制。首先看看绘制的效果&#xff1a; &#xff08;1&#xff09;计算定义中多项式的值 首先要求伯恩斯…

Bezier曲线描述

Bezier曲线 1.Bezier曲线的定义 当用曲线段拟合曲线f(x)时&#xff0c;可以把曲线表示为许多小线段φi(x)之和&#xff0c;其中φi(x)称为基&#xff08;混合&#xff09;函数。 这些基&#xff08;混合&#xff09;函数是要用于计算和显示的。因此&#xff0c;经常选择多项式…

Bezier曲线的绘制

Bezier曲线是参数多项式曲线,它由一组控制多边形折线(控制多边形)的顶点唯一定义,在控制多边形的各顶点中,只有第一个和最后一个顶点在曲线上,其他的顶点则用以定义曲线的导数,阶次和形状 Bezier曲线的数学基础是能够在第一个和最后一个顶点之间进行插值的一个多项式混合函数,…

Bezier曲线的生成算法

Bezier曲线的生成方法 生成一条Bezier曲线实际上就是要求出曲线上的点。 1.根据定义直接生成Bezier曲线 定义&#xff1a; 其中 那么生成步骤为&#xff1a; ①首先给出 的递归计算式&#xff1a; ②&#xff1a;将表示成分量形式 由于的计算量大&#xff0c;算法效率不高…

bezier曲线解析与代码(c++)

前言&#xff1a; 作为rhino重度用户&#xff0c;我对于nurbs建模早有耳闻&#xff0c;但对于何为nurbs却不得其解。最近借上《计算机辅助设计》课程的机会&#xff0c;对此作了一些深入的学习&#xff0c;于是在此记录一下一些课程笔记和课后思考。了解nurbs&#xff0c;主要对…

Bezier曲线构造

Bezier曲线构造 曲线公式 曲 线 &#xff1a; C ( u ) ∑ i 0 n B n , i ( u ) P i 基 函 数 &#xff1a; B n , i n ! i ! ( n − i ) ! u i ( 1 − u ) n − i 曲线&#xff1a;C(u) \sum^n_{i0}B_{n,i}(u)P_i\\ 基函数&#xff1a;B_{n,i}\frac{n!}{i!(n-i)!}u^i(1-u)…

java版 贝塞尔曲线算法

public void test() {CvPoint controlPoint[] new CvPoint[4];controlPoint[0] new CvPoint(50, 60); //起点controlPoint[1] new CvPoint(130, 200); //控制点controlPoint[2] new CvPoint(300, 360); //控制点controlPoint[3] new CvPoint(400, 600); //终点int n cont…

Bezier曲线原理及实现代码(c++)

http://devres.zoomquiet.io/data/20110728232822/index.html Bezier曲线原理及实现代码&#xff08;c&#xff09; 一、原理&#xff1a; 贝塞尔曲线于1962年&#xff0c;由法国工程师皮埃尔贝塞尔&#xff08;Pierre Bzier&#xff09;所广泛发表&#xff0c;他运用贝塞尔曲线…

用Java实现可交互的贝塞尔曲线(Bezier curve)

关于贝塞尔曲线的详细数学原理及公式可参考&#xff1a; 贝塞尔曲线_百度百科 我们来谈谈贝塞尔曲线 本文给出了一种用Java实现贝塞尔曲线的方法&#xff0c;并且可以用鼠标拖动改变锚点。 效果演示图&#xff1a; 这里引用百度百科给出的公式&#xff1a; 二次方公式 三次方…