官方Github地址:https://github.com/Unity-Technologies/com.unity.cinemachine/tree/main/com.unity.cinemachine
文档在Documentation~文件夹下。
这里主要介绍各个组件的功能,具体参数设置查阅文档即可。
目录
Brain
Camera
CinemachineVirtualCamera
CinemachineFreeLook
CinemachineMixingCamera
CinemachineBlendListCamera
CinemachineExternalCamera
CinemachineClearShot
CinemachineStateDrivenCamera
Body
DoNothing
CinemachineBodyFramingTransposer
CinemachineBodyHardLockTarget
CinemachineBodyOrbitalTransposer
CinemachineBodyTrackedDolly
CinemathinePath
CinemachineSmoothPath
CinemachineBodyTransposer
Aim
CinemachineAimDoNothing
CinemachineAimComposer
CinemachineAimGroupComposer
CinemachineTargetGroup
CinemachineAimHardLook
CinemachineAimPOV
CinemachineAimSameAsFollow
Noise
Extensions
CinemachineCameraOffset
CinemachineCameraCollider
CinemachineCameraConfiner
CinemachineCameraFollowZoom
CinemachineCameraStoryboard
CinemachineCameraExtension
CinemachineCameraImpulse
其他
Brain
CinemachineBrain
一个组件,直接通过AddComponet就能添加。
相机控制中心。当前active的优先级最高的生效,相同优先级则最新active的生效。也就是只要gameObject.SetActive(true),就会自动切换到当前相机。
Camera
都是组件,直接通过AddComponet就能添加。
相机的layer如果和Brain的layer相同,就会加入Brain的控制。不然相机怎么整都不会生效的。
CinemachineVirtualCamera
非常基础的虚拟相机。通过设置Body和Aim的组件来实现复杂的功能。
轨道相机:自动将Body设置为TrackedDolly,自动创建一条轨道,将轨道设置到TrackedDolly。
2D相机:自动将Body设置为FramingTransposer。
CinemachineFreeLook
围绕一个点自由观察相机。在三个圈组成的一个球体上运动。水平方向0~360度,竖直方向0~1。
可以自动接收XAxis和YAxis的输入转动相机。
通过代码修改XAxis和YAxis值就可以让相机动起来。
如果要实现拉近拉远的效果,同时缩放三个圈就可以。
可以单独设置上中下三个圈对应的看点。
当三个圈的半径一样时,就变成了一个柱子,设置三个圈对应的看点分别指向三个圈的中心,相机就会直视着上下移动,不会变化视角了。
代码访问:
freeLookCam.m_XAxis = t; //X轴值
freeLookCam.m_YAxis = t; //y轴值
freeLookCam.m_Orbits[1] = t; //上圈
freeLookCam.m_Orbits[2] = t; //中圈
freeLookCam.m_Orbits[3] = t; //底圈
CinemachineMixingCamera
对子CineMachineVirtualCamera进行混合。对所有相机同时进行插值,得到当前相机的显示参数。比如同时将所有相机的权重从0渐变到1,可以看到相机按贝塞尔曲线移动。
可以设置一系列的相机,然后通过差值,让相机运动、变化视角等等。比如围绕角色进行特写。如果用轨道实现的话,相机的参数不能这么自由定义,比如视角,通过Aim组件设置后它会看下一个点,不能这么自由定义。可惜最多支持8个相机,多了差值计算还是比较费的。
CinemachineBlendListCamera
列表融合相机。依次对列表中两个相邻的相机进行线性插值,得到当前相机的显示参数。
和Mixing不同的是,这个是对相邻两个插值,Mixing是同时对所有相机插值。
运行可以看到相机自动从1运动到2,然后从2运动到3,视角也会平滑的变动。
CinemachineExternalCamera
被弃用了。对一个Unity相机添加该组件,Cinemachine将把Camera作为VirtualCamera使用。就是一个没有设置Body和Aim的VirtualCamera。
CinemachineClearShot
在多个子相机中间,选择视野最好的那一个相机。也就是相机和看点直接障碍物最少的那个。
当将球放到1和立方体之间时,会自动切换到2号相机。
CinemachineStateDrivenCamera
根据Animator的状态切换相机
Body
相机移动行为。相机的Body设置中选择。
DoNothing
就是什么也不做
CinemachineBodyFramingTransposer
画面变换器。让跟随对象保持在屏幕空间的一个点上。只会改变相机的坐标,不会旋转和改视角。看到的效果就是画面在x/y方向移动。如果透视,画面也会拉远。
处理算法是:先沿Z轴移动,使相机xy平面到跟随点的距离是指定距离。然后再xy平面上移动,使相机在屏幕空间指定的点上。
为2D和正交相机设计,但是也可以用于透视相机和3D环境。
默认相机是正对着跟随点中心的,可以修改ScreenX和ScreenY让跟随点偏离中心,修改后相机的x/y坐标会发生变化。
如图所示,修改了ScreenX和ScreenY后,画面进行了偏移,相机了x坐标变化了。
注意它和AimComposer不同,它是改位置实现,AimComposer是改朝向实现。
CinemachineBodyHardLockTarget
死死的跟随跟随目标。
CinemachineBodyOrbitalTransposer
轨道变换器。在一条圆形轨道上变换相机位置。
通过XAxis输入,调整在轨道上的位置(0~360度)。
CinemachineBodyTrackedDolly
轨道摄影车。需要指定一个轨道,通过需改PathPosition的值,相机就会在轨道上移动。
路径有两种:Path和SmooPath。
创建一个gameObject,然后添加路径组件,设置参数调整曲线,然后拖给TrackedDolly就行。
CinemathinePath
是贝塞尔曲线。每个路径点都带有一个切线点,可以调整弯曲度。
Tip: Choose your path shapes with care when using Auto-Dolly mode. This becomes problematic on paths that form an arc around some point. As an extreme example, consider a perfectly circular path with the Follow target at the center. The closest point on the path becomes unstable because all points on the circular path are equally close to the target. In this situation, moving the Follow target small distances can cause the camera to move large distances on the track.
大概就是这个曲线可能产生不连续性震动,但是又不好调节,出现这种情况可以用SmoothPath。
CinemachineSmoothPath
是一条穿过多个点的平滑曲线,算法大家可以搜索到。虽然它多了个Smooth单词,但是设置更加简单。
CinemachineBodyTransposer
指定相对于跟随目标的位置。
Aim
相机的瞄准方式。在虚拟相机的Aim设置中选择。
CinemachineAimDoNothing
啥也不做
CinemachineAimComposer
创作者。让相机朝向看的目标。可以调整目标在屏幕上的位置(构图),相机跟随目标的偏移、阻尼(目标移动不是立刻跟上,而是有一个过渡效果)
CinemachineAimGroupComposer
通过调整FOV或者相机到目标的距离,使目标组保持在屏幕内。
这个过程被称作为Framing(构图)。
例如,如果目标组超出了屏幕,就放大FOV,或者拉远相机,让目标组回到屏幕中。
参数和普通的Composer基本一样,就是多了一些构图的设置参数。
CinemachineTargetGroup
将一堆目标作为一个组。会根据规则计算出目标组的位置,并设置在transform上。所以目标不能是它的子节点,否则坐标会一直变。
CinemachineAimHardLook
死死盯住看的目标。
按路径移动的同时变换相机朝向:相机按轨道移动的同时,让相机看向的目标跟着另一条轨道移动(CinemachineDollyCart)
CinemachineAimPOV
通过XAxis和YAxis输入,控制相机的X转向和Y转向
CinemachineAimSameAsFollow
让虚拟相机的朝向和跟随的目标朝向一样。
Noise
抖动。
目前只有Basic Multi Channel Perlin这个抖动组件。添加组件后选择一个配置文件就可以了。
可以通过Create > Cinemachine > NoiseSettings创建一个配置文件。会自动将新配置文件加入选择列表。
Extensions
CinemachineCameraOffset
增加一个xyz的偏移
CinemachineCameraCollider
是球形的。当物体撞上时,相机会自动避开。
如图所示,球体撞上碰撞体后,碰撞题会移动避开。
CinemachineCameraConfiner
将相机限制在Collier的区域里,出不去。可以选择是2DCollider还是3DCollider
CinemachineCameraFollowZoom
通过调整FOV让物体在屏幕上看起来是固定大小。
CinemachineCameraStoryboard
在屏幕上显示一张Texture。
CinemachineCameraExtension
用来写代码自定义扩展的
CinemachineCameraImpulse
接收脉冲信号。
默认信号就是一个x/y/z坐标的动画(FixedSingle)。可以可以通过代码自定义。
project的create菜单,即可创建。
创建了信号之后,需要再创建一个信号源发出信号。把创建的信号asset拖到信号源上。信号可以通过代码发出,也可以通过碰撞自动发出。通过AddComponet添加Cinemachine Collision Impulse Source或Cinemachine Impulse Source即可。
本质上就是一个发出事件,然后接收事件的机制。通过这个就可以很容易的实现技能释放后震屏的效果。
其他
Cinemachine Collision Impulse Source
在碰撞时自动发出脉冲信号的信号源
Cinemachine Dolly Cart
让对象在path上运动。
Cinemachine Impulse Source
通过代码发出脉冲信号的信号源
相机抖动:注册CinemachineCore.CameraUpdatedEven,在这个update中进行控制
重载输入获取方法:CinemachineCore.GetInputAxis