写的第一个Shader

 

第一个茶壶是可以运动的纹理,用时间的正弦值和余弦值加在纹理坐标上产生偏移实现的,可以考虑用来实现水面的各种效果

第二个茶壶是颜色和纹理的混合,多层纹理的混合应该也是同样的道理,就是把颜色值相乘就可以了

AniPass

float4x4 matViewProjection;
float fSinTime0_X;
float fCosTime0_X;

struct VS_INPUT
{
   float4 Position : POSITION0;
   float2 TexCoord : TEXCOORD0;
};

struct VS_OUTPUT
{
   float4 Position : POSITION0;
   float2 TexCoord : TEXCOORD0; 
};

VS_OUTPUT vs_main( VS_INPUT Input )
{
   VS_OUTPUT Output;

   Output.Position = mul( Input.Position, matViewProjection );
   Output.TexCoord = float2(Input.TexCoord.x + fSinTime0_X, Input.TexCoord.y + fCosTime0_X);
  
   return( Output );
}

sampler Texture0;

struct PS_INPUT
{
   float4 Diffuse   : COLOR0;
   float2 TexCoord  : TEXCOORD0;
};

float4 ps_main(PS_INPUT Input) : COLOR0
{  
   return( tex2D(Texture0, Input.TexCoord) );
}

BlendPass

float4x4 matViewProjection;
float4   teapotPos;

struct VS_INPUT
{
   float4 Position : POSITION0;
   float2 TexCoord : TEXCOORD0;
};

struct VS_OUTPUT
{
   float4 Position : POSITION0;
   float2 TexCoord : TEXCOORD0;
};

VS_OUTPUT vs_main( VS_INPUT Input )
{
   VS_OUTPUT Output;

   Output.Position = mul( Input.Position + teapotPos, matViewProjection );
   Output.TexCoord = Input.TexCoord;
  
   return( Output );
  
}

float fSinTime0_X;
float fCosTime0_X;
sampler Texture0;

float4 ps_main(float2 TexCoord  : TEXCOORD0
               ) : COLOR0
{  
   float4 texColor = tex2D( Texture0, TexCoord );
   texColor = texColor * float4( 1.0f, fSinTime0_X, fCosTime0_X, 1.0f );
  
   return( texColor );
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值