【shader】全景图
来源:互联网 发布:矩阵的逆 编辑:程序博客网 时间:2024/06/02 04:15
最终效果
思路
- 通过法线方向求平面坐标。x=atan(x/z),y=acos(y/r) r为半径;
- 通过ddx,ddy 偏导数模糊极坐标像素解决极坐标问题。
- 通过反射比较真实的扑捉视觉。
源代码
Shader "QQ/Sky/Latitude"{Properties{_MainTex("Texture", 2D) = "white" {}[Enum(UnityEngine.Rendering.CullMode)] _Cull("Cull Mode", float) = 2[Enum(Off, 0, On, 1)] _Inverse("inverse", float) = 0}SubShader{Tags { "RenderType" = "Opaque" }LOD 100Pass{Cull[_Cull]CGPROGRAM#pragma vertex vert#pragma fragment frag#include "UnityCG.cginc"struct a2v{float4 vertex : POSITION;float3 normal : NORMAL;};struct v2f{float4 pos : SV_POSITION;float3 normal : TEXCOORD0;float3 wPos:TEXCOORD1;};sampler2D _MainTex;float4 _MainTex_ST;float _Cull;float _Inverse;v2f vert(a2v v){v2f o;o.pos = mul(UNITY_MATRIX_MVP, v.vertex);o.normal = v.normal;o.wPos = mul(unity_ObjectToWorld, v.vertex);return o;}fixed4 frag(v2f i) : SV_Target{float3 nor = normalize(i.normal);float3 viewDir = normalize(_WorldSpaceCameraPos.xyz - i.wPos);float3 refl = (_Inverse > 0 ? 1 : -1) * reflect(viewDir,nor);float u = atan(refl.x / refl.z) / UNITY_PI;u = (u + 0.5)*0.5;if (refl.z >= 0)u += 0.5;float v = acos(refl.y) / UNITY_PI;float2 uv = float2(u, v)*_MainTex_ST.xy + _MainTex_ST.zw;fixed4 col = tex2D(_MainTex,uv,float2(0,0), float2(0,0));return col;}ENDCG}}}
0 0
- 【shader】全景图
- Houdini中全景摄像机shader立体左右眼成像方法
- UE4 导出全景图和全景视频
- 【自己写全景】TreeJs实现全景图
- 关于全景图浏览
- Microsoft Live全景图
- 入侵检测全景图
- 全景图技术
- 软件测试全景图
- 软件测试全景图
- 软件测试全景图
- .NET学习全景图
- fwd:测试全景图
- TOC全景图
- 敏捷开发全景图
- .NET学习全景图
- 软件测试全景图
- android全景图
- MFC笔记:切换窗口
- 销售手帐用例的详细描述
- java正则表达式的使用
- LeetCode #404 - Sum of Left Leaves - Easy
- Java互联网工程师要具备哪些技能
- 【shader】全景图
- 百度导航引擎初始化失败问题解决
- MySQL提示Writing to net的解决方法
- Mysql+servlet实现分页
- Oracle基本操作--数据查询
- mysql left join写法
- Spring JMS 整合Tomcat和ActiveMQ
- 愚蠢的傲慢
- Tree Traversals