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

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

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

2019-11-11 03:05:06
字體:
來源:轉載
供稿:網友

藍寶書 第三章

畫線 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在线播放| 日韩免费在线电影| 国产精品一区二区久久久| 中文字幕日韩欧美在线视频| 久久精品国产v日韩v亚洲| 黑人巨大精品欧美一区免费视频| 在线观看精品自拍私拍| 丁香五六月婷婷久久激情| 国产欧美精品日韩| 日韩欧美中文第一页| 国产精品无av码在线观看| 91影院在线免费观看视频| 日韩美女免费观看| 色香阁99久久精品久久久| 久久人人爽人人爽人人片亚洲| 久久久久久国产精品美女| 中文字幕av一区中文字幕天堂| 97超碰蝌蚪网人人做人人爽| 欧美性猛xxx| 精品久久久久久中文字幕| 亚洲精品国产电影| 狠狠久久五月精品中文字幕| 精品香蕉一区二区三区| 欧美精品在线网站| 久久久久久久久久久人体| 欧美日韩一二三四五区| 亚洲性夜色噜噜噜7777| 国产成人亚洲综合| 黑人巨大精品欧美一区二区一视频| 成人看片人aa| 91影视免费在线观看| 在线播放日韩欧美| 久久久免费电影| 国产精品视频区| 清纯唯美亚洲激情| 日本国产欧美一区二区三区| 欧美老女人在线视频| 国产乱人伦真实精品视频| 日韩女在线观看| 国产精品高清免费在线观看| 最新中文字幕亚洲| 久久久天堂国产精品女人| 欧美在线一级va免费观看| 亚洲天堂免费观看| 亚洲欧美日韩第一区| 国产精品视频久久久| 久久人人爽人人爽人人片av高清| 久久99久久亚洲国产| 91麻豆国产语对白在线观看| 日韩在线观看高清| 久久国产精品久久国产精品| 亚洲男子天堂网| 久久精品国产久精国产一老狼| 日韩毛片在线观看| 91精品视频在线| 欧美视频在线视频| 激情久久av一区av二区av三区| 亚洲三级 欧美三级| 国产91亚洲精品| 精品国产福利视频| 亚洲最大av在线| 一区三区二区视频| 国产精品日韩欧美综合| 国产精品偷伦视频免费观看国产| 久久国内精品一国内精品| 国产精品狠色婷| 亚洲变态欧美另类捆绑| 亚洲欧美福利视频| 超碰精品一区二区三区乱码| 91精品久久久久久久久久久久久久| 国产91ⅴ在线精品免费观看| 欧美激情国内偷拍| 国产精品视频男人的天堂| 欧美成人精品在线| 国内久久久精品| 91美女片黄在线观看游戏| 亚洲成色www8888| 久久久久久91| 久久久久久久久久久网站| 国产精品免费电影| 久久久999精品免费| 日韩经典一区二区三区| 国产亚洲欧美日韩精品| 2019亚洲日韩新视频| 98精品在线视频| 成人av电影天堂| 亚洲视频在线观看免费| 国内精品400部情侣激情| 在线成人中文字幕| 国产精品亚洲片夜色在线| 午夜精品一区二区三区在线视| 色小说视频一区| 日本一区二区不卡| 亚洲国产高清高潮精品美女| 午夜精品一区二区三区在线播放| 成人午夜在线视频一区| 成人福利在线观看| 国产成人精品久久二区二区91| 色中色综合影院手机版在线观看| 亚洲经典中文字幕| 国产精品久久77777| 韩国欧美亚洲国产| 欧美性精品220| 播播国产欧美激情| 国产成人精品在线视频| 国产一区二区三区在线免费观看| 亚洲国产精品视频在线观看| 久久99热这里只有精品国产| 97香蕉超级碰碰久久免费的优势| 国内精品久久久久| 亚洲精品成人av| 中文字幕亚洲欧美日韩2019| 欧美日韩爱爱视频| 成人亲热视频网站| 亚洲欧洲成视频免费观看| 国产精品美女999| 国产精品91一区| 日韩欧美亚洲成人| 国产在线久久久| 欧美中文字幕视频| 欧美中文字幕在线观看| 欧美一级片久久久久久久| 欧美性生交大片免网| 欧美一级视频在线观看| 亚州av一区二区| 亚洲精品影视在线观看| 在线播放国产一区中文字幕剧情欧美| 欧美一级大胆视频| 深夜福利日韩在线看| 久久免费视频网| 777777777亚洲妇女| 一二美女精品欧洲| 亚洲精品永久免费| 亚洲国产女人aaa毛片在线| 亚洲日本欧美日韩高观看| 亚洲精品国偷自产在线99热| 欧美二区乱c黑人| 视频在线观看一区二区| 国产激情久久久| 日韩精品视频免费| 日韩小视频在线观看| 久久久久久久一区二区三区| 久久精品中文字幕电影| 欧美中文在线字幕| 麻豆精品精华液| 91成人在线播放| 欧美与黑人午夜性猛交久久久| 欧美综合一区第一页| 91久久精品国产| 成人a在线观看| 久久国产加勒比精品无码| 久久福利视频网| 欧美一区二区三区免费视| 欧美性猛交丰臀xxxxx网站| 久久久免费av|