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

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

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

2019-11-11 04:38:10
字體:
來源:轉載
供稿:網友

藍寶書 第三章

畫線 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
色综久久综合桃花网| 久久久久久久国产精品视频| 国产精品色午夜在线观看| 国产精品最新在线观看| 日韩在线不卡视频| 性欧美xxxx| 欧美国产日韩在线| 全亚洲最色的网站在线观看| 欧美性xxxxxx| www.色综合| 91在线高清视频| 91欧美视频网站| 欧美极品少妇与黑人| 欧美激情一区二区三级高清视频| 91色视频在线导航| 一本色道久久综合亚洲精品小说| 日韩av成人在线| 日日摸夜夜添一区| 亚洲性av网站| 性视频1819p久久| 日韩不卡中文字幕| 91免费福利视频| 国产在线播放不卡| 久久精品电影网| 日韩在线www| 亚洲欧美中文日韩v在线观看| 91爱视频在线| 国产成人高清激情视频在线观看| 伊人久久久久久久久久久| 日韩精品在线视频观看| 久久久久久有精品国产| 日韩精品一区二区三区第95| 热re91久久精品国99热蜜臀| 最近免费中文字幕视频2019| 久久精品中文字幕免费mv| www国产91| 国产伦精品一区二区三区精品视频| 一区二区三区无码高清视频| 尤物精品国产第一福利三区| 欧美激情xxxx性bbbb| 91性高湖久久久久久久久_久久99| 亚洲欧美制服第一页| 国产美女直播视频一区| 亚洲女人天堂视频| 日韩av一区在线观看| 久久久精品在线观看| 亚洲剧情一区二区| 欧美日韩成人在线视频| 在线观看国产欧美| 精品国产一区二区三区久久狼黑人| 欧美一级片在线播放| 91精品视频在线免费观看| 亚洲第一国产精品| 亚洲国产精品嫩草影院久久| 日本不卡视频在线播放| 搡老女人一区二区三区视频tv| 久久综合国产精品台湾中文娱乐网| 色偷偷888欧美精品久久久| 国产日韩视频在线观看| 欧美黑人xxxⅹ高潮交| 最近2019中文字幕在线高清| 成人国产精品日本在线| 久久精品一偷一偷国产| 在线观看精品国产视频| 日韩视频在线免费观看| 国模极品一区二区三区| 精品一区电影国产| 久久av中文字幕| 日韩人在线观看| 亚洲一区第一页| 欧美一区二区色| 亚洲成人a**站| 亚洲深夜福利视频| 成人国产精品免费视频| 亚洲韩国欧洲国产日产av| 欧美日韩亚洲系列| 久久久国产成人精品| 欧美精品手机在线| 性欧美办公室18xxxxhd| 在线看国产精品| 日韩中文字幕在线精品| 日韩电影网在线| 久久久久久国产精品| 尤物99国产成人精品视频| 黑人巨大精品欧美一区二区| 亚洲第一天堂无码专区| 成人网在线免费看| 日韩视频免费大全中文字幕| 日韩av在线播放资源| 亚洲精品成人免费| 亚洲人成亚洲人成在线观看| 亚洲视频777| 日韩一中文字幕| www日韩欧美| 国产精品视频一| 日韩精品极品毛片系列视频| 亚洲精品视频在线观看视频| 日韩精品在线电影| 91av在线不卡| 日韩在线视频国产| 国产精品成av人在线视午夜片| 国产极品精品在线观看| 在线视频日本亚洲性| 岛国视频午夜一区免费在线观看| 亚洲人在线观看| 亚洲а∨天堂久久精品喷水| 亚洲精品456在线播放狼人| 亚洲免费成人av电影| 色琪琪综合男人的天堂aⅴ视频| 久久中国妇女中文字幕| 日韩精品免费电影| 中文字幕亚洲一区在线观看| 8x海外华人永久免费日韩内陆视频| 国产黑人绿帽在线第一区| 久久精品视频在线播放| 91成人在线观看国产| 亚洲国产精品小视频| 亚洲天堂免费观看| 91色琪琪电影亚洲精品久久| 精品福利在线观看| 欧美激情视频免费观看| 久久精品视频播放| 亚洲丁香婷深爱综合| 久久电影一区二区| 欧美成人激情图片网| 最好看的2019年中文视频| 精品欧美一区二区三区| 2018中文字幕一区二区三区| 91夜夜揉人人捏人人添红杏| 日本午夜人人精品| 国内伊人久久久久久网站视频| 中文字幕欧美在线| 自拍偷拍亚洲在线| 精品欧美一区二区三区| 成人淫片在线看| 成人动漫网站在线观看| 亚洲日本aⅴ片在线观看香蕉| 成人精品视频久久久久| 国产成人午夜视频网址| 亚洲视频777| 欧美最猛性xxxxx(亚洲精品)| 亚洲欧美国内爽妇网| 久久91精品国产91久久久| 欧美福利视频在线观看| 欧美亚洲国产日韩2020| 亚洲人在线观看| 国产成人精品电影久久久| 91九色在线视频| 久久久精品在线观看| 亚洲二区中文字幕| 亚洲美女福利视频网站| 国产精品高潮在线| 亚洲精品国产品国语在线| 精品福利在线观看| 欧美色欧美亚洲高清在线视频| 亚洲成成品网站| 九九热99久久久国产盗摄| 国产原创欧美精品| 国产精品福利观看| 精品一区二区三区电影| 国产精品视频永久免费播放| 日韩电影大片中文字幕| 久久艹在线视频| 国产精品久久久久久五月尺|