unity各种形状正确描边方式

描边在卡通渲染中经常会用到,最常见的做法是法线外扩,这种方式有一个问题是如果顶点的两个边的法线变化不连续或者说变化比较大,则会出现分叉,入正方体的法线外扩就会有这个问题。

其他解决方式: 

然后有一些做法可以解决这种问题,比如顶点放大,然后后处理把中间角色的颜色剔除来模拟描边。这种的问题就在于有一个全屏后处理的消耗,对于手机带宽有一定的影响。

当然还有卷积处理等等都会增加一定的带宽消耗。

而之前有尝试过一种解决方式,能够类似多一个pass描边来解决问题而不需要其他多余的消耗。

本方案核心思路:

主要的做法是堆模型的顶点做预处理。首先说下我们在顶点着色器是用顶点的法线外扩来实现最基础的描边的,而其实顶点他本身是没有法线这个概念的,他的法线来源于他的面,而一个顶点会相连三个面,如果我们只用一个面的信息,那么他当然是不连续的跳跃的过渡的。而我们想让他连续的话,就需要离线将三个面的法线拿到然后取平均。这个给到顶点颜色上,然后这个顶点颜色就是平均法线了,然后这个法线在描边的pass中做外扩就能得到连续的描边了。

核心代码:

离线处理上核心是法线取平均让他顶点间的法线连续:

for (int i = 0; i < mMesh.vertices.Length; i++)
{
            var key = mMesh.vertices[i];
            if (mRealNormals.ContainsKey(key))
            {
                mRealNormals[key] += mMesh.normals[i] / 3;
            }
            else
            {
                mRealNormals[key] = mMesh.normals[i] / 3;
            }
}

shader中拿颜色信息外扩:

input.positionOS.xyz += input.color * _Outline;

最终效果:

 

 

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在Unity中实现鼠标经过物体时描边的效果,可以通过以下步骤实现: 1. 导入描边Shader 首先要导入一个描边Shader,可以从Unity Asset Store中下载或自行编写。这里以一个叫做“Outline Object”描边Shader为例,在Shader中添加以下代码: ``` Shader "Custom/Outline Object" { Properties { _OutlineColor ("Outline Color", Color) = (1,0.5,0,1) _Outline ("Outline width", Range(0.01,0.1)) = 0.05 } SubShader { Tags {"Queue"="Transparent" "RenderType"="Transparent"} LOD 100 Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc" struct appdata { float4 vertex : POSITION; }; struct v2f { float4 vertex : SV_POSITION; float4 worldPos : TEXCOORD0; }; float _Outline; float4 _OutlineColor; v2f vert (appdata v) { v2f o; o.vertex = UnityObjectToClipPos(v.vertex); o.worldPos = mul(unity_ObjectToWorld, v.vertex); return o; } fixed4 frag (v2f i) : SV_Target { float3 worldNormal = UnityObjectToWorldNormal(float3(0,0,1)); float3 worldPos = i.worldPos.xyz + worldNormal * _Outline; float4 col = tex2D(_MainTex, i.uv); float4 outline = tex2D(_OutlineTex, i.uv); col *= outline.a; if (outline.a <= 0) discard; return col * _OutlineColor; } ENDCG } } FallBack "Diffuse" } ``` 其中,_OutlineColor表示描边颜色,_Outline表示描边宽度。 2. 触发描边效果 在鼠标经过物体时,触发描边效果。可以在物体的脚本中添加以下代码: ``` using System.Collections; using System.Collections.Generic; using UnityEngine; public class OutlineObject : MonoBehaviour { private Renderer _renderer; private Material _material; public Shader _shader; void Start() { _renderer = GetComponent<Renderer>(); _material = _renderer.material; _material.shader = _shader; } void OnMouseEnter() { _material.SetFloat("_Outline", 0.05f); } void OnMouseExit() { _material.SetFloat("_Outline", 0f); } } ``` 其中,OnMouseEnter()函数和OnMouseExit()函数分别在鼠标经过物体和离开物体时触发描边效果,_material.SetFloat("_Outline", 0.05f)表示设置描边宽度为0.05。 通过以上步骤,就可以实现鼠标经过物体时的描边效果了。需要注意的是,该方法只适用于鼠标触发描边效果,如果需要其他方式触发描边效果,需要修改脚本中的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值