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

红袖添香网站建设时间专业网页设计价格

红袖添香网站建设时间,专业网页设计价格,如何查看网站的建设者,小贷网站需要多少钱可以做这是使用几何着色器在点中心生成一个点并根据这个点把原本的面片分成三个三角形的操作。 对于几何着色器构造相对简单#xff0c;网上的信息也相对较多#xff0c;需要注意的点就是需要提供一个新的数据结构供几何着色器输出#xff0c;因为几何着色器在顶点之后#xff0… 这是使用几何着色器在点中心生成一个点并根据这个点把原本的面片分成三个三角形的操作。 对于几何着色器构造相对简单网上的信息也相对较多需要注意的点就是需要提供一个新的数据结构供几何着色器输出因为几何着色器在顶点之后片元之前所以结构体就需要模型输入的结构体、顶点输出的结构体、几何输出的结构体。 下面是完整代码 Shader Kerzh/GeoShaderTest {Properties{_Length(Length,Float) 1}SubShader{Tags {LightMode UniversalForward}LOD 100Pass{Cull OffCGPROGRAM#pragma vertex vert#pragma fragment frag#pragma geometry geom#include UnityCG.cginc//cpu 传到 vsstruct appdata{float4 posOS : POSITION;float2 uv : TEXCOORD0;float4 normalOS : NORMAL;};//vs 传到 gsstruct v2g{float4 posOS : TEXCOORD0;float2 uv : TEXCOORD1;float3 normalOS : TEXCOORD2;};//gs 传到 fsstruct g2f{float4 posCS : SV_POSITION;float2 uv : TEXCOORD0;float3 normalWS : TEXCOORD1;float3 posWS : TEXCOORD2;float dis : TEXCOORD3;};float _Length;v2g vert (appdata input){v2g output;output.uv input.uv;output.normalOS input.normalOS;output.posOS input.posOS;return output;}//最大的顶点数这里比如你要生成三个三角形面片那么一个面片需要三个顶点就是9个顶点[maxvertexcount(9)]void geom (triangle v2g input[3],inout TriangleStreamg2f triStream){g2f center; // 中间那个点center.uv (input[0].uv input[1].uv input[2].uv)/3.0;// 计算中间点的uvfloat3 centerNormalOS (input[0].normalOS input[1].normalOS input[2].normalOS)/3.0;center.normalWS UnityObjectToWorldNormal(centerNormalOS );// 计算中间点的法线float3 centerPosOS (input[0].posOS input[1].posOS input[2].posOS)/3.0;// 计算中间点的位置centerPosOS centerPosOS centerNormalOS *_Length;// 沿着中心点法线根据噪声及系数位移中心点//中心点后期所需数据center.posWS mul(unity_ObjectToWorld, centerPosOS);center.posCS UnityObjectToClipPos(centerPosOS);center.dis 1;g2f output[3]; // 这里是原样把输入三角形的三个点放到了这里面只是为了下面取得方便for(int i0;i3;i){g2f p0;p0.uv input[i].uv;p0.normalWS UnityObjectToWorldNormal( input[i].normalOS);p0.posWS mul(unity_ObjectToWorld, input[i].posOS);p0.posCS UnityObjectToClipPos(input[i].posOS );p0.dis 0;output[i] p0;}// 根据这三个点分别和中心点制造三角形输出triStream.RestartStrip(); // 重新开始一个新的三角形triStream.Append(output[1]);triStream.Append(center);triStream.Append(output[0]);triStream.RestartStrip(); // 重新开始一个新的三角形triStream.Append(output[2]);triStream.Append(center);triStream.Append(output[1]);triStream.RestartStrip(); // 重新开始一个新的三角形triStream.Append(output[0]);triStream.Append(center);triStream.Append(output[2]);}float4 frag (g2f i) : SV_Target{return i.dis;return float4(i.uv,0,0);}ENDCG}} } 关于其中几何着色器的部分 //最大的顶点数这里比如你要生成三个三角形面片那么一个面片需要三个顶点就是9个顶点[maxvertexcount(9)]void geom (triangle v2g input[3],inout TriangleStreamg2f triStream){g2f center; // 中间那个点center.uv (input[0].uv input[1].uv input[2].uv)/3.0;// 计算中间点的uvfloat3 centerNormalOS (input[0].normalOS input[1].normalOS input[2].normalOS)/3.0;center.normalWS UnityObjectToWorldNormal(centerNormalOS );// 计算中间点的法线float3 centerPosOS (input[0].posOS input[1].posOS input[2].posOS)/3.0;// 计算中间点的位置centerPosOS centerPosOS centerNormalOS *_Length;// 沿着中心点法线根据噪声及系数位移中心点//中心点后期所需数据center.posWS mul(unity_ObjectToWorld, centerPosOS);center.posCS UnityObjectToClipPos(centerPosOS);center.dis 1;g2f output[3]; // 这里是原样把输入三角形的三个点放到了这里面只是为了下面取得方便for(int i0;i3;i){g2f p0;p0.uv input[i].uv;p0.normalWS UnityObjectToWorldNormal( input[i].normalOS);p0.posWS mul(unity_ObjectToWorld, input[i].posOS);p0.posCS UnityObjectToClipPos(input[i].posOS );p0.dis 0;output[i] p0;}// 根据这三个点分别和中心点制造三角形输出triStream.RestartStrip(); // 重新开始一个新的三角形triStream.Append(output[1]);triStream.Append(center);triStream.Append(output[0]);triStream.RestartStrip(); // 重新开始一个新的三角形triStream.Append(output[2]);triStream.Append(center);triStream.Append(output[1]);triStream.RestartStrip(); // 重新开始一个新的三角形triStream.Append(output[0]);triStream.Append(center);triStream.Append(output[2]);} 大部分在注释中描述的相对明确但要注意这些操作 center.uv (input[0].uv input[1].uv input[2].uv)/3.0;// 计算中间点的uv center.normalWS UnityObjectToWorldNormal(centerNormalOS );// 计算中间点的法线 //中心点后期所需数据 center.posWS mul(unity_ObjectToWorld, centerPosOS); center.posCS UnityObjectToClipPos(centerPosOS); center.dis noise; 根据一定的计算规则给中心点赋予详细的顶点信息这样他就和模型上初始存在的顶点无异数据填充完毕后和原顶点一起组成片元组成一个片元的操作如下。 triStream.RestartStrip(); //  重新开始一个新的三角形 triStream.Append(output[1]); triStream.Append(center); triStream.Append(output[0]); 通过这样的操作确立一个三角形片元中的三个点。 而这些点在像素着色器中调用时因为是对每个像素调用所以会根据这些点取插值 这里的像素着色器是这么写的 float4 frag (g2f i) : SV_Target {return i.dis; }所以对于一个片元中的像素根据片元三个顶点的信息 struct g2f {float4 posCS : SV_POSITION;float2 uv : TEXCOORD0;float3 normalWS : TEXCOORD1;float3 posWS : TEXCOORD2;float dis : TEXCOORD3; }; 插值到对应像素dis也就会呈现出一种渐变感。
http://www.pierceye.com/news/206216/

相关文章:

  • 电影院网站建设方案网络维护是什么职业
  • 网站建设需要的公司wordpress考试主题
  • 企业网站管理系统多站多语言版电子书推送网站怎么做
  • 海洋公司做网站推广安阳网站如何做优化
  • 南昌网站开发公司哪家公司好网站建设接单
  • 宁波网站制作哪家强调用wordpress的文章编辑器
  • 在线制作手机网站公司网站建设厂家
  • 在线分析网站一个小外贸公司怎么开
  • 给自己的公司做网站怎么做好电脑手机一体网站
  • 精通网站建设 全能建站密码pdf电商网站设计理念
  • 百度推广建设网站是不是合发手机网站的必要性
  • 企业网站建设是什么实现的物质基础和技术支撑现货交易平台代理
  • 网站建设的描述长沙发布app
  • 好的设计作品网站代理网站建设
  • 做网站的软件m开头网站建设公司问候语
  • 做网站需要工商证吗app软件开发价格
  • 做足球原创短视频网站网站建设永远在路上
  • 做seo为什么要了解网站苏州做网站公司
  • 这几年做哪些网站能致富网站开发账务处理
  • 网站的版权信息做阿里巴巴网站卖货咋样
  • 找项目去哪个网站成都哪里有做网站的公司
  • 网站推广的方法及特点国外专门做童装的网站
  • 企业网站开发模型图wordpress 侧边导航
  • 济南网站系统优化网站建设属于什么专业
  • 114啦建站程序页面效果好的网站
  • 龙华网站建设-信科网络电子商务网站建设和技术现状
  • 网站备案有效期wordpress 评论图片
  • 搭建网站需要哪些步骤wordpress 主题使用
  • 网站怎么发布做微商天眼官方网站
  • qq群网站制作异常网站服务器失去响应