area.effect 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. uniform float4x4 ViewProj;
  2. uniform float2 base_dimension_i;
  3. uniform texture2d image;
  4. struct VertInOut {
  5. float4 pos : POSITION;
  6. float2 uv : TEXCOORD0;
  7. };
  8. VertInOut VSDefault(VertInOut vert_in)
  9. {
  10. VertInOut vert_out;
  11. vert_out.pos = mul(float4(vert_in.pos.xyz, 1.0), ViewProj);
  12. vert_out.uv = vert_in.uv;
  13. return vert_out;
  14. }
  15. float4 PSDrawAreaRGBA(VertInOut vert_in) : TARGET
  16. {
  17. float4 totalcolor = float4(0.0, 0.0, 0.0, 0.0);
  18. float2 uv = vert_in.uv;
  19. float2 uvdelta = float2(ddx(uv.x), ddy(uv.y));
  20. // Handle potential OpenGL flip.
  21. uvdelta.y = abs(uvdelta.y);
  22. float2 uvhalfdelta = 0.5 * uvdelta;
  23. float2 uvmin = uv - uvhalfdelta;
  24. float2 uvmax = uv + uvhalfdelta;
  25. float2 imagesize = 1.0 / base_dimension_i;
  26. float2 loadindexmin = floor(uvmin * imagesize);
  27. float2 loadindexmax = floor(uvmax * imagesize);
  28. float2 targetsize = 1.0 / uvdelta;
  29. float2 targetpos = uv * targetsize;
  30. float2 targetposmin = targetpos - 0.5;
  31. float2 targetposmax = targetpos + 0.5;
  32. float2 scale = base_dimension_i * targetsize;
  33. float loadindexy = loadindexmin.y;
  34. do {
  35. float loadindexx = loadindexmin.x;
  36. do {
  37. float2 loadindex = float2(loadindexx, loadindexy);
  38. float2 potentialtargetmin = loadindex * scale;
  39. float2 potentialtargetmax = potentialtargetmin + scale;
  40. float2 targetmin = max(potentialtargetmin, targetposmin);
  41. float2 targetmax = min(potentialtargetmax, targetposmax);
  42. float area = (targetmax.x - targetmin.x) * (targetmax.y - targetmin.y);
  43. float4 sample = image.Load(int3(loadindex, 0));
  44. totalcolor += area * sample;
  45. ++loadindexx;
  46. } while (loadindexx <= loadindexmax.x);
  47. ++loadindexy;
  48. } while (loadindexy <= loadindexmax.y);
  49. return totalcolor;
  50. }
  51. technique Draw
  52. {
  53. pass
  54. {
  55. vertex_shader = VSDefault(vert_in);
  56. pixel_shader = PSDrawAreaRGBA(vert_in);
  57. }
  58. }