unity UGUI 正交相机实现图片的透视旋转效果
UI透视效果常见的就是绕x轴或y轴旋转,来达到近大远小的效果。正经要做透视UI的话肯定直接用透视相机,如果透视效果用的极少(就一张图)不改动相机类型才按这种思路进行。
最简单直接的想法就是把矩形的图片顶点扭成梯形,在PS里面扭一下很直观的就是透视效果嘛。但是在unity里面不行,一个矩形实际是两个三角面,改了顶点位置之后明显是能看出来扭曲的,所以要按照径向方向再切分,来削弱扭曲效果。
大概切8刀(分成9份)效果就还不错了,当然如果放一个正方形、圆形这种标准图形还是能明显看出来 需要再提高切分次数。
贴出主要思路 要用的话需要再补全一下
public class UIRawImagePerspective : BaseMeshEffect
{
[SerializeField]
private float m_DeltaRate = 0.1f;
[SerializeField]
private int m_SplitCount = 8;
// Properties 略
private Graphic m_Graphic;
private Vector3 m_LastRotation;
protected override void OnEnable()
{
base.OnEnable();
m_LastRotation = transform.rotation.eulerAngles;
m_Graphic = this.GetComponent<Graphic>();
}
private void Update()
{
if (!IsActive()) return;
Vector3 rotation = transform.rotation.eulerAngles;
if (rotation != m_LastRotation)
{
m_LastRotation = rotation;
m_Graphic.SetVerticesDirty();
}
}
private override void ModifyMesh(VertexHelper vh)
{
if (!IsActive()) return;
if (m_SplitCount <= 0) return;
Vector3 rotation = m_LastRotation;
if (rotation.x == 0 && rotation.y == 0) return;
if (vh.currentVertCount > 4)
{
// 不是单个矩形的不处理
return;
}
// 这个函数是自定义的,因为直接用GetUIVertexStream()比较讨厌,写法也很别扭,实际逻辑就是取出数据
List<UIVertex> vertices = vh.GetUIVerticesEx();
List<int> indices = new List<int>();
UIVertex v;
if (rotation.x != 0)
{
float left = vertices[0].position.x;
float right = vertices[2].position.x;
Vector4 uvLeftBottom = vertices[0].uv0;
Vector4 uvRightBottom = vertices[3].uv0;
float delta = Mathf.Sin((rotation.x / 180) * Mathf.PI) * m_DeltaRate;
float length = right - left;
UIVertex tempBottom = vertices[0];
UIVertex tempTop = vertices[1];
vertices.Clear();
int parts = m_SplitCount + 1;
float topLeft = left + delta * length * 0.5f;
float bottomLeft = left - delta * length * 0.5f;
for (int i = 0; i < m_SplitCount + 2; i++)
{
float partFactor = (float)i / parts;
float uvx = uvLeftBottom.x + partFactor * (uvRightBottom.x - uvLeftBottom.x);
v = tempBottom;
v.position.x = bottomLeft + partFactor * length * (1 + delta);
v.uv0.x = uvx;
vertices.Add(v);
v = tempTop;
v.position.x = topLeft + partFactor * length * (1 - delta);
v.uv0.x = uvx;
vertices.Add(v);
if (i > 0)
{
int count = vertices.Count;
indices.Add(count - 4);
indices.Add(count - 3);
indices.Add(count - 1);
indices.Add(count - 1);
indices.Add(count - 2);
indices.Add(count - 4);
}
}
}
else
{
// 绕y轴旋转 换个方向再来一遍 略
}
vh.Clear();
// 这个函数是自定义的,也是因为AddUIVertexStream()用起来比较讨厌
vh.SetFullData(vertices, indices);
}
}
unity UGUI 正交相机实现图片的透视旋转效果的更多相关文章
- Unity 3D 正交相机(Orthographic)
1. Camera.aspect 表示摄像机显示区域的纵横比.宽高比,摄像机初始化的时候会默认设置成当前屏幕的宽高比,可以更改,也可以通过 Camera.ResetAspect 来重置. 2. Cam ...
- Unity UGUI实现鼠标拖动图片
using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; ...
- Unity UGUI暂停按钮切换图片代码
using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; ...
- Unity正交相机智能包围物体(组)方案
Unity正交相机智能包围物体(组)方案 目录 Unity正交相机智能包围物体(组)方案 一.技术背景 二.相关概念 2.1 正交摄像机 2.2 正交相机的Size 2.3 相机的Aspect 2.4 ...
- Unity UGUI图文混排源码(三) -- 动态表情
这里是根据图文混排源码(二)进一步修改的,其他链接也不贴了,就贴一个链接就好了,第一次看这文章的同学可以先去看看其他几篇文章 Unity UGUI图文混排源码(二):http://blog.csdn. ...
- Unity UGUI图文混排源码(二)
Unity UGUI图文混排源码(一):http://blog.csdn.net/qq992817263/article/details/51112304 Unity UGUI图文混排源码(二):ht ...
- Unity UGUI图文混排源码(一)
Unity UGUI图文混排源码(一):http://blog.csdn.net/qq992817263/article/details/51112304 Unity UGUI图文混排源码(二):ht ...
- Unity UGUI实现图文混排
目前在unity实现图文混排的好像都是通过自定义字体然后在文本获取字符的位置,用图片替换掉图片标签,这样对于支持英文来说,并没有什么影响.然后对于中文来说就是一个相当麻烦的事了,毕竟图文混排多用于游戏 ...
- Unity UGUI
超详细的基础教程传送门:(持续更新中) Unity UGUI之Canvas&EventSystem:http://blog.csdn.net/qq992817263/article/detai ...
- Unity UGUI Layout自动排版组件用法介绍
Unity UGUI布局组件 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享 ...
随机推荐
- python-gitlab 一个简单demo
背景 需要收集git仓库信息到数据库供前端展示 包括:仓库信息.仓库所有者.成员列表.提交信息.活跃情况等 需要定时启动.灵活触发 实现简介 使用gitlab v4 restful 接口 使用pyth ...
- React Router@3.x 升级到 @6.x 的实施方案
我们是袋鼠云数栈 UED 团队,致力于打造优秀的一站式数据中台产品.我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值. 本文作者:景明 升级背景 目前公司产品有关 react 的工具版本普 ...
- Django视图与网址进阶
1. 采用/add/?a=4&b=5这样get方法进行 1)修改learn/views.py文件 代码: #增加新函数 def add(request): a=request.GET['a'] ...
- Programming abstractions in C阅读笔记:p123-p126
<Programming Abstractions In C>学习第50天,p123-p126,总结如下: 一.技术总结 1.notaion 这也是一个在计算机相关书籍中出现的词,但有时却 ...
- 详解 canal 同步 MySQL 增量数据到 ES
canal 是阿里知名的开源项目,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费. 这篇文章,我们手把手向同学们展示使用 canal 将 MySQL 增量数据同步到 ES . ...
- 利用接口测试框架实现web状态的监控
之前,我们已经说明了如何实现一个我们的接口测试框架RATF,当然这个框架不止可以用于管理我们的接口测试代码,我们还可以用他来对我们的web进行简单粗暴的监控. 原理: 1. 通过使用配置文件,对要监控 ...
- Ubuntu 18.04安装RabbitMQ
1.安装erlang语言环境 sudo apt install erlang-nox 2.更新Ubuntu 源 sudo apt update 3.安装RabbitMQ服务 sudo apt inst ...
- Solution -「CF 1303G」Sum of Prefix Sums
Description Link. 对于一棵树,选出一条链 \((u,v)\),把链上结点从 \(u\) 到 \(v\) 放成一个 长度 \(l\) 的数组,使得 \(\sum_{i=1}^{l}\s ...
- Openssl Des3对压缩文件进行加密命令详解
群友提问: 致力于明天: tar -cvf - WMG_Back_"$Today"|openssl des3 -salt -k hY91gd3GJAAfghECleLwWQAPGK ...
- FreeSWITCH添加h264编码及pcap视频提取
操作系统 :CentOS 7.6_x64.Windows 10_x64 FreeSWITCH版本 :1.10.9 Python版本:3.9.2 一.启用h264相关模块 这里以 mod_openh26 ...