亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

OpenGL繪制三次Bezier曲線

 更新時間:2020年04月20日 16:25:37   作者:wyg1997  
這篇文章主要為大家詳細介紹了OpenGL繪制三次Bezier曲線,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了OpenGL繪制三次Bezier曲線的具體代碼,供大家參考,具體內(nèi)容如下

計算公式:

運行結果:

代碼如下:

#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)   //兩個參數(shù):窗口被移動后大小
{
  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;
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 使用c++實現(xiàn)OpenCV繪制旋轉矩形圖形

    使用c++實現(xiàn)OpenCV繪制旋轉矩形圖形

    這篇文章主要給大家介紹了使用c++實現(xiàn)OpenCV繪制圖形旋轉矩形的方法案例,通過圖文及代碼形式進行了詳細的描述,有需要的朋友可以參考下,希望可以有所幫助
    2021-08-08
  • 淺析C++內(nèi)存布局

    淺析C++內(nèi)存布局

    本文給大家介紹了C++內(nèi)存布局的相關知識,通過進程間通信比線程間通信難也是因為進程間的用戶空間是相互隔離的,無法相互訪問,需要通過進程間通信方式通信,通過內(nèi)核地址空間
    2021-10-10
  • C語言數(shù)據(jù)結構哈希表詳解

    C語言數(shù)據(jù)結構哈希表詳解

    哈希表是一種根據(jù)關鍵碼去尋找值的數(shù)據(jù)映射結構,該結構通過把關鍵碼映射的位置去尋找存放值的地方,說起來可能感覺有點復雜,我想我舉個例子你就會明白了,最典型的的例子就是字典
    2022-02-02
  • C語言銀行系統(tǒng)課程設計

    C語言銀行系統(tǒng)課程設計

    這篇文章主要為大家詳細介紹了C語言銀行系統(tǒng)課程設計,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 詳解如何實現(xiàn)C++虛函數(shù)調(diào)用匯編代碼

    詳解如何實現(xiàn)C++虛函數(shù)調(diào)用匯編代碼

    多態(tài)是C++中最重要的特性之一,對虛函數(shù)的調(diào)用在C++代碼中是隨處可見的,本篇文章我們詳細探討一下,感興趣的朋友快來看看吧
    2021-11-11
  • C++?超詳細梳理繼承的概念與使用

    C++?超詳細梳理繼承的概念與使用

    這篇文章主要介紹了C++?多繼承詳情,C++支持多繼承,即允許一個類同時繼承多個類。只有C++等少數(shù)語言支持多繼承,下面我們就來看看具體的多繼承介紹吧,需要的朋友可以參考一下
    2022-03-03
  • C++ TensorflowLite模型驗證的過程詳解

    C++ TensorflowLite模型驗證的過程詳解

    這篇文章給大家介紹了C++ TensorflowLite模型驗證的過程,測試代碼,主要是RunInference()和read_file(),詳細操作過程跟隨小編一起看看吧
    2021-08-08
  • C語言實現(xiàn)貪吃蛇小游戲

    C語言實現(xiàn)貪吃蛇小游戲

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • VC MFC非模態(tài)對話框的實現(xiàn)方法

    VC MFC非模態(tài)對話框的實現(xiàn)方法

    這篇文章主要介紹了VC MFC非模態(tài)對話框的實現(xiàn)方法,有助于讀者加深對于模態(tài)對話框與非模態(tài)對話框的理解與運用,需要的朋友可以參考下
    2014-07-07
  • 手把手教你用C語言實現(xiàn)三子棋

    手把手教你用C語言實現(xiàn)三子棋

    三子棋是黑白棋的一種。三子棋是一種民間傳統(tǒng)游戲,又叫九宮棋、圈圈叉叉、一條龍、井字棋等。這篇文章就教你如何用C語言實現(xiàn)三子棋的功能
    2021-08-08

最新評論