Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >5分钟入门Cinemachine智能相机系统

5分钟入门Cinemachine智能相机系统

作者头像
全栈程序员站长
发布于 2022-09-02 06:26:25
发布于 2022-09-02 06:26:25
9620
举报

大家好,又见面了,我是你们的朋友全栈君。

摘要:相机是Unity世界的眼睛,一个智能相机更是能帮咱们节省大把的时间和精力。Cinemachine现在已经大量应用到各种项目中,如果你还没有用过Cinemachine,墙裂建议你来体验一下。

你好,我是跟着大智学Unity的萌新,我叫小新,这是我本周的学习总结报告哦。

Cinemachine入门

Cinemachine入门还是很容易的,5分钟足矣,但是深入去研究里面也有很多门道。

安装

Cinemachine是Unity官方开发的一个免费的插件。目前Cinemachine最新版为2.5,支持Unity 2017.1及以上版本。

从Unity 2018.1开始,Cinemachine可以从Package Manager安装。之前的Unity版本可以从Asset Store中下载安装。

安装好Cinemachine之后,菜单栏会有一个新的菜单项叫:Cinemachine。

Cinemachine没有外部依赖包,安装后就可以使用。Cinemachine还可以和Post Processing Stack(场景后处理工具)一起使用

从旧版Cinemachine升级

如果你从Asset Store安装过Cinemachine,现在想从Package manager中升级到最新版本。那需要注意以下步骤: 1、用Unity2018.1或之后的版本打开工程。 2、新建一个空场景(防止升级时场景中脚本引用丢失)。 3、在Project窗口中删除Cinemachine文件夹以及相关资产(如CinemachinePostProcessing相关资产)。 4、在Package Manager中安装Cinemachine包。

Cinemachine基本使用流程

使用Cinemachine时需要用一种新的方式来思考相机:你可能之前研究的都是如何通过脚本来更好的控制相机,但是在Cinemachine中,你需做的是各种相机的不同用途,快速创建出想要的相机然后调他们的参数就可以了。

虚拟相机

从菜单栏Cinemachine > Create Virutal Camera创建虚拟相机。

Cinemachine能控制大量相机,但是它并不创建新的相机,它通过控制Unity相机来实现多机位的效果。如何实现的呢?在Cinemachine中有一个虚拟相机的概念。虚拟相机是相机的一些设置,用于控制Unity相机的移动、旋转以及相关设置。

每个虚拟相机是一个单独的物体,独立运行,也和场景中的相机没有直接关系。例如,你的场景可能长这样:

虚拟相机有什么功能呢?

  • 决定Unity相机在场景中的位置
  • 决定Unity相机的朝向,并跟踪某物体
  • 为相机添加程序化的晃动,比如手持相机效果或者车辆的震动

Cinemachine系统鼓励你创建多个虚拟相机。虚拟相机有很好的性能,不用过多担心会出现性能问题。如果你的场景对性能很敏感,可以禁用当前使用的虚拟相机以外的所有的虚拟相机,这样能达到极致性能。

虚拟相机的一个最佳实践是:一个镜头使用一个虚拟相机。例如:

  • 对于两个角色对话的过场动画,使用三个虚拟相机:一个相机用于两个角色中间的镜头,单独的虚拟相机用于每个角色的特写镜头。然后使用Timeline同步音频与虚拟相机。
  • 复制一个现有的虚拟相机,这样两个虚拟相机在场景中的位置相同。对于第二个虚拟相机,稍微改变一下FOV或构图。当玩家进入触发区域时,Cinemachine会从第一个虚拟相机过渡到第二个虚拟相机,用于强调变化。

同一时间仅有一个虚拟相机控制Unity相机,这个虚拟相机被称为活动虚拟相机(live virtual camera)。例外情况是从一个虚拟相机混合到另外一个虚拟相机的时候,混合阶段两个虚拟相机都是活动状态。

2、添加Cinemachine Brain

通常这一步不需要你手动添加,因为在第一步创建Virtual Camera时会自动给Unity相机添加Cinemachine Brain组件。

CinemachineBrain是挂在Unity相机上的一个组件。这个组件会跟踪场景中所有的活动虚拟相机。你可以通过激活/禁用虚拟相机物体来指定下一个活动虚拟相机。

Cinemachine Brain在运行时可以响应各种事件,这样可以通过逻辑动态控制相机。因为在游戏中,很多动作是不可预测的。

3、配置VirtualCamera的移动和旋转策略

使用VirtualCamera组件中的Body属性来设置相机如何移动。使用Aim属性来设置相机如何旋转。

虚拟相机有两个跟踪目标:

  • Follow指定了相机跟随移动的目标。
  • Look At指定了相机瞄准的目标。

Cinemachine中包含了各种用于相机控制和瞄准的算法。每个算法提供了一种特定的方式,你可以通过设置算法的属性来满足你的特殊需求。你也可以通过继承CinemachineComponent来实现自定义的移动和瞄准的行为。

Body属性提供了下列算法来移动虚拟相机:

  • Do Nothing:不移动虚拟相机
  • Framing Transposer:在屏幕空间,保持相机和跟随目标的相对位置,可以设置缓动。
  • Hard Lock to Target:虚拟相机和跟随目标使用相同位置。
  • Orbital Transposer:相机和跟随目标的相对位置是可变的,还能接收用户的输入。常见于玩家控制的相机。
  • Tracked Dolly:相机沿着预先设置的轨道移动。
  • Transposer:相机和跟随目标的相对位置固定,可以设置缓动。

Aim属性提供了下列算法来旋转相机对准Look At的目标:

  • Composer:将目标保持在相机镜头内,可以设置多种约束
  • Group Composer:将多个目标保持在相机镜头内
  • Do Nothing:不旋转相机
  • POV:根据用户的输入旋转相机
  • Same As Follow Target:将相机的旋转和跟随目标的旋转同步
  • Hard Look At:将Look At目标固定在镜头中心的位置。

4、配置镜头构图

上面第3步提到的Framing Transposer、Composer和Group Composer算法定义了镜头的几个特殊区域,可以用于镜头构图。

  • Dead zone:Cinemachine会将目标保持在这个区域,目标在这个区域时,镜头保持不动。
  • Soft zone:如果目标进入这个区域,会触发相机的移动和旋转,将目标重新移回dead zone。这个过程可能很快,也可能很慢,取决于Damping属性设置。
  • Screen:Dead zone区域的中心在屏幕上的位置,可以不在整个游戏屏幕的正中间。
  • Damping:模式现实世界中操控相机时的延迟。Damping设置了目标进入soft zone后相机的反应速度。数值越小,相机反应越快,会更快地操作相机把目标保持在dead zone。数值越大,相机反应越慢,跟随目标回到dead zone所需的时间也就更长,可以用来模拟一个很笨重的摄像机。

组件中的Game Window Guides勾选后,可以在Game窗口可视化的查看/编辑构图区域。最外圈是no pass zone,也就是目标从来不会到的位置。中间的黄色小方块代表了target的位置。

通过拖拽每个区域的边缘或者调整Inspector上的数值来调整这些区域。调整这些区域可以得到多种多样的相机行为。比如使用更大的damping值模拟笨重的相机;增加dead zone和soft zone来创建一个对目标运动不敏感的相机。

5、配置模拟相机的晃动

现实世界的摄像机通常比较笨重,由摄影师手持或者绑在车辆上。使用Noise属性可以模拟这些效果。例如,你可以给相机添加晃动来跟随一个向前跑的角色以获得更好的沉浸感。

每帧更新后,Cinemachine给相机单独添加晃动。这些晃动不会影响相机后续的位置和镜头。这样可以保证虚拟相机运行结果的一致性。

总结

小新:“上面就是配置一个Cinemachine虚拟相机的基本流程,经过这些步骤之后,就有了一个初步能用的虚拟相机了。动动手试试调节一下这些属性,看看有什么不同的结果。后面咱们继续一起来探索这些属性的详细信息。”

【扩展学习】在洪流学堂公众号回复timeline可以下载Timeline&Cinemachine系列教程全文带目录PDF


发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/140408.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
java 中 BigDecimal 详解「建议收藏」
首先,学习一个东西,我们都必须要带着问题去学,这边我分为 【为什么?】【是什么?】【怎么用?】
全栈程序员站长
2022/08/14
7960
java 中 BigDecimal 详解「建议收藏」
BigDecimal使用总结
对于超过16位的大型数字,需要用到Java在java.math包中提供的API类BigDecimal,而且也不是传统的+-*/,而是调用对应的方法。
向着百万年薪努力的小赵
2022/11/20
8810
BigDecimal使用总结
Java中BigDecimal用法详解
float和double类型的主要设计目标是为了科学计算和工程计算。他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合。但是,商业计算往往要求结果精确,这时候BigDecimal就派上大用场啦。
挨踢小子部落阁
2023/03/16
9250
Java中BigDecimal用法详解
Kotlin BigDecimal 精确计算
完整工具类 /** * 加、减、乘、除 高精度计算工具类 * @author lyl 20190191 * */ object UtilsBigDecimal { // 需要精确至小数点后几位 const val DECIMAL_POINT_NUMBER:Int = 2 // 加法运算 @JvmStatic fun add(d1:Double,d2:Double):Double = BigDecimal(d1).add(BigDecimal(d2)).s
码脑
2019/04/11
4.8K0
BigDecimal的除法
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/147892.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/02
2K0
【java基础】BigDecimal 精度控制
如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同。
爱笑的架构师
2020/09/24
7360
Java中的BigDecimal详解
今天碰到一个问题,金额计算用double类型会丢失经度,就改用了BigDecimal类型,这个类型之前用的比较少,没怎么接触。就到网上看了一下相关教程,写个总结记一下。
sunonzj
2022/06/21
6330
java 四舍五入保留小数的几种方式
(new BigDecimal()).setScale()方法用于格式化小数点,有多种小数保留模式,如下:
全栈程序员站长
2022/08/31
2.5K0
BigDecimal加减乘除计算
前阵子做题遇到了大数的精确计算,再次认识了bigdecimal 关于Bigdecimal意外的有许多小知识点和坑,这里特此整理一下为方便以后学习,希望能帮助到其他的萌新
全栈程序员站长
2022/07/23
2.4K0
BigDecimal加减乘除计算
BigDecimal 保留小数位/保留两位小数「建议收藏」
ROUND_CEILING Rounding mode to round towards positive infinity. 向正无穷方向舍入
全栈程序员站长
2022/09/29
3.5K0
【蓝桥杯Java_C组·从零开始卷】第五节(二)、BigDecimal的使用
RoundingMode是一个枚举类,有以下几个值:UP,DOWN,CEILING,FLOOR,HALF_UP,HALF_DOWN,HALF_EVEN,UNNECESSARY 
红目香薰
2022/11/29
1.2K0
【蓝桥杯Java_C组·从零开始卷】第五节(二)、BigDecimal的使用
Double转BigDecimal并保留两位小数出现异常: java.lang.ArithmeticException: Rounding necessary
Double 转 BigDecima l并保留两位小数出现异常: java.lang.ArithmeticException: Rounding necessary 。
全栈程序员站长
2022/08/31
8800
新手小白学JAVA 正则表达式 包装类 自动装箱/自动拆箱 BigDecimal
正确的字符串格式规则。 常用来判断用户输入的内容是否符合格式的要求,注意是严格区分大小写的。
全栈程序员站长
2022/08/15
3170
新手小白学JAVA 正则表达式 包装类 自动装箱/自动拆箱 BigDecimal
手把手教你进行 Java 的精确计算
作为 Java 程序员在日常的工作中,很多时候我们都会遇到一些需要进行数据计算的场景,通常对于不需要计算精度的场景我们都可以使用 Integer,Float 或者 Double 来进行计算,虽然会丢失精度但是偶尔也可以用,如果我们需要精确计算结果的时候,就会用到 java.math 包中提供的 BigDecimal 类来实现对应的功能了。
Java极客技术
2022/12/02
6060
手把手教你进行 Java 的精确计算
Java中的BigDecimal比较大于小于等于,四舍五入保留几位(setScale方法详解),加减乘除取余
本文主要讲解BigDecimal的比较运算,保留精度和取整和基础运算,BigDecimal与其他数据类型转换。
共饮一杯无
2022/11/28
2.2K0
Java中的BigDecimal比较大于小于等于,四舍五入保留几位(setScale方法详解),加减乘除取余
java保留两位小数
四舍五入   double   f   =   111231.5585;   BigDecimal   b   =   new   BigDecimal(f);   double   f1   =   b.setScale(2,   BigDecimal.ROUND_HALF_UP).doubleValue();   保留两位小数 ---------------------------------------------------------------
bear_fish
2018/09/19
6.5K0
BigDecimal 除法
divide(BigDecimal divisor, int scale, int roundingMode)
全栈程序员站长
2022/07/02
2.5K0
一文带你读懂 BigDecimal 源码
本章带来的是BigDecimal类的源码解读。BigDecimal类是 Java 在 java.math 包中提供的API类,用来对超过16位有效位的数进行精确的运算。除了复杂度设计和拓展性,里面的数学计算思维也很值得我们学习。对于用惯了float/double的同学,得好好仔细看看了。
后台技术汇
2022/05/28
6840
一文带你读懂 BigDecimal 源码
Java中的BigDecimal类和int和Integer总结「建议收藏」
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说Java中的BigDecimal类和int和Integer总结「建议收藏」,希望能够帮助大家进步!!!
Java架构师必看
2022/10/24
1.1K0
bigdecimal保留小数位数_如何保留两位小数
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/09/30
6.4K0
bigdecimal保留小数位数_如何保留两位小数
相关推荐
java 中 BigDecimal 详解「建议收藏」
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档