【光能蝸牛的圖形學之旅】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
- 計算機圖形學之紋理的作用計算機
- Unity安卓共享紋理Unity安卓
- 蝸牛遊戲哪去了遊戲
- ACM 奮鬥的小蝸牛ACM
- 圖形學之Unity渲染管線流程Unity
- Android - 蝸牛進度條Android
- 4.QOpenGLWidget-對三角形進行紋理貼圖、紋理疊加
- Unity iOS 使用 ASTC 格式紋理實踐UnityiOSAST
- 計算機圖形學(二)輸出圖元_20_章節總結_程式展示_蝸形線、心形線、螺旋線計算機
- Unity3D學習筆記3——Unity Shader的初步使用Unity3D筆記
- flutter與unity的碰撞--opengl紋理共享實現flutter與unity介面的融合FlutterUnity
- Unity3D學習筆記2——繪製一個帶紋理的面Unity3D筆記
- WebGPU[4] 紋理三角形WebGPU
- 科學家研製柔性機器人手 可感知物體形狀紋理機器人
- ASP.Net請求處理機制初步探索之旅(3):管道ASP.NET
- ASP.Net請求處理機制初步探索之旅(2)核心ASP.NET
- ASP.Net請求處理機制初步探索之旅(1):前奏ASP.NET
- 紋理優化:讓你的紋理也 “瘦” 下來優化
- 《最強蝸牛》體驗總結:放置的魅力、沙雕文化的勝利
- Webgl 紋理Web
- unity中取樣深度圖的結果處理Unity
- 形態學影像處理
- 《最強蝸牛》運營分析:這個奇葩放置遊戲的樂趣在哪裡?遊戲
- JB的Python之旅-爬蟲篇-圖形驗證碼(1)-- tesserocrPython爬蟲
- android簡單的圖形特效處理Android特效
- 法線紋理
- 老周的ABP框架系列教程 -》 一、框架理論初步學習框架
- CGContextRef處理圓形圖片GCContext
- python 圖形初學Python
- 計算機圖形學計算機
- 【CG】圖形學相關
- 形態學影像處理(二)
- Git的初步學習Git
- C#開發PACS醫學影像處理系統(十二):繪圖處理之圖形標記C#繪圖
- 上線10天iOS流水破億,萬字長文剖析《最強蝸牛》iOS
- Unity官方文件之“圖形效能優化-幀偵錯程式”的翻譯Unity優化
- 顯示網路圖片變形的處理