我在C#/ XNA中製作遊戲。我目前正在研究我將用於地形的着色器。我使用的紋理地圖集的速度和效率,但我遇到瓷磚之間紋理/顏色出血: http://i.imgur.com/lZcESsn.png使用紋理地圖集時的HLSL顏色流血
我在FX作曲家和我的遊戲本身得到這種效果。這裏是我的着色器:
//-----------------------------------------------------------------------------
// InstancedModel.fx
//
// Microsoft XNA Community Game Platform
// Copyright (C) Microsoft Corporation. All rights reserved.
//-----------------------------------------------------------------------------
// Camera settings.
float4x4 World : World < string UIWidget="None"; >;
float4x4 View : View < string UIWidget="None"; >;
float4x4 Projection : Projection < string UIWidget="None"; >;
// This sampler uses a simple Lambert lighting model.
float3 LightDirection = normalize(float3(-1, -1, -1));
float3 DiffuseLight = 1.25;
float3 AmbientLight = 0.25;
float TextureSide = 0; //0 = top, 1 = side, 2 = bottom
float2 TextureCoord;
texture Texture;
float2 TextureSize = 2.0;
sampler Sampler = sampler_state
{
Texture = (Texture);
MinFilter = Linear;
MipFilter = Linear;
MagFilter = Linear;
AddressU = Clamp;
AddressV = Clamp;
};
struct VertexShaderInput
{
float4 Position : POSITION0;
float3 Normal : NORMAL0;
float2 TextureCoordinate : TEXCOORD0;
};
struct VertexShaderOutput
{
float4 Position : POSITION0;
float4 Color : COLOR0;
float2 TextureCoordinate : TEXCOORD0;
};
// Vertex shader helper function shared between the two techniques.
VertexShaderOutput VertexShaderCommon(VertexShaderInput input, float4x4 instanceTransform, float2 atlasCoord, float4 colour)
{
VertexShaderOutput output;
// Apply the world and camera matrices to compute the output position.
float4 worldPosition = mul(input.Position, instanceTransform);
float4 viewPosition = mul(worldPosition, View);
output.Position = mul(viewPosition, Projection);
// Compute lighting, using a simple Lambert model.
float3 worldNormal = mul(input.Normal, instanceTransform);
float diffuseAmount = max(-dot(worldNormal, LightDirection), 0);
float3 lightingResult = saturate(diffuseAmount * DiffuseLight + AmbientLight);
output.Color = float4(lightingResult, 1);
output.Color = output.Color * colour;
//calculate texture coords
float2 InputTextureCoords = input.TextureCoordinate;///TextureSize;
float2 InputAtlasCoords = atlasCoord;///TextureSize;
float2 textCoordsActual = InputTextureCoords + InputAtlasCoords;
output.TextureCoordinate = textCoordsActual;
return output;
}
// Hardware instancing reads the per-instance world transform from a secondary vertex stream.
VertexShaderOutput HardwareInstancingVertexShader(VertexShaderInput input,
float4x4 instanceTransform : BLENDWEIGHT,
float2 atlasCoord1 : TEXCOORD1, float2 atlasCoord2 : TEXCOORD2, float2 atlasCoord3 : TEXCOORD3,
float4 colour : COLOR1)
{
float2 atlasCoord = atlasCoord1;
if (TextureSide == 1)
{
atlasCoord = atlasCoord1;
}
if (TextureSide == 2)
{
atlasCoord = atlasCoord2;
}
else if (TextureSide == 3)
{
atlasCoord = atlasCoord3;
}
return VertexShaderCommon(input, mul(World, transpose(instanceTransform)), atlasCoord, colour);
}
// When instancing is disabled we take the world transform from an effect parameter.
VertexShaderOutput NoInstancingVertexShader(VertexShaderInput input,
float4x4 instanceTransform : BLENDWEIGHT,
float2 atlasCoord1 : TEXCOORD1, float2 atlasCoord2 : TEXCOORD2, float2 atlasCoord3 : TEXCOORD3,
float4 colour : COLOR1)
{
return VertexShaderCommon(input, World, TextureCoord, float4(1,1,1,1));
}
float2 HalfPixileCorrectedCoords(float2 coords)
{
float u = (coords.x)/TextureSize;
float v = (coords.y)/TextureSize;
return float2(u, v);
}
// Both techniques share this same pixel shader.
float4 PixelShaderFunction(VertexShaderOutput input,
float2 atlasCoord1 : TEXCOORD1) : COLOR00
{
float2 outputTextureCoords = HalfPixileCorrectedCoords(input.TextureCoordinate);
return tex2D(Sampler, outputTextureCoords) * input.Color;
}
// Hardware instancing technique.
technique HardwareInstancing
{
pass Pass1
{
VertexShader = compile vs_3_0 HardwareInstancingVertexShader();
PixelShader = compile ps_3_0 PixelShaderFunction();
}
}
// For rendering without instancing.
technique NoInstancing
{
pass Pass1
{
VertexShader = compile vs_3_0 NoInstancingVertexShader();
PixelShader = compile ps_3_0 PixelShaderFunction();
}
}
我的FX Composer的HLSL簡介: http://i.imgur.com/wNzmPXA.png
,並使用測試圖譜IM: (廣東話職位,因爲我需要更多的聲譽,我也許可以將它張貼在隨訪? )
我已經做了很多關於這方面的閱讀,似乎我需要做一個「半像素校正」或者將像素包裹在地圖集中指定紋理的邊緣。我已經嘗試了這兩個都沒有成功。
問題: 如何解決我遇到的像素出血問題?
紋理圖集:http://i.imgur.com/MYUbGKm.jpg – user2002287