当前位置: 首页 > news >正文

appcan 手机网站开发wordpress首页音乐

appcan 手机网站开发,wordpress首页音乐,极客学院 网站建设,食品网络营销策划方案文章目录 前言一、在Shader中使用转化矩阵1、在顶点着色器中定义转化矩阵2、用 UNITY_NEAR_CLIP_VALUE 区分平台矩阵3、定义一个枚举用于区分当前是处于什么相机 二、我们在DirectX平台下#xff0c;看看效果1、正交相机下2、透视相机下3、最终代码 前言 在上一篇文章中… 文章目录 前言一、在Shader中使用转化矩阵1、在顶点着色器中定义转化矩阵2、用 UNITY_NEAR_CLIP_VALUE 区分平台矩阵3、定义一个枚举用于区分当前是处于什么相机 二、我们在DirectX平台下看看效果1、正交相机下2、透视相机下3、最终代码 前言 在上一篇文章中我们推导得出了 透视相机到裁剪空间的转化矩阵 Unity中Shader裁剪空间推导透视相机到裁剪空间的转化矩阵 我们在正交矩阵Shader的基础上继续测试 Unity中Shader裁剪空间推导在Shader中实现 在这篇文章中我们在Shader中使用该矩阵测试一下。 OpenGL [ 2 v w 0 0 0 0 2 n h 0 0 0 0 n f n − f 2 n f n − f 0 0 − 1 0 ] \begin{bmatrix} \frac{2v}{w} 0 0 0 \\ 0 \frac{2n}{h} 0 0\\ 0 0 \frac{nf}{n-f} \frac{2nf}{n-f}\\ 0 0 -1 0\\ \end{bmatrix} ​w2v​000​0h2n​00​00n−fnf​−1​00n−f2nf​0​ ​DirectX [ 2 v w 0 0 0 0 2 n h 0 0 0 0 n f − n n f f − n 0 0 − 1 0 ] \begin{bmatrix} \frac{2v}{w} 0 0 0 \\ 0 \frac{2n}{h} 0 0\\ 0 0 \frac{n}{f-n} \frac{nf}{f-n}\\ 0 0 -1 0\\ \end{bmatrix} ​w2v​000​0h2n​00​00f−nn​−1​00f−nnf​0​ ​ 一、在Shader中使用转化矩阵 1、在顶点着色器中定义转化矩阵 OpenGL M_clipP float4x4 ( 2n/w,0,0,0, 0,2n/h,0,0, 0,0,(nf)/(n-f),(2nf)/(n-f), 0,0,-1,0 ); DirectX M_clipP float4x4 ( 2n/w,0,0,0, 0,2n/h,0,0, 0,0,n/(f-n),(n*f)/(f-n), 0,0,-1,0 ); 2、用 UNITY_NEAR_CLIP_VALUE 区分平台矩阵 1为OpenGL-1为DirectX 3、定义一个枚举用于区分当前是处于什么相机 [Enum(OrthoGraphic,0,Perspective,1)]_CameraType(“CameraType”,Float) 0 在手动转化矩阵时使用三目运算符来决定使用哪一个矩阵 float4x4 M_clip _CameraType ? M_clipP : M_clipO; o.vertexCS mul(M_clip,float4(vertexVS,1)); 二、我们在DirectX平台下看看效果 1、正交相机下 2、透视相机下 3、最终代码 //平移变换 //缩放变换 //旋转变换四维 //视图空间矩阵 //正交相机视图空间 - 裁剪空间 Shader MyShader/URP/P3_7_6 {Properties{[Header(MainTexx)]_MainTex(MainTex,2D) white{}[Header(Transtion)]_Translate(Translate(XYZ),Vector) (0,0,0,0)_Scale(Scale(XYZ),Vector) (1,1,1,1)_Rotation(Rotation(XYZ),Vector) (0,0,0,0)[Header(View)]_ViewPos(View Pos,vector) (0,0,0,0)_ViewTarget(View Target,vector) (0,0,0,0)[Header(Camera)]_CameraParams(Size(X),Near(Y),Far(Z) Ratio(W),Vector) (0,0,0,1.777)[Enum(OrthoGraphic,0,Perspective,1)]_CameraType(CameraType,Float) 0}SubShader{Tags{PenderPipelineUniversalPipelineRenderTypeOpaqueQueueGeometry}Pass{HLSLPROGRAM#pragma vertex vert#pragma fragment frag#include Packages/com.unity.render-pipelines.core/ShaderLibrary/Color.hlsl#include Packages/com.unity.render-pipelines.universal/ShaderLibrary/Core.hlsl#include Packages/com.unity.render-pipelines.universal/ShaderLibrary/Lighting.hlslstruct Attribute{float4 vertexOS : POSITION;float2 uv : TEXCOORD0;};struct Varying{float4 vertexCS : SV_POSITION;float2 uv : TEXCOORD0;};CBUFFER_START(UnityPerMaterial)float4 _Translate;float4 _Scale;float4 _Rotation;float4 _ViewPos;float4 _ViewTarget;float4 _CameraParams;float _CameraType;CBUFFER_ENDTEXTURE2D(_MainTex);SAMPLER(sampler_MainTex);Varying vert (Attribute v){Varying o;o.uv v.uv;//平移变换float4x4 M_Translate float4x4(1,0,0,_Translate.x,0,1,0,_Translate.y,0,0,1,_Translate.z,0,0,0,1);v.vertexOS mul(M_Translate,v.vertexOS);//缩放交换float4x4 M_Scale float4x4(_Scale.x,0,0,0,0,_Scale.y,0,0,0,0,_Scale.z,0,0,0,0,1);v.vertexOS mul(M_Scale,v.vertexOS);//旋转变换float4x4 M_rotateX float4x4(1,0,0,0,0,cos(_Rotation.x),sin(_Rotation.x),0,0,-sin(_Rotation.x),cos(_Rotation.x),0,0,0,0,1);float4x4 M_rotateY float4x4(cos(_Rotation.y),0,sin(_Rotation.y),0,0,1,0,0,-sin(_Rotation.y),0,cos(_Rotation.y),0,0,0,0,1);float4x4 M_rotateZ float4x4(cos(_Rotation.z),sin(_Rotation.z),0,0,-sin(_Rotation.z),cos(_Rotation.z),0,0,0,0,1,0,0,0,0,1);v.vertexOS mul(M_rotateX,v.vertexOS);v.vertexOS mul(M_rotateY,v.vertexOS);v.vertexOS mul(M_rotateZ,v.vertexOS);//观察空间矩阵推导//P_view [W_view] * P_world//P_view [V_world]^-1 * P_world//P_view [V_world]^T * P_worldfloat3 ViewZ normalize(_ViewPos.xyz - _ViewTarget.xyz);float3 ViewY float3(0,1,0);float3 ViewX cross(ViewZ,ViewY);ViewY cross(ViewX,ViewZ);float4x4 M_viewTemp float4x4(ViewX.x,ViewX.y,ViewX.z,0,ViewY.x,ViewY.y,ViewY.z,0,ViewZ.x,ViewZ.y,ViewZ.z,0,0,0,0,1);float4x4 M_viewTranslate float4x4(1,0,0,-_ViewPos.x,0,1,0,-_ViewPos.y,0,0,1,-_ViewPos.z,0,0,0,1);float4x4 M_view mul(M_viewTemp,M_viewTranslate);float3 vertexWS TransformObjectToWorld(v.vertexOS.xyz);//世界空间转化到观察空间float3 vertexVS mul(M_view,float4(vertexWS,1)).xyz;//相机参数float h _CameraParams.x * 2;float w h * _CameraParams.w;float n _CameraParams.y;float f _CameraParams.z;//正交相机投影矩阵//P_Clip [M_Clip] * P_viewfloat4x4 M_clipO;if(UNITY_NEAR_CLIP_VALUE-1){//OpenGLM_clipO float4x4(2/w,0,0,0,0,2/h,0,0,0,0,2/(n - f),(n f) / (n - f),0,0,0,1);}if(UNITY_NEAR_CLIP_VALUE1){//DirectXM_clipO float4x4(2/w,0,0,0,0,2/h,0,0,0,0,1/(f-n),f/(f-n),0,0,0,1);}//透视相机投影矩阵float4x4 M_clipP;if(UNITY_NEAR_CLIP_VALUE-1){//OpenGLM_clipP float4x4(2*n/w,0,0,0,0,2*n/h,0,0,0,0,(nf)/(n-f),(2*n*f)/(n-f),0,0,-1,0);}if(UNITY_NEAR_CLIP_VALUE1){//DirectXM_clipP float4x4(2*n/w,0,0,0,0,2*n/h,0,0,0,0,n/(f-n),(n*f)/(f-n),0,0,-1,0);}//手动将观察空间下的坐标转换到裁剪空间下float4x4 M_clip _CameraType ? M_clipP : M_clipO;o.vertexCS mul(M_clip,float4(vertexVS,1));//观察空间 转化到 齐次裁剪空间//o.vertexCS TransformWViewToHClip(vertexVS);//o.vertexCS TransformObjectToHClip(v.vertexOS.xyz);return o;}half4 frag (Varying i) : SV_Target{float4 mainTex SAMPLE_TEXTURE2D(_MainTex,sampler_MainTex,i.uv);return mainTex;}ENDHLSL}} }
http://www.zqtcl.cn/news/243149/

相关文章:

  • 杭州响应式网站案例建筑工程网站建站方案
  • 网站访客抓取国内网站搭建
  • 凡科网站做的好不好太原网页
  • 十堰商城网站建设国外效果图网站
  • 怎么登陆建设工程网站泉州网红
  • 哈尔滨队网站网页美工跨境电商是什么意思
  • 网站规划与建设课程推广型网站建设软件
  • 山东网站建设系统网站设计哪家更好
  • 网络推广有哪些网站网络推广公司联系昔年下拉
  • 长沙专业外贸建站公司百度提交网站入口网站
  • 西安网站搭建建设定制市场营销推广策略
  • 用户等待网站速度公司网站怎么做站外链接
  • 设计新闻发布网站模板wonder audio wordpress
  • 教育与培训网站建设wordpress侧栏文章
  • 四川做网站的公司哪家好信誉好的赣州网站建设
  • seo外包网站网站的备案流程图
  • 学网站建设好么免费网页制作有哪些
  • 宁波公司网站开发招聘最便宜的视频网站建设
  • 找人做网站大概多少钱永州企业网站建设
  • 免费备案网站空间网站怎么做组织图
  • 四川省和城乡建设厅网站怎么做网站淘宝转换工具
  • 网站单页支付宝支付怎么做的排名优化公司口碑哪家好
  • 淄博网站制作服务推广做网站服务器配置
  • ppt做的好的有哪些网站有哪些广州品牌型网站建设
  • 怎么学做一件完整衣服网站网站 相对路径
  • 十大wordpress主题江门seo排名优化
  • 石家庄网站搭建定制在百度上如何上传自己的网站
  • 南宁建设厅官方网站福州中小企业网站制作
  • 模板网站建设平台昆山专业网站建设公司哪家好
  • 百度指数的数值代表什么网站建设优化的作用