OpenGL绘制三次Bezier曲线

 更新时间:2020年04月20日 16:25:37   作者:wyg1997  
这篇文章主要为大家详细介绍了OpenGL绘制三次Bezier曲线,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了OpenGL绘制三次Bezier曲线的具体代码,供大家参考,具体内容如下

计算公式:

运行结果:

代码如下:

#include<gl/glut.h>
#include<math.h>
#include<windows.h>
#include<vector>
#include<algorithm>
using namespace std;
struct Point
{
  int x, y;
  Point(){};
  Point(int tx, int ty)
  {
    x = tx;
    y = ty;
  }
};
vector<Point> p;
double getRatio(double t,double a,double b,double c,double d)
{
  return a * pow(t, 3) + b * pow(t, 2) + c * t + d;
}
void Bezier()
{
  int n = 500;
  double derta = 1.0 / n;
  glPointSize(2);
  glColor3d(0, 0, 0);
  glBegin(GL_POINTS);
  for (int i = 1; i < n; i++)
  {
    double t = derta * i;
    double ratio[4];
    ratio[0] = getRatio(t, -1, 3, -3, 1);
    ratio[1] = getRatio(t, 3, -6, 3, 0);
    ratio[2] = getRatio(t, -3, 3, 0, 0);
    ratio[3] = getRatio(t, 1, 0, 0, 0);
    double x=0, y=0;
    for (int j = 0; j < 4; j++)
    {
      x += ratio[j] * p[j].x;
      y += ratio[j] * p[j].y;
    }
    glVertex2d(x, y);
  }
  glEnd();
}
void myDisplay()
{
  glClear(GL_COLOR_BUFFER_BIT);  //清除颜色缓存和深度缓存

  //画点
  glPointSize(5);
  glColor3d(1, 0, 0);
  glBegin(GL_POINTS);
  for (int i = 0; i < p.size(); i++)
    glVertex2d(p[i].x, p[i].y);
  glEnd();

  //画线
  glLineWidth(2);
  glColor3d(0, 1, 0);
  glBegin(GL_LINE_STRIP);
  for (int i = 0; i < p.size(); i++)
    glVertex2d(p[i].x, p[i].y);
  glEnd();

  if (p.size() == 4)
    Bezier();

  glFlush();
}
void mouse(int button, int state, int x, int y)
{
  if (button == GLUT_LEFT_BUTTON && state == GLUT_DOWN && p.size() < 4)
  {
    Point t(x, y);
    p.push_back(t);
    glutPostRedisplay();
  }
}

void Reshape(int w, int h)   //两个参数:窗口被移动后大小
{
  glViewport(0, 0, w, h);
  glMatrixMode(GL_PROJECTION);
  glLoadIdentity();
  gluOrtho2D(0, w, h, 0);
  glMatrixMode(GL_MODELVIEW);
  glLoadIdentity();
}

void initWindow(int &argc, char *argv[], int width, int height, char *title)  //初始化并显示到屏幕中央
{
  glutInit(&argc, argv);
  glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);
  glutInitWindowPosition((GetSystemMetrics(SM_CXSCREEN) - width) >> 1, (GetSystemMetrics(SM_CYSCREEN) - height) >> 1);    //指定窗口位置
  glutInitWindowSize(width, height);    //指定窗口大小
  glutCreateWindow(title);

  glClearColor(1, 1, 1, 0);
  glShadeModel(GL_FLAT);
}

int main(int argc, char *argv[])
{
  initWindow(argc, argv, 600, 600, "四点画Bezier曲线");

  puts("\n\t鼠标在窗口点击四次后自动绘制出Bezier曲线");

  glutDisplayFunc(myDisplay);
  glutReshapeFunc(Reshape);
  glutMouseFunc(mouse);

  glutMainLoop();
  return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 使用c++实现OpenCV绘制旋转矩形图形

    使用c++实现OpenCV绘制旋转矩形图形

    这篇文章主要给大家介绍了使用c++实现OpenCV绘制图形旋转矩形的方法案例,通过图文及代码形式进行了详细的描述,有需要的朋友可以参考下,希望可以有所帮助
    2021-08-08
  • 浅析C++内存布局

    浅析C++内存布局

    本文给大家介绍了C++内存布局的相关知识,通过进程间通信比线程间通信难也是因为进程间的用户空间是相互隔离的,无法相互访问,需要通过进程间通信方式通信,通过内核地址空间
    2021-10-10
  • C语言数据结构哈希表详解

    C语言数据结构哈希表详解

    哈希表是一种根据关键码去寻找值的数据映射结构,该结构通过把关键码映射的位置去寻找存放值的地方,说起来可能感觉有点复杂,我想我举个例子你就会明白了,最典型的的例子就是字典
    2022-02-02
  • C语言银行系统课程设计

    C语言银行系统课程设计

    这篇文章主要为大家详细介绍了C语言银行系统课程设计,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • 详解如何实现C++虚函数调用汇编代码

    详解如何实现C++虚函数调用汇编代码

    多态是C++中最重要的特性之一,对虚函数的调用在C++代码中是随处可见的,本篇文章我们详细探讨一下,感兴趣的朋友快来看看吧
    2021-11-11
  • C++ 超详细梳理继承的概念与使用

    C++ 超详细梳理继承的概念与使用

    这篇文章主要介绍了C++ 多继承详情,C++支持多继承,即允许一个类同时继承多个类。只有C++等少数语言支持多继承,下面我们就来看看具体的多继承介绍吧,需要的朋友可以参考一下
    2022-03-03
  • C++ TensorflowLite模型验证的过程详解

    C++ TensorflowLite模型验证的过程详解

    这篇文章给大家介绍了C++ TensorflowLite模型验证的过程,测试代码,主要是RunInference()和read_file(),详细操作过程跟随小编一起看看吧
    2021-08-08
  • C语言实现贪吃蛇小游戏

    C语言实现贪吃蛇小游戏

    这篇文章主要为大家详细介绍了C语言实现贪吃蛇小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • VC MFC非模态对话框的实现方法

    VC MFC非模态对话框的实现方法

    这篇文章主要介绍了VC MFC非模态对话框的实现方法,有助于读者加深对于模态对话框与非模态对话框的理解与运用,需要的朋友可以参考下
    2014-07-07
  • 手把手教你用C语言实现三子棋

    手把手教你用C语言实现三子棋

    三子棋是黑白棋的一种。三子棋是一种民间传统游戏,又叫九宫棋、圈圈叉叉、一条龙、井字棋等。这篇文章就教你如何用C语言实现三子棋的功能
    2021-08-08

最新评论