shader实现二维CT图像效果

        首先需要根据医院提供的数据生成Texture3D,然后在shader中使用内置函数tex3D进行3D纹理采样,最后通过lightCT封装的算法过滤颜色通道,只取单个通道。shader代码如下,效果如图。

Shader "Custom/CT"
{
    Properties
    {
        _Volume ("Texture3D", 3D) = "" {}
        _WindowWidth("WindowWidth",float) = 2000
        _WindowPos("NarrowPos",float) = 1000
        maxDataValue("DataMax",float) = 2000
        minDataValue("DataMin",float) = 0
    }

    SubShader
    {
        Tags { "RenderType"="Opaque" "Queue" = "Geometry" }
        LOD 100
        //ZWrite Off
        //ZTest Off
        Pass
        {
            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag
            #include "UnityCG.cginc"

            #pragma multi_compile _ WHOLE

            sampler3D _Volume;

            float minDataValue;
            float maxDataValue;

            float _WindowWidth;
            float _WindowPos;

            float lightCT(float a){                
                float minV = saturate((_WindowPos - (_WindowWidth / 2) - minDataValue ) / (maxDataValue - minDataValue));
                float maxV = saturate((_WindowPos + (_WindowWidth / 2) - minDataValue ) / (maxDataValue - minDataValue));
                return saturate((a - minV)/(maxV - minV));
            }
            struct appdata
            {
                float4 vertex : POSITION;
            };

            struct v2f
            {
                float4 vertex : SV_POSITION;
                float3 worldPos : TEXCOORD0;
            };

            v2f vert (appdata v)
            {
                v2f o;
                o.vertex = UnityObjectToClipPos(v.vertex);
                o.worldPos = v.vertex;
                return o;
            }
            
            fixed4 frag (v2f i) : SV_Target
            {
                float4 col = float4(0, 0, 0, 0);
                float3 lpos =i.worldPos;
                float3 pos =float3(lpos.x, lpos.y , lpos.z+0.5);//做成屏幕特效的坐标调整
                col = tex3D(_Volume, float4(pos, 0));//采样3D纹理
                col.r = lightCT(col.r);    //CT图像生成算法过滤,此处取任意一个通道即可                    
                return float4(col.rrr,1);
            }
            ENDCG
        }
    }
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值