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

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

?? example_bumpmapping.cg

?? 赫赫大名的 OGRE 游戲引擎
?? CG
字號:
// General functions

// Expand a range-compressed vector
float3 expand(float3 v)
{
	return (v - 0.5) * 2;
}


/* Bump mapping vertex program
   In this program, we want to calculate the tangent space light vector
   on a per-vertex level which will get passed to the fragment program,
   or to the fixed function dot3 operation, to produce the per-pixel
   lighting effect. 
*/
void main_vp(float4 position	: POSITION,
			 float3 normal		: NORMAL,
			 float2 uv			: TEXCOORD0,
			 float3 tangent     : TEXCOORD1,
			 // outputs
			 out float4 oPosition    : POSITION,
			 out float2 oUv			 : TEXCOORD0,
			 out float3 oTSLightDir	 : TEXCOORD1,
			 // parameters
			 uniform float3 lightPosition, // object space
			 uniform float3 eyePosition,   // object space
			 uniform float4x4 worldViewProj)
{
	// calculate output position
	oPosition = mul(worldViewProj, position);

	// pass the main uvs straight through unchanged
	oUv = uv;

	// calculate tangent space light vector
	// Get object space light direction
	float3 lightDir = lightPosition - position.xyz;

	// Calculate the binormal (NB we assume both normal and tangent are
	// already normalised)
	// NB looks like nvidia cross params are BACKWARDS to what you'd expect
	// this equates to NxT, not TxN
	float3 binormal = cross(tangent, normal);
	
	// Form a rotation matrix out of the vectors
	float3x3 rotation = float3x3(tangent, binormal, normal);
	
	// Transform the light vector according to this matrix
	oTSLightDir = normalize(mul(rotation, lightDir));
	
	
}

void main_fp( float2 uv			: TEXCOORD0,
			  float3 TSlightDir : TEXCOORD1,

			  out float4 colour	: COLOR,

			  uniform float4 lightDiffuse,
			  uniform sampler2D   normalMap,
			  uniform samplerCUBE normalCubeMap)
{
	// retrieve normalised light vector, expand from range-compressed
	float3 lightVec = expand(texCUBE(normalCubeMap, TSlightDir).xyz);

	// get bump map vector, again expand from range-compressed
	float3 bumpVec = expand(tex2D(normalMap, uv).xyz);

	// Calculate dot product
	colour = lightDiffuse * dot(bumpVec, lightVec);
	
}

/* Vertex program which includes specular component */
void specular_vp(float4 position	: POSITION,
			 	 float3 normal		: NORMAL,
			 	 float2 uv			: TEXCOORD0,
			 	 float3 tangent     : TEXCOORD1,
			 	 // outputs
			 	 out float4 oPosition    : POSITION,
			 	 out float2 oUv			 : TEXCOORD0,
			 	 out float3 oTSLightDir	 : TEXCOORD1,
				 out float3 oTSHalfAngle : TEXCOORD2,
			 	 // parameters
			 	 uniform float3 lightPosition, // object space
			 	 uniform float3 eyePosition,   // object space
			 	 uniform float4x4 worldViewProj)
{
	// calculate output position
	oPosition = mul(worldViewProj, position);

	// pass the main uvs straight through unchanged
	oUv = uv;

	// calculate tangent space light vector
	// Get object space light direction
	float3 lightDir = lightPosition - position.xyz;

	// Calculate the binormal (NB we assume both normal and tangent are
	// already normalised)
	// NB looks like nvidia cross params are BACKWARDS to what you'd expect
	// this equates to NxT, not TxN
	float3 binormal = cross(tangent, normal);
	
	// Form a rotation matrix out of the vectors
	float3x3 rotation = float3x3(tangent, binormal, normal);
	
	// Transform the light vector according to this matrix
	oTSLightDir = normalize(mul(rotation, lightDir));

	// Calculate half-angle in tangent space
	float3 eyeDir = eyePosition - position.xyz;
	float3 halfAngle = normalize(eyeDir + lightDir);
	oTSHalfAngle = mul(rotation, halfAngle);
	
	
}

/* Fragment program which supports specular component */
void specular_fp( float2 uv			: TEXCOORD0,
			  float3 TSlightDir : TEXCOORD1,
			  float3 TShalfAngle: TEXCOORD2,

			  out float4 colour	: COLOR,

			  uniform float4 lightDiffuse,
			  uniform float4 lightSpecular,
			  uniform sampler2D   normalMap,
			  uniform samplerCUBE normalCubeMap, 
			  uniform samplerCUBE normalCubeMap2) // we need this second binding to be compatible with ps_1_1, ps_2_0 could reuse the other
{
	// retrieve normalised light vector, expand from range-compressed
	float3 lightVec = expand(texCUBE(normalCubeMap, TSlightDir).xyz);

	// retrieve half angle and normalise through cube map
	float3 halfAngle = expand(texCUBE(normalCubeMap2, TShalfAngle).xyz);

	// get bump map vector, again expand from range-compressed
	float3 bumpVec = expand(tex2D(normalMap, uv).xyz);

	// Pre-raise the specular exponent to the eight power
	// Note we have no 'pow' function in basic fragment programs, if we were willing to accept compatibility
	// with ps_2_0 / arbfp1 and above, we could have a variable shininess parameter
	// This is equivalent to 
	float specFactor = dot(bumpVec, halfAngle);
	for (int i = 0; i < 3; ++i)
		specFactor *= specFactor;
	

	// Calculate dot product for diffuse
	colour = (lightDiffuse * dot(bumpVec, lightVec)) + 
			(lightSpecular * specFactor);
	
}
			 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
911精品国产一区二区在线| 欧美三级午夜理伦三级中视频| 日韩极品在线观看| 视频一区视频二区中文| 午夜一区二区三区在线观看| 亚洲视频一二区| 午夜免费久久看| 蜜臂av日日欢夜夜爽一区| 激情综合色综合久久| 国产成人久久精品77777最新版本| 伦理电影国产精品| 国产乱人伦偷精品视频不卡| 成人国产电影网| 在线观看一区二区视频| 欧美一级一区二区| 国产精品每日更新| 国产清纯在线一区二区www| 精品国产91亚洲一区二区三区婷婷| 国产亚洲欧美在线| 亚洲美腿欧美偷拍| 国产精品综合在线视频| 色狠狠综合天天综合综合| 欧美一级在线观看| 亚洲乱码中文字幕| 麻豆国产一区二区| 国内精品自线一区二区三区视频| 26uuu亚洲综合色| 久久久无码精品亚洲日韩按摩| 国产精品无人区| 日本美女一区二区三区视频| 国产精品69久久久久水密桃| 91精品福利在线| 日韩伦理电影网| 成人免费电影视频| 久久精品男人的天堂| 日韩高清不卡一区二区| 91成人在线观看喷潮| 久久婷婷色综合| 国产一区二区三区免费| 日韩三级在线免费观看| 久久精品99久久久| 欧美一区二区美女| 日韩主播视频在线| 欧美一区二区免费| 韩国女主播成人在线观看| 欧美sm极限捆绑bd| 日韩精品国产精品| 欧美大白屁股肥臀xxxxxx| 麻豆一区二区99久久久久| 69堂精品视频| 麻豆一区二区三| 中文字幕巨乱亚洲| 91蝌蚪国产九色| 五月婷婷激情综合网| 日韩欧美美女一区二区三区| 麻豆视频一区二区| 中文字幕在线不卡一区二区三区| 99久久精品国产毛片| 一二三四社区欧美黄| 日韩一级精品视频在线观看| 国产一区二区剧情av在线| 国产精品素人视频| 在线播放亚洲一区| 91在线视频播放地址| 亚洲高清中文字幕| 欧美精品一区二区在线观看| caoporm超碰国产精品| 亚洲bt欧美bt精品| 中文字幕免费不卡| 欧美日韩高清一区二区三区| 成人av影院在线| 狠狠色丁香婷婷综合| 一区二区三区免费网站| 久久久www成人免费毛片麻豆 | 蜜臀91精品一区二区三区 | 国产视频亚洲色图| 日韩一级二级三级精品视频| www.综合网.com| 国产精品一二三四五| 男女性色大片免费观看一区二区 | 丁香五精品蜜臀久久久久99网站| 天天色综合天天| 亚洲欧洲在线观看av| 久久综合色婷婷| 精品日韩一区二区三区| 欧美一区二区视频在线观看2022| 在线免费观看一区| 日本午夜精品视频在线观看| 欧美一区二区精美| 成人精品小蝌蚪| 成人精品鲁一区一区二区| 男人操女人的视频在线观看欧美| 婷婷国产v国产偷v亚洲高清| √…a在线天堂一区| 亚洲精品菠萝久久久久久久| 亚洲精品国产视频| 亚洲一区二区三区三| 免费视频最近日韩| 国产在线国偷精品免费看| 国产乱理伦片在线观看夜一区| 久久99精品国产麻豆婷婷洗澡| 麻豆精品在线观看| 成人美女在线视频| 欧美日韩不卡在线| 26uuu色噜噜精品一区| 国产精品日韩精品欧美在线| 亚洲日本一区二区三区| 日韩国产欧美三级| 国产精品一区二区视频| 色94色欧美sute亚洲线路一久| 欧美猛男男办公室激情| 久久综合久久久久88| 亚洲精品久久久蜜桃| 国产自产2019最新不卡| 欧美色综合影院| 综合久久综合久久| 国产在线不卡一卡二卡三卡四卡| 一本色道久久加勒比精品| 日韩三区在线观看| 亚洲不卡av一区二区三区| 久久99精品国产麻豆不卡| 欧美中文字幕一区二区三区亚洲| 精品av综合导航| 久久99深爱久久99精品| 欧美色综合久久| 亚洲国产日韩一区二区| 成人丝袜高跟foot| 国产色产综合色产在线视频| 天堂一区二区在线| 欧美伊人久久久久久久久影院| 国产精品久久三区| 日本久久一区二区| 亚洲一区二区三区四区在线观看| 99这里都是精品| 亚洲一区二区视频| 欧美精品xxxxbbbb| 日韩精品欧美精品| 91精品国产手机| 国内精品国产成人| 国产精品天天看| 色就色 综合激情| 午夜精品久久久久久久蜜桃app| 欧美日韩国产综合草草| 精品一二线国产| 中文字幕欧美日韩一区| 欧美中文字幕一区二区三区亚洲| 国产午夜精品久久久久久久 | 欧美日韩大陆在线| 首页国产欧美久久| 国产精品每日更新| 欧美日韩一区二区三区不卡| 久久黄色级2电影| 国产精品丝袜一区| 日韩一区二区三区四区五区六区| 国产精品99久| 日日摸夜夜添夜夜添亚洲女人| 精品国内二区三区| 99re热这里只有精品免费视频| 亚洲v中文字幕| 国产日韩精品久久久| 欧美久久久久中文字幕| 波多野结衣中文字幕一区| 日韩经典一区二区| 91老师片黄在线观看| 亚洲欧洲中文日韩久久av乱码| 在线综合亚洲欧美在线视频| www.av亚洲| 国产成人精品一区二| 久久99精品久久久久久国产越南 | 精品在线一区二区三区| 一区二区三区精品在线| 国产精品无码永久免费888| 精品国产亚洲在线| 日韩欧美亚洲国产另类| 91精品啪在线观看国产60岁| 色国产精品一区在线观看| 99国产精品一区| 色综合网色综合| 色8久久人人97超碰香蕉987| 91免费版在线| 在线视频国内自拍亚洲视频| 色国产精品一区在线观看| 91麻豆文化传媒在线观看| 91麻豆国产福利在线观看| 在线欧美小视频| 欧美一区二区三区四区五区| 日韩小视频在线观看专区| 日韩欧美在线综合网| 久久精品免视看| 亚洲视频一区二区在线| 一区二区高清免费观看影视大全| 亚洲在线观看免费| 麻豆91免费看| 91亚洲精品久久久蜜桃网站| 91在线观看成人| 欧美美女一区二区三区| 久久久不卡网国产精品一区| 亚洲精品免费电影| 国产一区二区免费在线| 日本精品免费观看高清观看|