using System;

 using System.Collections.Generic;

 using System.ComponentModel;

 using System.Data;

 using System.Drawing;

 using System.Linq;

 using System.Text;

 using System.Windows.Forms;

 namespace doBezier

 {

     public partial class Form1 : Form

     {

         PointF[] p = new PointF[];   //存储控制点坐标

         int count;                    //记录已输入的控制点个数

         Graphics g;                  //GDI 对象

         public Form1()

         {

             InitializeComponent();

             g = CreateGraphics();

             count = ;

         }

         private void Form1_Load(object sender, EventArgs e)

         {

         }

         private void Form1_MouseClick(object sender, MouseEventArgs e)

         {

             if (e.Button == MouseButtons.Left)

             {

                 if (count == )      //如果输入的是第一个点,先清空窗口

                     g.Clear(BackColor);

                 g.FillRectangle(Brushes.Red, e.X - , e.Y - , , );  //输出一个标记

                 p[count] = new PointF(e.X, e.Y);                 //存储

                 count ;                                    //记录输入控制点个数

                 return;

             }

             else

             {

                 PointF q1 = new PointF();

                 PointF q2 = new PointF();

                 double u;

                 for (int i = ; i <= ; i )//生成100个点并连成折线

                 {

                     u = (double)i / 100.0;

                     if (i == )

                     {

                         q1 = deCasteljau(u);

                     }

                     else

                     {

                         q2 = deCasteljau(u);

                         g.DrawLine(Pens.Black, q1, q2);

                         q1.X = q2.X;

                         q1.Y = q2.Y;

                     }

                 }

                 count = ;

                 return;

             }

         }

         PointF deCasteljau(double u)   //曲线参数为u,函数返回一个二维点 

         {

             int i, k;

             //以下将控制点数组p[],复制到数组q[]

             PointF[] q = new PointF[];

             for (i = ; i < count; i )

             {

                 q[i].X = p[i].X;

                 q[i].Y = p[i].Y;

             }

             //以下用de Casteljau割角算法计算bezier曲线上参数点u对应的x,y,

             //计算完成后,结果存储在q[0]

             for (k = ; k < count; k )

                 for (i = ; i < count - k; i )

                 {

                     q[i].X = (float)(1.0 - u) * q[i].X   (float)u * q[i   ].X;

                     q[i].Y = (float)(1.0 - u) * q[i].Y   (float)u * q[i   ].Y;

                 }

             return new PointF(q[].X, q[].Y);

         }

         private void Form1_Paint(object sender, PaintEventArgs e)

         {

         }

     }

 }

C# 实现Bezier曲线(vs2008)的更多相关文章

  1. Bezier曲线的原理 及 二次Bezier曲线的实现

    原文地址:http://blog.csdn.net/jimi36/article/details/7792103 Bezier曲线的原理 Bezier曲线是应用于二维图形的曲线.曲线由顶点和控制点组成 ...

  2. [摘抄] Bezier曲线、B样条和NURBS

    Bezier曲线.B样条和NURBS,NURBS是Non-Uniform Rational B-Splines的缩写,都是根据控制点来生成曲线的,那么他们有什么区别了?简单来说,就是: Bezier曲 ...

  3. 连续bezier曲线的实现

    需求场景 一系列的坐标点,划出一条平滑的曲线 3次Bezier曲线 基本上大部分绘图工具都实现了3次Bezier曲线,4个点确定一条3次Bezier曲线.以html5中的canvas为例 let ct ...

  4. 7.5.5编程实例-Bezier曲线曲面绘制

    (a)Bezier曲线                         (b) Bezier曲面 1. 绘制Bezier曲线 #include <GL/glut.h> GLfloat ct ...

  5. 实验6 Bezier曲线生成

    1.实验目的: 了解曲线的生成原理,掌握几种常见的曲线生成算法,利用VC+OpenGL实现Bezier曲线生成算法. 2.实验内容: (1) 结合示范代码了解曲线生成原理与算法实现,尤其是Bezier ...

  6. 简单而粗暴的方法画任意阶数Bezier曲线

    简单而粗暴的方法画任意阶数Bezier曲线 虽然说是任意阶数,但是嘞,算法原理是可以到任意阶数,计算机大概到100多阶就会溢出了 Bezier曲线介绍] [本文代码] 背景 在windows的Open ...

  7. python bezier 曲线

    1.手写bezier公式,生成bezier代码, 如果给的点数过多,则会生成一半bezier曲线,剩下的一半就需要进行拼接: import numpy as np import matplotlib. ...

  8. iOS Bezier曲线

    https://www.jianshu.com/p/2316f0d9db65 1. Bezier曲线 相关软件:PaintCode:可以直接画图,软件根据图像生产Bezier曲线 相关概念:UIBez ...

  9. Bezier曲线的实现——de Casteljau算法

    这学期同时上了计算机图形学和计算方法两门课,学到这部分的时候突然觉得de Casteljau递推算法特别像牛顿插值,尤其递推计算步骤很像牛顿差商表. 一开始用伯恩斯坦多项式计算Bezier曲线的时候, ...

随机推荐

  1. VSCODE安装以及使用Python运行调试代码的简单记录

    1. VScode安装 官网下载VSCODE https://code.visualstudio.com/ 下载呢windows的x64安装包,安装stable的版本 当前日期 2018.01.15 ...

  2. delphi dbgrid 修改、更新、删除

    https://zhidao.baidu.com/question/580946797.html DELPHI 中,使用 dbgrid显示数据.窗体上放置三个按钮,caption分别为:修改.删除.更 ...

  3. Java之"instanceof"和"isInstance"代码举例

    源码: /** * @Date:2018-04-20 * @Description:判断Instance * - instanceof方法返回一个boolean类型的值,意在告诉我们对象是不是某个特定 ...

  4. js脚本 将本地图片路径转换为html

    公司业务类似于电商, 因此有很多纯图片展示的商品详情页, 类似淘宝店商品页面下的多个图片组成的商品详情页, 页面很简单, 就是一大串img标签, 但是每次做详情页都要配合emmet一顿操作( 如下图 ...

  5. maven dependcymanage作用在父类里面定义依赖包 子类不会自动继承需要主动使用 这样解决了父类引用任意包 子类就会引用的问题

    maven dependcymanage作用在父类里面定义依赖包 子类不会自动继承需要主动使用 这样解决了父类引用任意包 子类就会引用的问题  子类在引用时候 不需要加上版本号

  6. Minimum Cost POJ - 2516(模板题。。没啥好说的。。)

    题意: 从发货地到商家 送货 求送货花费的最小费用... 有m个发货地,,,n个商家,,每个商家所需要的物品和物品的个数都不一样,,,每个发货地有的物品和物品的个数也不一样,,, 从不同的发货地到不同 ...

  7. 棋盘问题 POJ - 1321

    题意: 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放 ...

  8. 【Gym 100733D】Little thief Shi(取数,DP)

    题 Shi realized that he was almost out of money, even renting Shitalian lands. Shi was walking on a s ...

  9. 洛谷 P1613 跑路 解题报告

    P1613 跑路 题目描述 小\(A\)的工作不仅繁琐,更有苛刻的规定,要求小\(A\)每天早上在\(6:00\)之前到达公司,否则这个月工资清零.可是小\(A\)偏偏又有赖床的坏毛病.于是为了保住自 ...

  10. bzoj4571/luogu3293 美味 (主席树+贪心)

    首先想到建出可持久化trie树然后在上面贪心,但是它加了一个数所以不能这么做 但依然可以贪心,仿照上面那个的过程,如果设y是在第i位上^b是1的数(前面的位数已经贪好了),我只要在[l,r]范围内能有 ...