位置: 编程技术 - 正文

[置顶] 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函数)

  • 注册资本印花税减半征收政策
  • 房地产开发企业土地增值税预缴
  • 组成计税价格是销售额吗
  • 待转销项税额是几级科目
  • 基金份额股权转让
  • 个税代扣代缴手续费返还 申请
  • 开票资料需要哪些内容
  • 开了负数发票增值税申报表怎么填
  • 收到诉讼状之后怎么办
  • 个人股东之间股权转让的溢价账务处理
  • 财务报表其他应付款为负数
  • 白条入账所得税怎么做纳税调曾
  • 事业单位代扣社保分录
  • 开具的发票是否为印花税的应税凭证?
  • 税控盘清盘怎么做
  • 发票作废是不是很麻烦
  • 个人房补申请书怎么办
  • 增值税扣税凭证包括增值税专用发票
  • 教学用品采购
  • 发票抬头开错跨月了怎么办?
  • 代收污水处理费要交税吗
  • 出售固定资产账务如何处理
  • 向投资者宣告发放股利会影响所有者权益吗
  • 高新技术企业如何节税
  • win10开机启动文件路径
  • 检验费用会计分录
  • php魔术方法的讲解与使用
  • msmpeng.exe 是什么
  • 企业固定资产有哪些
  • 知识产权作用
  • 预售商品房转让合同
  • 偏食和挑食会有什么不良后果?
  • thinkphp smarty
  • 汇算清缴补交的所得税怎么记帐
  • 应收借方表示什么
  • 非征期不能抄报
  • 国内版的chatpdf
  • python获取字符串中汉字的个数
  • 交上年企业所得税多少
  • 商品流通企业商品验收入库流程
  • python中的装饰器的使用实战
  • 文章让修改了就一定会接收吗?
  • sqlserver2012安装后找不到
  • 应付职工薪酬的会计科目
  • 亏损企业所得税汇算清缴怎么做
  • 非盈利组织企业所得税主表如何填列
  • 股东投资款可以拿出来吗
  • 本月冲红上月发票后的税款能抵减吗
  • 企业注销清算报告模板
  • 差旅费属于什么会计科目 会计分录
  • 设计规划费入什么科目
  • 母子公司可以合并吗
  • 汽修厂印花税怎么交
  • 保理融资的费用由谁承担
  • 出口退税转免税怎么写个说明
  • 什么叫做对公转账
  • 公司给员工租房没有发票怎么入账
  • 客户逾期不付款,需要赔多少违约金
  • 营改增题目
  • 淘宝电商怎么做账
  • 设置账簿的依据
  • centos的命令行界面输入
  • 如何用pe弄双系统引导
  • xp系统本地连接启用不了
  • windows8无线网络选项消失不见
  • windows预体验版本遇到问题
  • win10打开此电脑的快捷键
  • /proc目录造成linux根目录爆满
  • opengl画矩形函数
  • javaweb技术栈是什么
  • 学习名言警句 励志
  • javascript函数大全
  • ios shell脚本
  • 在文本输入框中的输入内容是
  • javascript中变量的命名规则有哪些?
  • css弹性布局是什么
  • 湖北省地方税务局公告2014年第7号
  • 江苏 税务局
  • 贵州国家电子税务局登录入口
  • 契税的征收机关是哪里
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设