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

西安网站建设孙正学做健康食品的网站

西安网站建设孙正学,做健康食品的网站,移动网站开发内容,台州seo免费诊断Unity制作力场护盾 大家好#xff0c;我是阿赵。   继续做护盾#xff0c;这一期做一个力场冲击波护盾。 一、效果展示 主要的效果并不是这个球#xff0c;而是护盾在被攻击的时候#xff0c;会出现一个扩散的冲击波。比如上图在右边出现了冲击波 如果在左边被攻击我是阿赵。   继续做护盾这一期做一个力场冲击波护盾。 一、效果展示 主要的效果并不是这个球而是护盾在被攻击的时候会出现一个扩散的冲击波。比如上图在右边出现了冲击波 如果在左边被攻击冲击波会出现在左边并且慢慢扩散渐隐消失。 二、原理 把用于装饰的球体去掉之后实际上我们要做的事情其实很简单就是要计算一个沿着球体的环形范围显示。 1、准备工作 这里我们需要几个东西 1.一个球形模型 用于获取碰撞点还有显示冲击波 2.碰撞点的坐标   比如我们用鼠标点击来模拟攻击护盾那么从屏幕的鼠标位置发射射线碰撞到上面的球体得到一个球体上的坐标用于计算扩散的中心点 3.扩散范围的大小   在每次点击护盾获取到碰撞点之后这个值应该是动态改变的从小到大用于控制扩散的幅度 4.一张渐变图 这张渐变图其实就是上面看到的环形效果所采样的贴图了。 2、计算过程 接下来看看是怎样计算的 1.计算碰撞点的坐标和球体的顶点坐标的距离distance 2.距离distance减去一个size得到一个扩散范围range 3.扩散范围除以一个扩散值diffuse用于扩散范围的拉伸 4.上面得到的值作为UV坐标的u坐标然后v坐标是0.5。其实v坐标是0-1随便一个值都可以因为  我们的渐变图只有x轴有变化。用这个uv值去采样渐变图就能得到一个沿着球体的环形贴图效果 通过控制size的大小就能让这个 环形从小到大的变化。   如果觉得这个环太整齐了可以在第2步计算范围之后再减去一个噪声图采样这样环形的边缘就会出现不规则的变化 看着好像很复杂的效果其实做起来是很简单的。接下来写一个很简单的C#脚本获取碰撞点把坐标传入到材质球里面然后在C#写一个size从小到大变化的控制让环形从小到大的扩散最后消失就可以了。 3、特别说明 1.多个冲击波 上面这样做之后我们每次就只能点击出一个冲击波如果点击第二个的时候第一个会消失。为了可以多个冲击波同时存在可以通过C#端的SetVectorArray方法和SetFloatArray方法使用数组去传冲击波中心点和扩散的size然后在shader里面用循环的方式计算多个中心点和扩散size得到多个冲击波同时出现的效果 2.三平面采样 然后还有一个需要说明的是如果我们单纯的用UV坐标去采样噪声图在球形的UV接缝位置会出现断裂的情况。所以我这里使用了一个三平面采样的技术 inline float4 TriplanarSampling44(sampler2D topTexMap, float3 worldPos, float3 worldNormal, float falloff, float2 tiling, float3 normalScale, float3 index) {float3 projNormal (pow(abs(worldNormal), falloff));projNormal / (projNormal.x projNormal.y projNormal.z) 0.00001;float3 nsign sign(worldNormal);half4 xNorm; half4 yNorm; half4 zNorm;xNorm tex2D(topTexMap, tiling * worldPos.zy * float2(nsign.x, 1.0));yNorm tex2D(topTexMap, tiling * worldPos.xz * float2(nsign.y, 1.0));zNorm tex2D(topTexMap, tiling * worldPos.xy * float2(-nsign.z, 1.0));return xNorm * projNormal.x yNorm * projNormal.y zNorm * projNormal.z; }使用起来也很简单 直接使用UV坐标采样一般是这样写 float2 noiseUV i.uv*_noiseTex_ST.xy _noiseTex_ST.zw; float4 noiseCol tex2D(_noiseTex, noiseUV);现在改成 float4 noiseCol TriplanarSampling44(_noiseTex, i.vertex_world, i.normal_world, 1.0, _noiseTilling, 1, 0);3.装饰球体的制作 最后那个用于装饰用的球其实Shader代码更简单就是一个菲涅尔边缘光加上一个Flow流动效果用一张噪声图做流动而已。Flow的源码在上一篇闪电护盾给过了所以这里就不给了各位有兴趣可以自己试试。 三、代码 c#代码就不给了实在太简单就是一个射线拾取碰撞点的代码。   给一下Shader的源码吧 Shader azhao/ShockWave {Properties{_diffuse(kuosan,float) 0_noiseTex(noiseTex,2D) black{}_gradient(gradientTex,2D) black{}_baseColor(baseColor,Color) (1,1,1,1)_noisePow(noisePow,float) 1_addSize(addSize,float) 0_divSize(divSize,float) 1_noiseTilling(noiseTilling,Vector) (1,1,1,1)_hitSpeed(hitSpeed,float) 10}SubShader{Tags { QueueTransparent }LOD 100Pass{Blend SrcAlpha OneMinusSrcAlphaCGPROGRAM#pragma vertex vert#pragma fragment frag#include UnityCG.cgincstruct appdata{float4 vertex : POSITION;float2 uv : TEXCOORD0;float3 normal:NORMAL;};struct v2f{float2 uv : TEXCOORD0;float4 vertex : SV_POSITION;float4 vertex_world:TEXCOORD1;float3 normal_world:TEXCOORD2;};float3 _hitCenter[10];float _hitSize[10];float _diffuse;sampler2D _noiseTex;float4 _noiseTex_ST;sampler2D _gradient;float4 _baseColor;float _noisePow;float _addSize;float _divSize;float2 _noiseTilling;float _hitSpeed;inline float4 TriplanarSampling44(sampler2D topTexMap, float3 worldPos, float3 worldNormal, float falloff, float2 tiling, float3 normalScale, float3 index){float3 projNormal (pow(abs(worldNormal), falloff));projNormal / (projNormal.x projNormal.y projNormal.z) 0.00001;float3 nsign sign(worldNormal);half4 xNorm; half4 yNorm; half4 zNorm;xNorm tex2D(topTexMap, tiling * worldPos.zy * float2(nsign.x, 1.0));yNorm tex2D(topTexMap, tiling * worldPos.xz * float2(nsign.y, 1.0));zNorm tex2D(topTexMap, tiling * worldPos.xy * float2(-nsign.z, 1.0));return xNorm * projNormal.x yNorm * projNormal.y zNorm * projNormal.z;}v2f vert (appdata v){v2f o;o.vertex UnityObjectToClipPos(v.vertex);o.uv v.uv;o.vertex_world mul(v.vertex, unity_ObjectToWorld);o.normal_world mul(unity_WorldToObject, v.normal);return o;}fixed4 frag (v2f i) : SV_Target{float alpha 0;for (int j 0;j 10;j){float dis distance(_hitCenter[j], i.vertex_world);float hitMaskVal (1 - (dis - _addSize)) / (max(_divSize, 0.001f));float hitSizeVal (dis - (_hitSize[j] * _hitSpeed)) / _diffuse;//float2 noiseUV i.uv*_noiseTex_ST.xy _noiseTex_ST.zw;//float4 noiseCol tex2D(_noiseTex, noiseUV);float4 noiseCol TriplanarSampling44(_noiseTex, i.vertex_world, i.normal_world, 1.0, _noiseTilling, 1, 0);float noisePowerVal pow(noiseCol.r, _noisePow);float hitRange clamp(hitSizeVal - noisePowerVal, 0, 1);float2 jianbianUV float2(hitRange, 0);float4 jianbianCol tex2D(_gradient, jianbianUV);alpha alpha clamp(hitMaskVal* jianbianCol.r, 0, 1);}alpha * _baseColor.a;return float4(_baseColor.rgb, alpha);}ENDCG}} }
http://www.yutouwan.com/news/464042/

相关文章:

  • 南京科技网站设计费用有什么网站是专做婚礼素材的
  • wordpress很多英文文章长春做网络优化的公司
  • wordpress搭建影视站毕设网站
  • 花都网站建设策划宽屏网站欣赏
  • 做网站用什么语音沈阳百度seo关键词优化排名
  • 网站建设服务费计入什么科目电子网站建设方案
  • 创意网站建设设计公司修改wordpress上传文件大小
  • 网站seo诊断湖南岚鸿深圳最便宜的物流公司
  • 做网站开发的经营范围深圳市地图
  • 网站建设不完整wordpress 网址分享
  • 怎样看网站建设如何建设自己的网站
  • phpcms 投资 网站源码广州企业建站系统模板
  • 湖北建设厅网站模版的优化
  • 芜湖做网站的邓健照片厦门专业的网站建设
  • 东莞网站建设制作价格做视频网站 服务器
  • 去哪个网站找题目给孩子做网站建设排名优化公司
  • 郑州pc网站开发wap建站程序
  • 网站免费一站二站四站模板制作工艺流程
  • 什么是网站建设外包wordpress 商场插件
  • 百度站长平台网址wordpress外部链接
  • html5自适应网站模板广州安全教育平台登录入口账号
  • 没备案的网站能用吗有源码怎么做app
  • 制作网站 美工天津做一个简单的网站首页
  • 东莞php网站建设价格网站前置审批类型
  • 网站建设的步骤及方法哪些是用vue做的网站
  • 广东广州电脑个人建站wordpress怎么把图片存七牛
  • 保险官方网站顺德手机网站设计信息
  • 做网站工作室互联网商城建设
  • 什么网站可以做高三英语试题吉林省吉林市舒兰市
  • 免费网站商城建设网站图片自动切换怎么做