- 用户指南
- Components
- 寻路
- 动画组件
- 资源组件
- 音频组件(AudioComponent)
- 音频侦听器(AudioListener)
- 音频源(AudioSource)
- 音频过滤器(AudioFilter)(仅限专业版)
- 混响区域(ReverbZone)
- 麦克风(Microphone)
- 物理组件(PhysicsComponent)
- 箱体碰撞体(BoxCollider)
- 胶囊碰撞体(CapsuleCollider)
- 角色控制器(CharacterController)
- 角色关节(CharacterJoint)
- 可配置关节(ConfigurableJoint)
- 恒定力(ConstantForce)
- 固定关节(FixedJoint)
- 铰链关节(HingeJoint)
- 网格碰撞体(MeshCollider)
- 物理材质(PhysicsMaterial)
- 刚体(Rigidbody)
- (SphereCollider)
- 弹簧关节(SpringJoint)
- 交互布(InteractiveCloth)
- 蒙皮布(SkinnedCloth)
- 车轮碰撞体(WheelCollider)
- 游戏对象(GameObject)
- 图像效果(ImageEffectScripts)
- 高光溢出和镜头光晕(BloomandLensFlare)
- 模糊(Blur)
- 相机运动模糊(MotionBlur)
- 颜色修正曲线(ColorCorrectionCurve)
- 颜色修正(ColorCorrection)
- 颜色修正查找纹理(ColorCorrectionLookupTexture)
- 对比度增强(ContrastEnhance)
- 对比度拉伸(ContrastStretch)
- 起皱(Crease)
- 视野深度(DepthofField)3.4
- 视野深度(DepthofField)
- 边缘检测(EdgeDetection)
- 鱼眼(Fisheye)
- 全局雾(GlobalFog)
- 发光(Glow)
- 灰度(Grayscale)
- 运动模糊(MotionBlur)
- 噪波和颗粒(NoiseAndGrain)
- 噪波(Noise)
- 屏幕叠加(ScreenOverlay)
- 棕褐色调(SepiaTone)
- 边缘检测效应
- 阳光照射(SunShaft)
- 屏幕空间环境光遮蔽(SSAO)(ScreenSpaceAmbientOcclusion(SSAO))
- 倾斜位移(TiltShift)
- 色调映射(Tonemapping)
- 旋转(Twirl)
- 渐晕(Vignetting)(和色差(ChromaticAberration))
- 状态同步详细信息
- 旋涡
- 设置管理器(SettingsManager)
- 网格组件(MeshComponents)
- 网络组
- 效果
- 渲染组件
- 变换组件(TransformComponent)
- UnityGUI组
- 向导
- 地形引擎指南(TerrainEngineGuide)
- 树木创建器指南
- 动画视图指南
- GUI脚本指南
- 网络参考指南
- 移动设备上的网络连接
- 高级网络概念
- Unity中的网络元素
- RPC详细信息
- NetworkLevelLoading
- 主服务器
- 最小化网络带宽
- 社交API
- 内置着色器指南
- Unity的后台渲染
- 着色器参考
- ShaderLab语法:Shader
- ShaderLab语法:Properties
- ShaderLab语法:子着色器(SubShader)
- ShaderLab语法:Pass
- ShaderLabsyntax:Color,Material,Lighting
- ShaderLab语法:剔除和深度测试(Culling&DepthTesting)
- ShaderLab语法:纹理组合器(TextureCombiners)
- ShaderLab语法:雾(Fog)
- ShaderLab语法:Alpha测试(Alphatesting)
- ShaderLab语法:混合(Blending)
- ShaderLab语法:通道标记(PassTags)
- ShaderLab语法:名称(Name)
- ShaderLab语法:绑定通道(BindChannels)
- ShaderLab语法:使用通道(UsePass)
- ShaderLab语法:GrabPass
- ShaderLab语法:子着色器标记(SubShaderTags)
- ShaderLab语法:回退(Fallback)
- ShaderLab语法:自定义编辑器(CustomEditor)
- ShaderLab语法:其他命令
- ShaderLab语法:Pass
- 高级ShaderLab主题
- ShaderLab内置值
- 其他
- 网络视图
- 导航网格 (Navmesh) 和寻路 (Pathfinding)(仅限专业版 (Pro))
- Mecanim 动画系统
- 动画状态机
- 混合树 (Blend Tree)
- 在 Mecanim 中使用动画曲线 (Animation Curves)(仅限专业版 (Pro))
- 循环动画片段
- Animation State Machine Preview (solo and mute)
- 动画参数
- 旧动画系统
- 使用类人动画
- 动画层
- 资源导入与创建
- 音轨模块
- 减少文件大小
- 光照贴图 UV
- 资源准备和导入
- 如何安装或升级标准资源 (Standard Assets)?
- FBX 导出指南
- 从 Maya 中导入对象
- 从 Cinema 4D 中导入对象
- 从 3D Studio Max 中导入对象
- 从 Cheetah3D 中导入对象
- 从 Modo 中导入对象
- 从 Lightwave 中导入对象
- 从 Blender 中导入对象
- 为优化性能建模角色
- 如何使用法线贴图 (NormalMaps)?
- 如何修正已导入模型的旋转?
- 程序材质
- 如何使用水?
- 分析器(仅限专业版)
- 绘制调用批处理
- 遮挡剔除(仅限专业版)
- Unity 中的高动态范围 (High Dynamic Range) 渲染
- 在 Unity 4 中使用 DirectX 11
- 文本场景文件格式(仅限专业版)
- 使用网络播放器模版
- 平台依赖编译
- 日志文件
- 首选项
- 粒子系统曲线编辑器
- 渐变编辑器
- 怎样制作网格粒子发射器?(旧粒子系统)
- 深入了解光照贴图
- 光照贴图快速入门
- 着色器
- 动画脚本(旧版)
- 自定义
- 布局模式
- 扩展编辑器
- 网络实例化
- 材质和着色器
- 如何使用细节纹理?
- 着色器:顶点和片段程序
- Unity 中的阴影
时间管理器(TimeManager)
时间管理器 (Time Manager)
属性
属性: | 功能: |
---|---|
固定时间步长 (Fixed Timestep) | 独立于帧速率的时间间隔,用来命令何时执行物理计算和FixedUpdate() 事件。 |
允许的最大时间步长 (Maximum Allowed Timestep) | 独立于帧速率的时间间隔,当帧速率低时,它会覆盖最坏的案例场景。执行物理计算和(FixedUpdate()) 事件的时间不会超过规定的时间。 |
时间尺度 (Time Scale) | 时间前进的速度。更改此值以模拟子弹时间特效。1 表示实时时间。.5 表示速度减半;2 表示速度加倍。 |
详细信息
固定时间步长 (Fixed Timestep)
对于稳定的物理模拟来说,固定时间步长 (Fixed time stepping) 非常重要。计算机不尽相同,不同的硬件配置在运行 Unity 游戏时表现出来的性能也不同。因此,物理计算必须独立于游戏的帧速率进行。诸如碰撞检测和刚体 (Rigidbody) 移动这样的物理计算是在独立于帧速率的离散固定时间步长中进行。这使不同电脑间或帧速率发生变化时模拟的一致性更强。例如,帧速率可能会由于屏幕上多个游戏同时进行或用户在后台执行另一应用程序而降低。
以下是固定时间步长的计算方法。在屏幕上绘制帧之前,Unity 将固定时间提前一段固定增量时间,并在到达当前时间之前执行物理计算。这直接与固定时间步长 (Fixed Timestep) 属性相关联。固定时间步长 (Fixed Timestep)的值越小,进行物理计算的频率越高。每秒的固定帧数的计算方法是,用 1 除以固定时间步长 (Fixed Timestep)。因此,1/0.02 = 50(帧每秒) 以及 1/0.05 = 20(帧每秒)。
简而言之,固定更新值越小,物理模拟越精确,但是 CPU 的负担也会更大。
允许的最大时间步长 (Maximum Allowed Timestep)
固定时间步长是稳定的物理模拟的保证。然而,如果游戏对物理负担大并且已经运行缓慢或偶尔会降至低帧速率,那么固定时间步长也可能对性能带来负面影响。帧所用时间越长 - 就必须执行更大的固定更新步长以转到下一个帧。这会导致性能下降。为避免这种场景的出现,Unity iOS 引入了允许的最大时间步长 (Maximum Allowed Timestep),以确保物理计算的运行时间不会超出规定的阈值。
如果帧所用时间超过允许的最大时间步长 (Maximum Allowed Timestep) 中规定的时间,那么物理会“假设”帧仅用了允许的允许的最大时间步长 (Maximum Allowed Timestep) 秒数。换句话说,如果帧速率降低到某个阈值以下,那么刚体的速度就会变慢一点,以便让 CPU 可以赶上。
允许的最大时间步长 (Maximum Allowed Timestep) 对物理计算和 FixedUpdate() 事件都会造成影响。
允许的最大时间步长 (Maximum Allowed Timestep) 和 固定时间步长 (Fixed Timestep) 时,都以秒为单位。因此,如果帧速率降低到 1/0.1 = 10 (帧每秒)以下,那么设置 0.1 就会使物理和 FixedUpdate() 事件速度降低。
典型场景
- 假设 固定时间步长 (Fixed Timestep) 是 0.01,也就是说应该每 10 毫秒处理一次 physX、固定更新 (fixedUpdate) 和动画。
- 当您的帧时间大约是 ~33每个视觉帧平均要执行 3 次固定循环。
- 但是,帧时间不是固定不变的,它取决于许多因素,包括您的场景状态、OS 后台任务等。
- 由于 3. 的原因,帧时间有时会达到 40 - 50 毫秒,也就是说会执行 4 - 5 次固定步长循环。
- 当您的固定时间步长任务相当繁重时,physX、固定更新 (fixedUpdate) 和动画花费的时间会将帧时间延长 10 毫秒,也就是说为所有这些固定时间步长任务增加了一次迭代。
- 在一些不幸的情况下,5. 中描述的过程时间会延长至处理固定步长循环所用时间的 10 倍及其以上。
- 这就是引入允许的最大时间步长 (Maximum Allowed Timestep)的原因。它是在单个视觉帧期间限制 physX、固定更新 (fixedUpdate) 和动画处理次数的方法。如果将允许的最大时间步长 (Maximum Allowed Timestep) 设为 100 毫秒,并固定时间步长 (Fixed Timestep) 设为 10 毫秒,那么在每个视觉帧会最多执行 10 次固定步长任务。因此,随着固定时间步长迭代次数的增加,小的性能故障有时会引发大的性能故障。通过将允许的允许的最大时间步长 (Maximum Allowed Timestep) 降到 30 毫秒,可将最大固定步长迭代次数限制到 3,这就是说您的 physX、固定更新 (fixedUpdate) 和动画不会将帧时间延长太多,但这种限制也有一些负面作用。您的动画和物理在性能故障发生时会变慢。
提示
- 使玩家可以通过编写脚本,动态地更改时间尺度 (Time Scale) 来控制时间。
- 如果您的游戏物理负担重或在FixedUpdate()事件中花费大量时间,那么请将允许的最大时间步长 (Maximum Allowed Timestep) 设为 0.1。这会防止物理以低于 10 帧每秒的速率驱动游戏。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论