亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? main.cpp

?? it is a visual c++ file
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
			glVertexPointer(3, GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[1].vertices[0].position);
			glNormalPointer(GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[1].vertices[0].normal);
			glDrawElements(GL_TRIANGLES, models[1].numIndices, GL_UNSIGNED_INT, models[1].indices);
		}
		glPopMatrix();
	}

	glPopAttrib();




	//Draw shadow volumes
	glPushAttrib(GL_ALL_ATTRIB_BITS);
	glColorMask(0, 0, 0, 0);
	glShadeModel(GL_FLAT);
	glDepthMask(0);
	glDepthFunc(GL_LESS);
	glEnable(GL_STENCIL_TEST);

	for(int i=0; i<numTori; ++i)
	{
		//See which model is used for this torus
		int currentModel;
		if(i==0 || i==1)
			currentModel=0;
		else
			currentModel=1;

		//Calculate silhouette edges for this torus if not using vertex program volumes
		if(!useVPVolumes)
			models[currentModel].CalculateSilhouetteEdges(torus[i].objectSpaceLightPosition);

		//If using vertex program volumes, bind the program and
		//Set up vertex pointers to draw models
		if(useVPVolumes)
		{
			glBindProgramARB(GL_VERTEX_PROGRAM_ARB, shadowVolumeVP);

			//Pass light position as env parameter 0
			glProgramEnvParameter4fvARB(GL_VERTEX_PROGRAM_ARB, 0, VECTOR4D(torus[i].objectSpaceLightPosition));

			glEnable(GL_VERTEX_PROGRAM_ARB);

			glVertexPointer(3, GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[currentModel].vertices[0].position);
			glNormalPointer(GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[currentModel].vertices[0].normal);
		}
			
		glPushMatrix();
		glTranslatef(torus[i].position.x, torus[i].position.y, torus[i].position.z);
		glRotatef(90.0f, 1.0f, 0.0f, 0.0f);
		glRotatef(torus[i].angle, 0.0f, 0.0f, 1.0f);


		
		//If not always using zFail, see if it is necessary for this particular torus
		bool needZFail=true;

		if(!alwaysUseZFail)
		{
			//If the bounding sphere of the model is completely behind any of the lightPlanes,
			//no need for z fail.
			for(int currentPlane=0; currentPlane<6; ++currentPlane)
			{
				if(	lightPlanes[currentPlane].normal.x*torus[i].position.x+
					lightPlanes[currentPlane].normal.y*torus[i].position.y+
					lightPlanes[currentPlane].normal.z*torus[i].position.z+
					lightPlanes[currentPlane].intercept<-modelRadii[currentModel])
				{
					needZFail=false;
					break;
				}
			}
		}

		

		//Draw shadow volumes WITHOUT two sided stencil
		if(!useTwoSidedStencil)
		{
			//Using zfail
			if(alwaysUseZFail || needZFail)
			{
				//Increment stencil buffer for back face depth fail
				glStencilFunc(GL_ALWAYS, 0, ~0);
				glStencilOp(GL_KEEP, GL_INCR, GL_KEEP);
				glCullFace(GL_FRONT);
				//Draw the shadow volume if not using vertex program
				if(!useVPVolumes)
					models[currentModel].DrawInfiniteShadowVolume(	torus[i].objectSpaceLightPosition,
																	true);
				//Draw the model if using vertex program
				if(useVPVolumes)
					glDrawElements(GL_TRIANGLES, models[currentModel].numIndices, GL_UNSIGNED_INT, models[currentModel].indices);

			
				//Decrement stencil buffer for front face depth fail
				glStencilOp(GL_KEEP, GL_DECR, GL_KEEP);
				glCullFace(GL_BACK);
				//Draw the shadow volume if not using vertex program
				if(!useVPVolumes)
					models[currentModel].DrawInfiniteShadowVolume(	torus[i].objectSpaceLightPosition,
																	true);
				//Draw the model if using vertex program
				if(useVPVolumes)
					glDrawElements(GL_TRIANGLES, models[currentModel].numIndices, GL_UNSIGNED_INT, models[currentModel].indices);

			}
			else	//using zpass
			{
				//Increment stencil buffer for front face depth pass
				glStencilFunc(GL_ALWAYS, 0, ~0);
				glStencilOp(GL_KEEP, GL_KEEP, GL_INCR);
				glCullFace(GL_BACK);
				//Draw the shadow volume if not using vertex program
				if(!useVPVolumes)
					models[currentModel].DrawInfiniteShadowVolume(	torus[i].objectSpaceLightPosition,
																	false);
				//Draw the model if using vertex program
				if(useVPVolumes)
					glDrawElements(GL_TRIANGLES, models[currentModel].numIndices, GL_UNSIGNED_INT, models[currentModel].indices);


				//Decrement stencil buffer for back face depth pass
				glStencilOp(GL_KEEP, GL_KEEP, GL_DECR);
				glCullFace(GL_FRONT);
				//Draw the shadow volume if not using vertex program
				if(!useVPVolumes)
					models[currentModel].DrawInfiniteShadowVolume(	torus[i].objectSpaceLightPosition,
																	false);
				//Draw the model if using vertex program
				if(useVPVolumes)
					glDrawElements(GL_TRIANGLES, models[currentModel].numIndices, GL_UNSIGNED_INT, models[currentModel].indices);
			}
		}

		//Draw shadow volumes WITH two sided stencil
		if(useTwoSidedStencil)
		{
			//Using zfail
			if(alwaysUseZFail || needZFail)
			{
				glDisable(GL_CULL_FACE);
				
				//Increment(with wrapping) for back face depth fail
				glActiveStencilFaceEXT(GL_BACK);
				glStencilFunc(GL_ALWAYS, 0, ~0);
				glStencilOp(GL_KEEP, GL_INCR_WRAP_EXT, GL_KEEP);

				//Decrement(with wrapping) for front face depth fail
				glActiveStencilFaceEXT(GL_FRONT);
				glStencilFunc(GL_ALWAYS, 0, ~0);
				glStencilOp(GL_KEEP, GL_DECR_WRAP_EXT, GL_KEEP);

				//Enable 2 sided stencil
				glEnable(GL_STENCIL_TEST_TWO_SIDE_EXT);

				//Draw the shadow volume if not using vertex program
				if(!useVPVolumes)
					models[currentModel].DrawInfiniteShadowVolume(	torus[i].objectSpaceLightPosition,
																	true);
				//Draw the model if using vertex program
				if(useVPVolumes)
					glDrawElements(GL_TRIANGLES, models[currentModel].numIndices, GL_UNSIGNED_INT, models[currentModel].indices);

			}
			else	//using zpass
			{
				glDisable(GL_CULL_FACE);

				//Increment(with wrapping) for front face depth pass
				glActiveStencilFaceEXT(GL_FRONT);
				glStencilFunc(GL_ALWAYS, 0, ~0);
				glStencilOp(GL_KEEP, GL_KEEP, GL_INCR_WRAP_EXT);

				//Decrement(with wrapping) for back face depth pass
				glActiveStencilFaceEXT(GL_BACK);
				glStencilFunc(GL_ALWAYS, 0, ~0);
				glStencilOp(GL_KEEP, GL_KEEP, GL_DECR_WRAP_EXT);

				//Enable 2 sided stencil
				glEnable(GL_STENCIL_TEST_TWO_SIDE_EXT);

				//Draw the shadow volume if not using vertex program
				if(!useVPVolumes)
					models[currentModel].DrawInfiniteShadowVolume(	torus[i].objectSpaceLightPosition,
																	false);
				//Draw the model if using vertex program
				if(useVPVolumes)
					glDrawElements(GL_TRIANGLES, models[currentModel].numIndices, GL_UNSIGNED_INT, models[currentModel].indices);
			}
		}

		glPopMatrix();
	}

	glPopAttrib();

	


	//Now draw lit where stencil==0
	glPushAttrib(GL_ENABLE_BIT);
	glEnable(GL_COLOR_MATERIAL);
	glLightfv(GL_LIGHT1, GL_POSITION, VECTOR4D(light.position)); 
	glLightfv(GL_LIGHT1, GL_AMBIENT, light.color/5);
	glLightfv(GL_LIGHT1, GL_DIFFUSE, light.color);
	glLightfv(GL_LIGHT1, GL_SPECULAR, white);
	glEnable(GL_LIGHT1);
	glEnable(GL_LIGHTING);
	glStencilFunc(GL_EQUAL, 0, ~0);
	glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP);
	glEnable(GL_STENCIL_TEST);

	//Enable vertex program if using VP for volumes
	if(useVPVolumes)
	{
		glBindProgramARB(GL_VERTEX_PROGRAM_ARB, lightingVP);
		glEnable(GL_VERTEX_PROGRAM_ARB);
	}

	//Draw box
	glMaterialfv(GL_FRONT, GL_SPECULAR, black);
	glColor3f(0.2f, 0.2f, 1.0f);
	DrawBox();

	//Draw models
	glMaterialfv(GL_FRONT, GL_SPECULAR, white);
	glMaterialf(GL_FRONT, GL_SHININESS, 32.0f);
	for(int i=0; i<numTori; ++i)
	{
		glColor4fv(torus[i].color);
		glPushMatrix();
		glTranslatef(torus[i].position.x, torus[i].position.y, torus[i].position.z);
		glRotatef(90.0f, 1.0f, 0.0f, 0.0f);
		glRotatef(torus[i].angle, 0.0f, 0.0f, 1.0f);
		if(i==0 || i==1)
		{	
			glVertexPointer(3, GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[0].vertices[0].position);
			glNormalPointer(GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[0].vertices[0].normal);
			glDrawElements(GL_TRIANGLES, models[0].numIndices, GL_UNSIGNED_INT, models[0].indices);
		
		}
		else
		{
			glVertexPointer(3, GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[1].vertices[0].position);
			glNormalPointer(GL_FLOAT, sizeof(SHADOW_MODEL_VERTEX), &models[1].vertices[0].normal);
			glDrawElements(GL_TRIANGLES, models[1].numIndices, GL_UNSIGNED_INT, models[1].indices);
		}
		glPopMatrix();
	}

	glPopAttrib();



	//Draw sphere at light's position
	glPushMatrix();
	glColor4fv(light.color);
	glTranslatef(light.position.x, light.position.y, light.position.z);
	gluSphere(sphere, 0.1, 24, 24);
	glPopMatrix();


	fpsCounter.Update();											//update frames per second counter
	glColor4f(1.0f, 1.0f, 0.0f, 1.0f);
	window.StartTextMode();
	window.Print(0, 28, "FPS: %.2f", fpsCounter.GetFps());			//print the fps
	glColor4f(1.0f, 1.0f, 1.0f, 1.0f);
	window.Print(0, 48, "%s", alwaysUseZFail ?	"\"zFail\" algorithm with capped, infinite shadow volumes" :
												"\"zPass\" algorithm with non-capped volumes, where possible");
	glColor4f(0.0f, 1.0f, 0.0f, 1.0f);
	window.Print(0, 68, "%s", useVPVolumes ?	"Extruding shadow volumes in a vertex program" :
												"Standard CPU shadow volume calculations");
	glColor4f(1.0f, 0.0f, 0.0f, 1.0f);
	if(useTwoSidedStencil)
		window.Print(0, 88, "Using EXT_stencil_two_side");
	window.EndTextMode();
	glColor4f(1.0f, 1.0f, 1.0f, 1.0f);

	if(window.isKeyPressed(VK_F1))
	{
		window.SaveScreenshot();
		window.SetKeyReleased(VK_F1);
	}

	window.SwapBuffers();									//swap buffers

	//check for any opengl errors
	window.CheckGLError();

	//quit if necessary
	if(window.isKeyPressed(VK_ESCAPE))
		PostQuitMessage(0);
}

void DemoShutdown()
{
	window.Shutdown();										//Shutdown window
}

//ENTRY POINT FOR APPLICATION
//CALL WINDOW CREATION ROUTINE, DEAL WITH MESSAGES, WATCH FOR INTERACTION
int WINAPI WinMain(	HINSTANCE	hInstance,				//instance
					HINSTANCE	hPrevInstance,			//Previous Instance
					LPSTR		lpCmdLine,				//command line parameters
					int			nCmdShow)				//Window show state
{
	//Initiation
	errorLog.Init("Error Log.txt");

	//init variables etc, then GL
	if(!DemoInit())
	{
		errorLog.OutputError("Demo Initiation failed");
		return 0;
	}
	else
		errorLog.OutputSuccess("Demo Initiation Successful");

	if(!GLInit())
	{
		errorLog.OutputError("OpenGL Initiation failed");
		return 0;
	}
	else
		errorLog.OutputSuccess("OpenGL Initiation Successful");

	//Main Loop
	for(;;)
	{
		if(!(window.HandleMessages())) break;//handle windows messages, quit if returns false
		UpdateFrame();
		RenderFrame();
	}

	DemoShutdown();
	
	errorLog.OutputSuccess("Exiting...");
	return (window.msg.wParam);								//Exit The Program
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99精品一区二区三区| 国产一区二区三区香蕉| 国产欧美一区二区三区网站| 欧美一区二区成人| 欧美日韩高清一区二区不卡| 欧美午夜影院一区| 91影视在线播放| 一本到不卡免费一区二区| 91久久精品一区二区三区| 日本电影欧美片| 欧美日韩电影在线| 欧美一区二区视频网站| 精品av久久707| 欧美国产激情一区二区三区蜜月| 国产精品久久久久久久久久久免费看| 国产精品免费免费| 一区二区三区四区不卡在线 | 亚洲卡通动漫在线| 亚洲精品你懂的| 午夜精品在线看| 国内久久精品视频| 91网址在线看| 欧美日本乱大交xxxxx| 精品女同一区二区| 综合av第一页| 日本一道高清亚洲日美韩| 日本系列欧美系列| 丁香婷婷综合网| 日本韩国视频一区二区| 日韩精品中文字幕在线不卡尤物 | 亚洲精品久久久蜜桃| 日韩国产欧美一区二区三区| 极品美女销魂一区二区三区| 99精品欧美一区二区蜜桃免费 | 色欧美片视频在线观看| 日韩限制级电影在线观看| 亚洲国产岛国毛片在线| 视频在线在亚洲| 成人污污视频在线观看| 欧美电影在哪看比较好| 国产精品网站在线| 奇米色777欧美一区二区| 成人一区在线看| 日韩欧美一级二级| 亚洲一区国产视频| 国产99久久久国产精品免费看| 欧美中文字幕一区二区三区亚洲| 久久亚洲精精品中文字幕早川悠里| 亚洲精选一二三| 国产盗摄女厕一区二区三区| 5566中文字幕一区二区电影| 国产精品女人毛片| 国内精品国产成人国产三级粉色| 91在线观看免费视频| 久久久青草青青国产亚洲免观| 五月激情丁香一区二区三区| 99久久伊人精品| 欧美经典一区二区| 久久精品72免费观看| 欧美日本一区二区| 亚洲午夜精品17c| 色国产综合视频| 国产精品久久久久久久久免费丝袜 | 美女视频黄 久久| 欧美日韩视频第一区| 亚洲伦理在线精品| 91免费版在线| 亚洲三级理论片| av网站一区二区三区| 久久免费美女视频| 国产美女精品一区二区三区| 精品理论电影在线| 久久se精品一区二区| 日韩三级av在线播放| 日本欧美一区二区三区| 6080日韩午夜伦伦午夜伦| 日韩和欧美的一区| 欧美一区二区三区思思人| 日韩精品一级二级| 欧美一区二区三区性视频| 亚洲va欧美va国产va天堂影院| 欧美午夜片在线观看| 亚洲成人午夜影院| 91精品国产综合久久久蜜臀图片| 日本美女视频一区二区| 日韩欧美一二三区| 精品写真视频在线观看| 国产亚洲一区字幕| 91玉足脚交白嫩脚丫在线播放| 亚洲精品国久久99热| 欧美午夜电影网| 久久av资源站| 亚洲私人影院在线观看| 欧美综合色免费| 久久精品免费观看| 国产精品国产三级国产aⅴ入口 | 中文字幕在线不卡| 欧洲国产伦久久久久久久| 五月婷婷激情综合| 日韩女优视频免费观看| 国产91在线观看| 亚洲黄色小视频| 4438成人网| 福利一区二区在线| 亚洲自拍偷拍综合| 精品欧美久久久| 色婷婷综合五月| 奇米一区二区三区av| 亚洲欧洲美洲综合色网| 欧美男人的天堂一二区| 国产精品123| 悠悠色在线精品| 久久久久久亚洲综合影院红桃 | 久久精品人人做| 欧美日韩在线免费视频| 激情亚洲综合在线| 一区二区三区欧美久久| 久久久久久久久久久电影| 在线视频一区二区三区| 国产成人自拍在线| 日一区二区三区| 中文字幕一区二区三区在线不卡 | 国产一区二区0| 亚洲永久免费av| 日本一二三四高清不卡| 欧美人牲a欧美精品| av激情亚洲男人天堂| 蜜臀久久久99精品久久久久久| 国产精品久久综合| www亚洲一区| 欧美老年两性高潮| 色一区在线观看| 成人美女视频在线看| 国内精品写真在线观看| 视频一区视频二区中文| 亚洲国产综合91精品麻豆| 亚洲人123区| 国产精品女上位| 国产欧美日韩综合| 久久综合九色综合97婷婷女人| 91精品国产手机| 欧美精品在线观看一区二区| 色妹子一区二区| 色综合天天性综合| 99久久精品久久久久久清纯| 成人爽a毛片一区二区免费| 国产成人午夜精品5599| 国产在线播放一区三区四| 捆绑变态av一区二区三区| 免费高清视频精品| 麻豆国产精品777777在线| 免费日韩伦理电影| 狠狠久久亚洲欧美| 国产精品综合网| 高清国产午夜精品久久久久久| 国产精品亚洲视频| 成人一区二区三区视频在线观看| 国产999精品久久久久久绿帽| 国产精品一区专区| 成人视屏免费看| 91猫先生在线| 欧美三日本三级三级在线播放| 欧美日韩一区国产| 欧美一级高清片| 久久久99精品免费观看不卡| www.在线欧美| 免费高清在线一区| 日本不卡不码高清免费观看| 免费欧美在线视频| 激情图片小说一区| 国产成人99久久亚洲综合精品| 国产精品77777竹菊影视小说| 成人黄色一级视频| 99视频在线精品| 欧美精品一级二级三级| 欧美变态口味重另类| 国产精品污污网站在线观看| 亚洲一区二区三区四区不卡| 美国三级日本三级久久99| 国产suv精品一区二区三区| 日本韩国欧美在线| 亚洲精品一区在线观看| 国产精品国产三级国产aⅴ中文 | 91麻豆精品国产91久久久更新时间 | 在线观看国产日韩| 91精品国产福利| 国产精品久久久久久久久快鸭| 一区二区三区国产豹纹内裤在线 | 亚洲精品视频在线观看免费| 偷拍一区二区三区四区| 国产精品综合av一区二区国产馆| 91麻豆产精品久久久久久 | 成人18视频日本| 欧美精品久久一区| 国产精品国产a| 欧美aⅴ一区二区三区视频| 国产黄色精品视频| 欧美二区在线观看| 国产精品成人免费| 国产精品一二三四|