【光能蝸牛的圖形學之旅】Unity紋理初步
shader程式碼
這段程式碼是在之前的光照shader基礎之上弄的
// Upgrade NOTE: replaced '_Object2World' with 'unity_ObjectToWorld'
Shader "Custom/TextureFirst"
{
Properties
{
_Color("_MainColor",Color) = (1,1,1,1)
_Diffuse ("_DiffuseColor", Color) = (1,1,1,1)
_ValveIndex("ValveIndex",Range(0,1)) = 0.5
_Specular("_SpecularColor",Color) = (1,1,1,1)
_Glossness("Glossness",Range(1.0,256))=8.0
_MainTex("MainTex", 2D) = "black"{}
}
SubShader
{
Tags {
"RenderType" = "Opaque"
"LightMode" = "ForwardBase"
}
LOD 100
Pass
{
CGPROGRAM
#pragma vertex vert
#pragma fragment frag
// make fog work
#pragma multi_compile_fog
#include "UnityCG.cginc"
#include "Lighting.cginc"
fixed4 _Diffuse;
float _ValveIndex;
fixed4 _Specular;
float _Glossness;
sampler2D _MainTex;
float4 _MainTex_ST;
fixed4 _Color;
struct a2v
{
float4 vertex : POSITION;
float3 normal:NORMAL;
float4 texcoord : TEXCOORD0;
};
struct v2f
{
float2 uv : TEXCOORD0;
UNITY_FOG_COORDS(1)
float4 Pos : SV_POSITION;
float3 color:COLOR;
float3 worldNormal: TEXCOORD1;
float3 WordPos: TEXCOORD2;
};
v2f vert (a2v v)
{
v2f o;
o.Pos = UnityObjectToClipPos(v.vertex);
//o.uv = TRANSFORM_TEX(v.uv, _MainTex);
o.uv = v.texcoord.xy * _MainTex_ST.xy + _MainTex_ST.zw;
o.worldNormal = normalize(mul((float3x3)unity_ObjectToWorld, v.normal));
o.WordPos = normalize(mul((float3x3)unity_ObjectToWorld, v.vertex));
return o;
}
fixed4 frag (v2f i) : SV_Target
{
float3 nDir = normalize(i.worldNormal);//用法線貼圖修正法線
float3 lDir = normalize(UnityWorldSpaceLightDir(i.WordPos));
float3 reflectDir = normalize(reflect(-lDir,i.worldNormal));
float3 viewDir = normalize(UnityWorldSpaceViewDir(i.WordPos));
fixed3 albedo = tex2D(_MainTex,i.uv).rgb * _Color.rgb;
fixed3 ambient = UNITY_LIGHTMODEL_AMBIENT.xyz * albedo.rgb;
fixed3 specular = _LightColor0 * albedo.rgb * pow(saturate(dot(viewDir, reflectDir)),_Glossness);
fixed3 diffuse = _LightColor0 * _Diffuse * saturate(dot(nDir, lDir)* _ValveIndex + (1 - _ValveIndex) );
float3 color = ambient + diffuse + specular;
return fixed4(color,1);
}
ENDCG
}
}
}
需要注意的東西
這裡面主要以下幾個地方需要注意
- 紋理的屬性宣告
_MainTex("MainTex", 2D) = "black"{}
- 紋理的取樣引用宣告
sampler2D _MainTex;
- 紋理ST宣告
這個名字不是隨便取的,是在紋理取樣名字加上_ST字尾,
_MainTex_ST中,其中_MainTex_ST.xy儲存的是紋理的縮放,_MainTex_ST.zw儲存的是紋理的位移
float4 _MainTex_ST;//
- 紋理轉換
我們使用如下方式進行紋理轉換
o.uv = v.uv.xy * _MainTex_ST.xy + _MainTex_ST.zw;
或者你可以直接呼叫unity的內部shader函式實現轉換功能
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
- 紋理取樣
fixed3 albedo = tex2D(_MainTex,i.uv).rgb ;
相關文章
- 圖形學之紋理後續/WebGL多紋理處理Web
- 圖形學_opengl紋理對映
- Unity安卓共享紋理Unity安卓
- 圖形學之Unity渲染管線流程Unity
- 「技美之路 第05篇」圖形 1.3 紋理的祕密
- 4.QOpenGLWidget-對三角形進行紋理貼圖、紋理疊加
- 蝸牛遊戲哪去了遊戲
- Unity iOS 使用 ASTC 格式紋理實踐UnityiOSAST
- Unity3D學習筆記3——Unity Shader的初步使用Unity3D筆記
- 蝸牛星際改造計劃
- flutter與unity的碰撞--opengl紋理共享實現flutter與unity介面的融合FlutterUnity
- Unity3D學習筆記2——繪製一個帶紋理的面Unity3D筆記
- WebGPU[4] 紋理三角形WebGPU
- 簡單的 OpenGL 紋理貼圖不起作用?
- android簡單的圖形特效處理Android特效
- JB的Python之旅-爬蟲篇-圖形驗證碼(1)-- tesserocrPython爬蟲
- unity中取樣深度圖的結果處理Unity
- 紋理最佳化:讓你的紋理也 “瘦” 下來
- CGContextRef處理圓形圖片GCContext
- Webgl 紋理Web
- 形態學影像處理
- 《最強蝸牛》體驗總結:放置的魅力、沙雕文化的勝利
- python 圖形初學Python
- hover 背後的數學和圖形學
- Git的初步學習Git
- 法線紋理
- C#開發PACS醫學影像處理系統(十二):繪圖處理之圖形標記C#繪圖
- 【譯】建立紋理文字的技巧
- 【CG】圖形學相關
- 超300萬預約,期待已久《最強蝸牛》今日上線
- GPU 架構是圖形處理器GPU架構
- 圖形學常⻅的變換推導
- 《最強蝸牛》運營分析:這個奇葩放置遊戲的樂趣在哪裡?遊戲
- android圖片處理,讓圖片變成圓形Android
- win10 ps 使用圖形處理器怎麼開啟_win10ps的圖形處理器在哪裡勾Win10
- Tableau——資料前處理、折線圖、餅圖(環形圖)
- OpenGL 紋理詳解
- 好評如潮 放置手遊《最強蝸牛》超高能測試開啟