计算机图形学实验——直线,多边形绘制算法(橡皮筋效果)

本文主要是介绍计算机图形学实验——直线,多边形绘制算法(橡皮筋效果),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

计算机图形学实验1.1橡皮筋效果绘制

  • OpenGL橡皮筋效果实现
    • 橡皮筋效果直线
    • 橡皮筋效果多边形
    • 运行截图
    • 小结

OpenGL橡皮筋效果实现

「实验题目」
设计一个二维卡通交互设计系统,实现直线,多边形绘制算法(橡皮筋效果)

「题目分析」
我们知道两点确定一条直线,对于直线来说,橡皮筋效果无非固定直线的一端,另一端随着鼠标的拖动不断绘制;所以大体思路讨论鼠标点击、拖动和绘制直线和这两个控制点之间的关系就vans了。

对于多边形来说,我采用的方法是通过直线定义多边形,相当于对直线橡皮筋的推广画法;比如说,一个矩形可以用对角线定义,随着对角线的伸缩,矩形的橡皮筋效果就实现了
P.S. TA说,正式的橡皮筋多边形绘制不是这么草率.好吧,那不管:(

橡皮筋效果直线

显示函数
用一个FixPoint数组保存确定下来的控制点对,这样就可以保存下绘画痕迹了。
这样想,直线橡皮筋需要固定一个控制点位置(鼠标按下位置),第二个控制点随着鼠标拖动不断更新并绘制,当鼠标抬起,则不需要绘制了。使用isDraw状态的切换,控制什么时候可以绘制新的图元

void Display(){glClear(GL_COLOR_BUFFER_BIT);glClearColor(0,0,0,1);glColor3f(0, 0.4, 0);glPolygonMode(GL_FRONT, GL_FILL);//历史记录for(int i=1; i <= counter; i++){switch(drawMode){case 1: DrawLine(FixPoint[i].x1, FixPoint[i].y1, FixPoint[i].x2, FixPoint[i].y2); break;case 2: DrawTriangle(FixPoint[i].x1, FixPoint[i].y1, FixPoint[i].x2, FixPoint[i].y2); break;case 3: DrawRectangle(FixPoint[i].x1, FixPoint[i].y1, FixPoint[i].x2, FixPoint[i].y2); break;case 4: DrawHexagon(FixPoint[i].x1, FixPoint[i].y1, FixPoint[i].x2, FixPoint[i].y2); break;case 5: DrawCircle(FixPoint[i].x1, FixPoint[i].y1, FixPoint[i].x2, FixPoint[i].y2); break;}}//橡皮筋效果if(isDraw == 1){switch(drawMode){case 1: DrawLine(ponint1x, ponint1y, ponint2x, ponint2y); break;case 2: DrawTriangle(ponint1x, ponint1y, ponint2x, ponint2y); break;case 3: DrawRectangle(ponint1x, ponint1y, ponint2x, ponint2y); break;case 4: DrawHexagon(ponint1x, ponint1y, ponint2x, ponint2y); break;case 5: DrawCircle(ponint1x, ponint1y, ponint2x, ponint2y); break;}}glutSwapBuffers();
}

监听mouseClick的回调函数
处理isDraw是否开启绘画的逻辑,鼠标抬起的时候写入点击—抬起位置对(即第一、第二个控制点相应坐标)到历史记录数组中保存即可

void mouseClick(GLint button, GLint action, GLint xMouse, GLint yMouse){//三个阶段: 按下确定第一个点,推拽更新第二个点坐标(仍然只能确定一个点),实现橡皮筋效果;//         抬起确定第二个点位置,固定形状if(button == GLUT_LEFT_BUTTON && action == GLUT_DOWN){isDraw = 1;ponint1x = xMouse; ponint1y = windowHeight - yMouse;}if(button == GLUT_LEFT_BUTTON && action == GLUT_UP){isDraw = 0;ponint2x = xMouse; ponint2y = windowHeight - yMouse;FixPoint[++counter] = Node{ponint1x, ponint1y, ponint2x, ponint2y};glutPostRedisplay();}
}

监听mouseClick的回调函数

void mouseMove(GLint xMouse, GLint yMouse){//根据拖动更新第二个坐标位置ponint2x = xMouse; ponint2y = windowHeight - yMouse;glutPostRedisplay();
}

橡皮筋效果多边形

这里实现就比较简单了,通过从左下右上的弹性"控制线",定义了三角形(等腰三角形中线)、矩形(对角线)、正六边形(斜对称轴)、圆形(水平直径)
等腰三角形绘制Function

void DrawTriangle(double x1, double y1, double x2, double y2){glBegin(GL_POLYGON);glVertex2f(x1, y1);glVertex2f(x2, y2);glVertex2f(2*x2-x1, y1);glEnd();
}

矩形绘制Function

void DrawRectangle(double x1, double y1, double x2, double y2){double height = abs(y2 - y1);glBegin(GL_POLYGON);glVertex2f(x1,y1);glVertex2f(x1,y1 + height);glVertex2f(x2,y2);glVertex2f(x2,y2 - height);glEnd();
}

正六边形绘制Function

void DrawHexagon(double x1, double y1, double x2, double y2){double edgeLen = sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2)) / 2;glBegin(GL_POLYGON);glVertex2f(x1, y1);glVertex2f(x1 - edgeLen/2, (y1+y2)/2);glVertex2f(x1, y2);glVertex2f(x2, y2);glVertex2f(x1 + 3*edgeLen/2, (y1+y2)/2);glVertex2f(x2, y1);glEnd();
}

圆形形绘制Function

void DrawCircle(double x1, double y1, double x2, double y2){double ox = (x1+x2)/2, oy = (y1+y2)/2;double r = sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));glBegin(GL_POLYGON);int n = 360;for(int i=0; i<n; i++)glVertex2f(r*cos(2*i*PI/n)+ox, r*sin(2*i*PI/n)+oy);glEnd();
}

运行截图

画直线
在这里插入图片描述

小结

就酱紫,然后木有了,感觉够用了。
完整代码资源戳这里🦄️

这篇关于计算机图形学实验——直线,多边形绘制算法(橡皮筋效果)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/336412

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

防近视护眼台灯什么牌子好?五款防近视效果好的护眼台灯推荐

在家里,灯具是属于离不开的家具,每个大大小小的地方都需要的照亮,所以一盏好灯是必不可少的,每个发挥着作用。而护眼台灯就起了一个保护眼睛,预防近视的作用。可以保护我们在学习,阅读的时候提供一个合适的光线环境,保护我们的眼睛。防近视护眼台灯什么牌子好?那我们怎么选择一个优秀的护眼台灯也是很重要,才能起到最大的护眼效果。下面五款防近视效果好的护眼台灯推荐: 一:六个推荐防近视效果好的护眼台灯的

【WebGPU Unleashed】1.1 绘制三角形

一部2024新的WebGPU教程,作者Shi Yan。内容很好,翻译过来与大家共享,内容上会有改动,加上自己的理解。更多精彩内容尽在 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信号:digital_twin123 在 3D 渲染领域,三角形是最基本的绘制元素。在这里,我们将学习如何绘制单个三角形。接下来我们将制作一个简单的着色器来定义三角形内的像素

dp算法练习题【8】

不同二叉搜索树 96. 不同的二叉搜索树 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 示例 1: 输入:n = 3输出:5 示例 2: 输入:n = 1输出:1 class Solution {public int numTrees(int n) {int[] dp = new int