亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

OpenGL 學習筆記3_2(繪制線相關)

2019-11-11 03:04:51
字體:
來源:轉載
供稿:網友

藍寶書 第三章

畫線 Line

1)兩點定一條實線

glBegin(GL_LINES);

glVertex3f(……);//點a

glVertex3f(……);//點b

glVertex3f(……);//點c

glVertex3f(……);//點d

glEnd();

繪制線段ab、cd

相關代碼見例3.4

2)繪制連續線段,連接密集的點成曲線

glBegin(GL_LINE_STRip);

glVertex3f(……);//點a

glVertex3f(……);//點b

glVertex3f(……);//點c

glVertex3f(……);//點d

glEnd();

繪制線段ab、bc、cd

相關代碼見例3.5

3)設置線寬度

voidglLineWidth(GLfloatwidth);設置線寬度

GLfloat sizes[2]; // 存放線寬度的范圍

GLfloat step; // 存放每次改變線寬度的最小增量

glGetFloatv(GL_LINE_WIDTH_RANGE,sizes);//獲取線寬范圍

glGetFloatv(GL_LINE_WIDTH_GRANULARITY,&step);//獲取最小增量

相關代碼見例3.6

4)繪制虛線,自定義虛線模板

glEnable(GL_LINE_STIPPLE);//啟用模板功能

void glLineStipple(GLintfactor, GLushort pattern);//設置影響因子及模板格式

factor代表每位二進制數在線上用幾個單位顯示

相關代碼見例3.7

例3.4 繪制多條線段

#include <windows.h>  #include <math.h>  #include <GL/GL.h>  #include <GL/GLU.h>  #include <GL/glut.h>  // Define a constant for the value of PI  #define GL_PI 3.1415f  // This function does any needed initialization on the rendering  void RenderScene(void){	GLfloat x, y, z, angle; // Storage for coordinates and angles  	GLfloat sizes[2]; // Store supported point size range  	GLfloat step; // Store supported point size increments  	GLfloat curSize; // Store current point size  	// Clear the window with current clearing color  	glClear(GL_COLOR_BUFFER_BIT);	// Save matrix state and do the rotation  	glPushMatrix();	//glRotatef(30.0f, 1.0f, 0.0f, 0.0f);//書中的xRot代表x軸偏移的角度  	//glRotatef(30.0f, 0.0f, 1.0f, 0.0f);//書中的yRot代表y軸偏移的角度  	// Get supported point size range and step size  	glGetFloatv(GL_POINT_SIZE_RANGE, sizes);	glGetFloatv(GL_POINT_SIZE_GRANULARITY, &step);	// Set the initial point size  	curSize = sizes[0];	// Set beginning z coordinate  	z = -50.0f;	// Call only once for all remaining points  	// Call only once for all remaining points	glBegin(GL_LINES);	// All lines lie in the xy plane.	z = 0.0f;	for (angle = 0.0f; angle <= GL_PI; angle += (GL_PI / 20.0f))	{		// Top half of the circle		x = 50.0f*sin(angle);		y = 50.0f*cos(angle);		glVertex3f(x, y, z); // First endpoint of line		// Bottom half of the circle		x = 50.0f*sin(angle + GL_PI);		y = 50.0f*cos(angle + GL_PI);		glVertex3f(x, y, z); // Second endpoint of line	}	// Done drawing points	glEnd();	// Restore transformations  	glPopMatrix();	// Flush drawing commands  	glutSwapBuffers();}void SetuPRC(){	// Black background  	glClearColor(0.0f, 0.0f, 0.0f, 1.0f);	// Set drawing color to green  	glColor3f(0.0f, 1.0f, 0.0f);}void ChangeSize(GLsizei w, GLsizei h){	GLfloat nRange = 100.0f;	// Prevent a divide by zero  	if (h == 0)		h = 1;	// Set Viewport to window dimensions  	glViewport(0, 0, w, h);	// Reset projection matrix stack  	glMatrixMode(GL_PROJECTION);	glLoadIdentity();	// Establish clipping volume (left, right, bottom, top, near, far)  	if (w <= h)		glOrtho(-nRange, nRange, -nRange*h / w, nRange*h / w, -nRange, nRange);	else		glOrtho(-nRange*w / h, nRange*w / h, -nRange, nRange, -nRange, nRange);	// Reset Model view matrix stack  	glMatrixMode(GL_MODELVIEW);	glLoadIdentity();}int main(int argc, char* argv[]){	glutInit(&argc, argv);	glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA);	glutInitWindowSize(800, 600);	glutCreateWindow("Bounce");	glutDisplayFunc(RenderScene);//顯示回調函數  	glutReshapeFunc(ChangeSize);//窗口大小變形回調函數  	SetupRC();	glutMainLoop();	return 0;}例3.5 點連曲線

#include <windows.h>  #include <math.h>  #include <GL/GL.h>  #include <GL/GLU.h>  #include <GL/glut.h>  // Define a constant for the value of PI  #define GL_PI 3.1415f  // This function does any needed initialization on the rendering  void RenderScene(void){	GLfloat x, y, z, angle; // Storage for coordinates and angles  	GLfloat sizes[2]; // Store supported point size range  	GLfloat step; // Store supported point size increments  	GLfloat curSize; // Store current point size  	// Clear the window with current clearing color  	glClear(GL_COLOR_BUFFER_BIT);	// Save matrix state and do the rotation  	glPushMatrix();	glRotatef(30.0f, 1.0f, 0.0f, 0.0f);//書中的xRot代表x軸偏移的角度  	glRotatef(30.0f, 0.0f, 1.0f, 0.0f);//書中的yRot代表y軸偏移的角度  	// Get supported point size range and step size  	glGetFloatv(GL_POINT_SIZE_RANGE, sizes);	glGetFloatv(GL_POINT_SIZE_GRANULARITY, &step);	// Set the initial point size  	curSize = sizes[0];	// Set beginning z coordinate  	z = -50.0f;	// Call only once for all remaining points  	// Call only once for all remaining points	glBegin(GL_LINE_STRIP);	z = -50.0f;	for (angle = 0.0f; angle <= (2.0f*GL_PI)*3.0f; angle += 0.1f)	{		x = 50.0f*sin(angle);		y = 50.0f*cos(angle);		// Specify the point and move the z value up a little		glVertex3f(x, y, z);		z += 0.5f;	}	// Done drawing points	glEnd();	// Restore transformations  	glPopMatrix();	// Flush drawing commands  	glutSwapBuffers();}void SetupRC(){	// Black background  	glClearColor(0.0f, 0.0f, 0.0f, 1.0f);	// Set drawing color to green  	glColor3f(0.0f, 1.0f, 0.0f);}void ChangeSize(GLsizei w, GLsizei h){	GLfloat nRange = 100.0f;	// Prevent a divide by zero  	if (h == 0)		h = 1;	// Set Viewport to window dimensions  	glViewport(0, 0, w, h);	// Reset projection matrix stack  	glMatrixMode(GL_PROJECTION);	glLoadIdentity();	// Establish clipping volume (left, right, bottom, top, near, far)  	if (w <= h)		glOrtho(-nRange, nRange, -nRange*h / w, nRange*h / w, -nRange, nRange);	else		glOrtho(-nRange*w / h, nRange*w / h, -nRange, nRange, -nRange, nRange);	// Reset Model view matrix stack  	glMatrixMode(GL_MODELVIEW);	glLoadIdentity();}int main(int argc, char* argv[]){	glutInit(&argc, argv);	glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA);	glutInitWindowSize(800, 600);	glutCreateWindow("Bounce");	glutDisplayFunc(RenderScene);//顯示回調函數  	glutReshapeFunc(ChangeSize);//窗口大小變形回調函數  	SetupRC();	glutMainLoop();	return 0;}例3.6 調整線寬度

#include <windows.h>  #include <math.h>  #include <GL/GL.h>  #include <GL/GLU.h>  #include <GL/glut.h>  // Define a constant for the value of PI  #define GL_PI 3.1415f  // This function does any needed initialization on the rendering  void RenderScene(void){	GLfloat y; // Storage for varying Y coordinate	GLfloat fSizes[2]; // Line width range metrics	GLfloat fCurrSize; // Save current size	// Clear the window with current clearing color  	glClear(GL_COLOR_BUFFER_BIT);	// Save matrix state and do the rotation  	glPushMatrix();	//glRotatef(30.0f, 1.0f, 0.0f, 0.0f);//書中的xRot代表x軸偏移的角度  	//glRotatef(30.0f, 0.0f, 1.0f, 0.0f);//書中的yRot代表y軸偏移的角度  	// Get supported point size range and step size  	glGetFloatv(GL_LINE_WIDTH_RANGE, fSizes);	fCurrSize = fSizes[0];	// Set the initial point size  	// Step up y axis 20 units at a time	for (y = -90.0f; y < 90.0f; y += 20.0f)	{		// Set the line width		glLineWidth(fCurrSize);		// Draw the line		glBegin(GL_LINES);		glVertex2f(-80.0f, y);		glVertex2f(80.0f, y);		glEnd();		// Increase the line width		fCurrSize += 1.0f;	}	// Restore transformations  	glPopMatrix();	// Flush drawing commands  	glutSwapBuffers();}void SetupRC(){	// Black background  	glClearColor(0.0f, 0.0f, 0.0f, 1.0f);	// Set drawing color to green  	glColor3f(0.0f, 1.0f, 0.0f);}void ChangeSize(GLsizei w, GLsizei h){	GLfloat nRange = 100.0f;	// Prevent a divide by zero  	if (h == 0)		h = 1;	// Set Viewport to window dimensions  	glViewport(0, 0, w, h);	// Reset projection matrix stack  	glMatrixMode(GL_PROJECTION);	glLoadIdentity();	// Establish clipping volume (left, right, bottom, top, near, far)  	if (w <= h)		glOrtho(-nRange, nRange, -nRange*h / w, nRange*h / w, -nRange, nRange);	else		glOrtho(-nRange*w / h, nRange*w / h, -nRange, nRange, -nRange, nRange);	// Reset Model view matrix stack  	glMatrixMode(GL_MODELVIEW);	glLoadIdentity();}int main(int argc, char* argv[]){	glutInit(&argc, argv);	glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA);	glutInitWindowSize(800, 600);	glutCreateWindow("Bounce");	glutDisplayFunc(RenderScene);//顯示回調函數  	glutReshapeFunc(ChangeSize);//窗口大小變形回調函數  	SetupRC();	glutMainLoop();	return 0;}

例3.7 自定義模板繪制虛線

#include <windows.h>  #include <math.h>  #include <GL/GL.h>  #include <GL/GLU.h>  #include <GL/glut.h>  // Define a constant for the value of PI  #define GL_PI 3.1415f  // This function does any needed initialization on the rendering  void RenderScene(void){	GLfloat y; // Storage for varying y coordinate	GLint factor = 1; // Stippling factor	GLushort pattern = 0x5555; // Stipple pattern	// Clear the window with current clearing color  	glClear(GL_COLOR_BUFFER_BIT);	// Save matrix state and do the rotation  	glPushMatrix();	//glRotatef(30.0f, 1.0f, 0.0f, 0.0f);//書中的xRot代表x軸偏移的角度  	//glRotatef(30.0f, 0.0f, 1.0f, 0.0f);//書中的yRot代表y軸偏移的角度  	// Get supported point size range and step size  	glEnable(GL_LINE_STIPPLE);	// Step up Y axis 20 units at a time	for (y = -90.0f; y < 90.0f; y += 20.0f)	{		// Reset the repeat factor and pattern		glLineStipple(factor, pattern);		// Draw the line		glBegin(GL_LINES);		glVertex2f(-80.0f, y);		glVertex2f(80.0f, y);		glEnd();		factor++;	}	// Restore transformations  	glPopMatrix();	// Flush drawing commands  	glutSwapBuffers();}void SetupRC(){	// Black background  	glClearColor(0.0f, 0.0f, 0.0f, 1.0f);	// Set drawing color to green  	glColor3f(0.0f, 1.0f, 0.0f);}void ChangeSize(GLsizei w, GLsizei h){	GLfloat nRange = 100.0f;	// Prevent a divide by zero  	if (h == 0)		h = 1;	// Set Viewport to window dimensions  	glViewport(0, 0, w, h);	// Reset projection matrix stack  	glMatrixMode(GL_PROJECTION);	glLoadIdentity();	// Establish clipping volume (left, right, bottom, top, near, far)  	if (w <= h)		glOrtho(-nRange, nRange, -nRange*h / w, nRange*h / w, -nRange, nRange);	else		glOrtho(-nRange*w / h, nRange*w / h, -nRange, nRange, -nRange, nRange);	// Reset Model view matrix stack  	glMatrixMode(GL_MODELVIEW);	glLoadIdentity();}int main(int argc, char* argv[]){	glutInit(&argc, argv);	glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA);	glutInitWindowSize(800, 600);	glutCreateWindow("Bounce");	glutDisplayFunc(RenderScene);//顯示回調函數  	glutReshapeFunc(ChangeSize);//窗口大小變形回調函數  	SetupRC();	glutMainLoop();	return 0;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线看片第一页欧美| 亚洲自拍偷拍第一页| 亚洲精品福利在线观看| 国产精品无av码在线观看| 亚洲精品乱码久久久久久按摩观| 日韩精品极品视频免费观看| 日韩电影中文字幕| 国产精品旅馆在线| 日本精品视频在线| 国产日韩换脸av一区在线观看| 亚洲精品色婷婷福利天堂| 亚洲精品影视在线观看| 欧美一区二区三区精品电影| 亚洲精品美女在线观看| 国产91色在线| 亚洲人精选亚洲人成在线| 国产欧美久久久久久| 精品亚洲va在线va天堂资源站| 一区二区亚洲精品国产| 精品成人乱色一区二区| 久久久精品视频成人| 亚洲精品日产aⅴ| 久久高清视频免费| 欧美不卡视频一区发布| 欧美极品少妇xxxxx| 国产精品露脸av在线| 清纯唯美亚洲激情| 在线中文字幕日韩| 亚洲综合精品伊人久久| 亚洲福利在线看| 亚洲色图35p| 久久久久久久久久久免费精品| 97视频在线观看免费高清完整版在线观看| 国产精品美女在线观看| 色综合久久中文字幕综合网小说| 欧美在线一区二区三区四| 欧美性色xo影院| 国模叶桐国产精品一区| 91精品国产综合久久香蕉的用户体验| 国产精品99久久99久久久二8| 一区二区三区美女xx视频| 日韩精品有码在线观看| 欧美大秀在线观看| 日本亚洲欧洲色| 51ⅴ精品国产91久久久久久| 人人爽久久涩噜噜噜网站| 亚洲高清福利视频| 中文字幕免费精品一区高清| 午夜精品蜜臀一区二区三区免费| 亚洲精品成a人在线观看| 日韩精品中文字| 国产精品视频一区二区三区四| 欧美日韩精品在线观看| 色狠狠av一区二区三区香蕉蜜桃| 欧美午夜激情小视频| 国内精品久久影院| 成人综合网网址| 日韩精品小视频| 国产最新精品视频| 国产精品久久久久久久久久东京| 亚洲男女自偷自拍图片另类| 成人黄色网免费| 在线视频精品一| 欧美日韩国产一区中文午夜| 一区二区三区国产视频| 欧美乱大交xxxxx另类电影| 国外成人在线视频| 国产精品视频精品| 伊人久久久久久久久久| 日韩高清电影免费观看完整| 2019中文在线观看| 啪一啪鲁一鲁2019在线视频| 国产精品扒开腿做爽爽爽视频| 精品国产拍在线观看| 国产精品福利网站| 欧美日韩中文字幕日韩欧美| 久久久精品久久久| 91久久精品久久国产性色也91| 欧美性视频精品| 亚洲а∨天堂久久精品喷水| 国产视频亚洲精品| 成人免费观看49www在线观看| 国产日韩精品在线| 国产精自产拍久久久久久蜜| 国产精品久久久久久久久免费| 日韩免费在线播放| 欧美日韩色婷婷| 97超级碰碰人国产在线观看| 亚洲老板91色精品久久| 精品自拍视频在线观看| 亚洲精品美女久久久| 国产精品夜间视频香蕉| 日本高清视频精品| 不卡av电影院| 性欧美xxxx| 日韩一区二区久久久| 国产精品99久久久久久人| 中文字幕在线观看亚洲| 国产一区二中文字幕在线看| 国产精品入口夜色视频大尺度| 日韩中文字幕不卡视频| 97成人精品区在线播放| 亚洲天堂第二页| 国产成人鲁鲁免费视频a| 成人国产在线激情| 中国china体内裑精亚洲片| 亚洲999一在线观看www| 亚洲电影免费观看高清完整版| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲跨种族黑人xxx| 亚洲va欧美va在线观看| 这里只有精品视频| 丰满岳妇乱一区二区三区| 久久久91精品| 亚洲r级在线观看| 国产偷亚洲偷欧美偷精品| 欧美夫妻性视频| 亚洲欧美资源在线| 欧美丰满少妇xxxxx做受| 久久艳片www.17c.com| 中文字幕v亚洲ⅴv天堂| 日韩中文视频免费在线观看| 日韩www在线| 亚洲免费成人av电影| 日韩中文视频免费在线观看| 韩国19禁主播vip福利视频| 亚洲一区二区三区xxx视频| 久久中文字幕视频| 国产精品中文字幕在线| 国产亚洲精品久久久| 成人综合网网址| 国产999精品久久久影片官网| 一本一本久久a久久精品综合小说| 成人黄色片在线| 久久91亚洲人成电影网站| 日产精品久久久一区二区福利| 97精品国产97久久久久久免费| 欧美成年人视频网站欧美| 国产免费成人av| 中文字幕欧美日韩精品| 中文字幕亚洲一区二区三区五十路| 国产视频观看一区| 欧美极品在线视频| 国产精品一区二区三区成人| 97视频在线观看免费高清完整版在线观看| 91免费福利视频| 国产精品久久久久久久一区探花| 久久91超碰青草是什么| 亚洲精品中文字幕女同| 欧美成人午夜免费视在线看片| 亚洲va久久久噜噜噜| 日韩在线www| 啪一啪鲁一鲁2019在线视频| 国产精品日韩av| 在线看日韩av| 日韩免费中文字幕| 欧美日韩性生活视频| 国产精品久久久久久久久久99| 欧美性色视频在线| 日韩欧美在线视频日韩欧美在线视频| 久久精品国产成人精品| 中文字幕日韩欧美在线| 深夜福利91大全| 欧美日韩国产成人高清视频|