位置: 编程技术 - 正文

[置顶] Bezier曲线的动态绘制([置顶]bilinovel)

编辑:rootadmin
#include <gl/glut.h>#include<math.h>#pragma comment(linker, "/subsystem:"windows" /entry:"mainCRTStartup"")int SCREEN_HEIGHT = ;int NUMPOINTS = 0;class Point{public:float x, y;void setxy(float x2, float y2){x = x2;y = y2;}};Point abc[4];Point bef[3];Point mid[2];Point link[];void myInit(){glClearColor(0.0, 0.0, 0.0, 0.0);glColor3f(1.0f, 0.0, 0.0);glPointSize(4.0);glMatrixMode(GL_PROJECTION);glLoadIdentity();gluOrtho2D(0.0, , 0.0, .0);}void drawDot(Point pt){glBegin(GL_POINTS);glVertex2f(pt.x, pt.y);glEnd();glFlush();}void drawLine(Point p1, Point p2){glBegin(GL_LINES);glVertex2f(p1.x, p1.y);glVertex2f(p2.x, p2.y);glEnd();glFlush();}//四个控制点的贝塞尔曲线 即三次Bezier曲线 void drawBezier(Point A, Point B, Point C, Point D){for (double t = 0.0; t <= 1.0; t &#;= 0.){bef[0].setxy((1 - t)*A.x &#; t*B.x, (1 - t)*A.y &#; t*B.y);bef[1].setxy((1 - t)*B.x &#; t*C.x, (1 - t)*B.y &#; t*C.y);bef[2].setxy((1 - t)*C.x &#; t*D.x, (1 - t)*C.y &#; t*D.y);mid[0].setxy((1 - t)*bef[0].x &#; t*bef[1].x, (1 - t)*bef[0].y &#; t*bef[1].y);mid[1].setxy((1 - t)*bef[1].x &#; t*bef[2].x, (1 - t)*bef[1].y &#; t*bef[2].y);link[0].setxy((1 - t)*mid[0].x &#; t*mid[1].x, (1 - t)*mid[0].y &#; t*mid[1].y);glColor3f(1.0f, 1.0f, 0.0f);drawLine(bef[0], bef[1]);glColor3f(1.0f, 1.0f, 0.0f);drawLine(bef[1], bef[2]);glColor3f(1.0f, 1.0f, 0.0f);drawLine(mid[0], mid[1]);glColor3f(1.0f, 0.0f, 0.0f);drawDot(link[0]);glColor3f(0.0f, 0.0f, 0.0f);drawLine(bef[0], bef[1]);glColor3f(0.0f, 0.0f, 0.0f);drawLine(bef[1], bef[2]);glColor3f(0.0f, 0.0f, 0.0f);drawLine(mid[0], mid[1]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[0], abc[1]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[1], abc[2]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[2], abc[3]);}}void myDisplay(){glClear(GL_COLOR_BUFFER_BIT);glFlush();}void ChangeSize(GLsizei width, GLsizei height){GLfloat aspect_init, aspect;glViewport(0, 0, width, height);glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);aspect_init = 4.0 / 3.0;aspect = 1.0*width / height;glMatrixMode(GL_PROJECTION);glLoadIdentity();//Keep Aspect of Current Windowif (aspect <= aspect_init)glViewport(0, (height - width / aspect) / 2, width, width / aspect_init);elseglViewport((width - height*aspect_init) / 2, 0, height*aspect_init, height);glMatrixMode(GL_MODELVIEW);glLoadIdentity();glOrtho(-2, 2, -2, 2, -2, 2);}void myMouse(int button, int state, int x, int y){if (button == GLUT_LEFT_BUTTON && state == GLUT_DOWN){abc[NUMPOINTS].setxy((float)x, (float)(SCREEN_HEIGHT - y));NUMPOINTS&#;&#;;if (NUMPOINTS == 4){glColor3f(1.0, 0.0, 1.0);drawDot(abc[0]);glColor3f(1.0, 0.0, 1.0);drawDot(abc[1]);glColor3f(1.0, 0.0, 1.0);drawDot(abc[2]);glColor3f(1.0, 0.0, 1.0);drawDot(abc[3]); glColor3f(0.0, 1.0, 0.0);drawLine(abc[0], abc[1]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[1], abc[2]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[2], abc[3]);//Point POld = abc[0];drawBezier(abc[0], abc[1], abc[2], abc[3]);glColor3f(1.0, 0.0, 1.0);drawDot(abc[0]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[0], abc[1]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[1], abc[2]);glColor3f(0.0, 1.0, 0.0);drawLine(abc[2], abc[3]);glColor3f(1.0, 0.0, 0.0);NUMPOINTS = 0;}}}void main(int argc, char **argv){glutInit(&argc, argv);// 在这里设置双缓冲区。 glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);glutInitWindowPosition(0, 0);glutInitWindowSize(, );glutCreateWindow("bezier");glutMouseFunc(myMouse);myInit();//glutIdleFunc(RenderScene);glutDisplayFunc(myDisplay);glutMainLoop();}

推荐整理分享[置顶] Bezier曲线的动态绘制([置顶]bilinovel),希望有所帮助,仅作参考,欢迎阅读内容。

[置顶]
        Bezier曲线的动态绘制([置顶]bilinovel)

文章相关热门搜索词:[置顶]游戏名:chivalry2,[置顶]从lv2开始开挂的原勇者候悠闲的异世界生活,[置顶] [笔记],[置顶] [笔记],[置顶]从lv2开始开挂的原勇者候悠闲的异世界生活,[置顶] [笔记],[置顶]bilinovel,[置顶]bilinovel,内容如对您有帮助,希望把文章链接给更多的朋友!

glutSwapBuffers函数用法 文章来源:

三 OpenGL常见平面图形绘制代码 //代码模板#includeglut.hvoiddisplayFunc(){glClearColor(0.0f,0.0f,0.0f,0.0f);//在RGB模式下,使用glClearColor清空之后画布的颜色glClear(GL_COLOR_BUFFER_BIT);//清空画布glColor3f(1.

四 OpenGL中的变换及示例 一视点变换相机位置(视点)的变换voidgluLookAt(GLdoubleeyex,GLdoubleeyey,GLdoubleeyez,GLdoublecenterx,GLdoublecentery,GLdoublecenterz,GLdoubleupx,GLdoubleupy,GLdoubleupz)二模型变换模

标签: [置顶]bilinovel

本文链接地址:https://www.jiuchutong.com/biancheng/369577.html 转载请保留说明!

上一篇:VS2012下基于Glut OpenGL显示一些立体图形示例程序(vs2019怎么用gets)

下一篇:glutSwapBuffers函数用法(glrotatef函数)

  • 账面价值与计税基础一般会产生差异的是
  • 堤防是啥
  • 增值税抵扣怎么取消
  • 确认固定资产减值损失
  • 小区业委会是否可以进行经营活动?
  • 高新企业奖励金怎么领
  • 交易性金融资产和其他权益工具投资的区别
  • 建筑业预交增值税按什么算
  • 印花税什么情况可以退
  • 合伙企业的合伙协议
  • 专票红冲账务处理
  • 低值易耗品如何报废
  • 收到现金货款可以直接用吗
  • 税率修改后对价格的影响
  • 影视发行收入该如何做税收处理?
  • 提取职工福利费计入什么科目
  • 一个人有多份工作
  • 管理服务费入什么科目
  • 网上申报时纳税人怎么填
  • 记账凭证领用材料如何填写
  • 日常管理的基本内容及方法是什么
  • 应收账款及票据
  • 工程施工购买的材料费会计分录
  • 公司增资减资法条
  • windows10如何设置屏幕常亮
  • 建筑公司小规模纳税人怎么做账报税
  • 专家评审费报销仅附签字笔迹相似
  • 固定资产清理是什么项目
  • 以公司名义购买房产的利与弊
  • 腾讯手游助手如何退出登录
  • Windows 11 Build 22000.176 (KB5006050) 更新推送(附更新内容+安装)
  • php数组函数实现机选双色球
  • 简述php可支持哪些数据类型
  • PHP:Memcached::getVersion()的用法_Memcached类
  • 印度活根桥 (© dhritipurna/Shutterstock)
  • php获取当天是星期几
  • php生成压缩包
  • php图片加水印实例分析
  • php zmq
  • php jsonp
  • wordpress neve
  • 零申报企业所得税怎么申报
  • 参展费可以抵扣吗
  • 织梦面包屑导航最后的分隔符大于号去掉方法
  • 企业应付账款明细表
  • mongodb配置文件详解
  • 融资租赁的种类
  • 开票是否享受优惠
  • ip地址跳转域名
  • 员工公交费补贴怎么入账
  • 企业汇算清缴的工资薪金支出是怎么填
  • 请培训老师的费用怎么处理
  • sql中的聚合函数
  • 交易性金融资产入账价值怎么计算
  • 工程项目劳务分包招投标要多久
  • 怎么对外投资
  • 发工资四舍五入多了几块钱怎么办
  • 预收账款的借方余额反映的是
  • 农业项目土地流转
  • 收到货款会计分录怎么写
  • 支付信息表
  • sqlserver中delete、update中使用表别名和oracle的区别
  • sql server多表查询
  • mac系统10.10
  • 超级简单的方法
  • quickdcf.exe - quickdcf是什么进程 作用是什么
  • 照相机文件名
  • 自定义ui界面
  • js获取中文拼音
  • 安卓手机屏幕不好使了怎么办
  • 关于shell的说法,不正确的是
  • 分享一些常用的文件
  • c#中thread的用法
  • shell 计算表达式
  • 安卓如何取消长按电源键关机
  • android自定义view流程
  • Javascript Objects详解
  • 辽宁省国家税务局电子税务局官网
  • 公司注销报税怎么申报
  • 沈阳铁西区房产中介电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设