欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

OpenGL绘制三次Bezier曲线

时间:2022-01-30 11:22:00|栏目:C代码|点击:

本文实例为大家分享了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++用Dijkstra(迪杰斯特拉)算法求最短路径

栏    目:C代码

下一篇:C语言打印杨辉三角示例汇总

本文标题:OpenGL绘制三次Bezier曲线

本文地址:http://www.codeinn.net/misctech/191831.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有