Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/andreasbaumde/unitycinematiccontrol

UnityCinematicControl is a versatile Unity camera control script, enabling dynamic and cinematic camera movements with ease. Ideal for crafting compelling game trailers and cutscenes, it provides developers with intuitive tools for enhancing visual storytelling in their games.
https://github.com/andreasbaumde/unitycinematiccontrol

unity unity-3d unity-camera unity3d unity3d-script

Last synced: 4 months ago
JSON representation

UnityCinematicControl is a versatile Unity camera control script, enabling dynamic and cinematic camera movements with ease. Ideal for crafting compelling game trailers and cutscenes, it provides developers with intuitive tools for enhancing visual storytelling in their games.

Awesome Lists containing this project

README

        

![Unity Cinematic Control](https://raw.githubusercontent.com/andreasbaumde/UnityCinematicControl/main/Assets/github-image.jpg)

# UnityCinematicControl

UnityCinematicControl is a versatile Unity camera control script, enabling dynamic and cinematic camera movements with ease. Ideal for crafting compelling game trailers and cutscenes, it provides developers with intuitive tools for enhancing visual storytelling in their games.

[Watch example footage (Vimeo)](https://vimeo.com/886964692)

## Features

- **Real-Time Speed Controls**: Adjust movement and rotation speeds in real-time.
- **Fly-To Function**: Instantly move to a specific point in your scene with the press of a button.
- **Real-Time FOV Controls**: Dynamically change the field of view, perfect for creating dolly zoom effects.
- **Gamepad Input Compatibility**: Every setting and function is accessible via gamepad inputs.
- **Easing Toggle and Adjustment**: Customize the easing times and toggle easing on or off.
- **Live Camera UI**: A compact UI that displays all relevant settings and information.
- **Toggleable UI Elements**: Includes a toggleable info UI and crosshair.
- **Y-Axis Movement Restriction**: Option to restrict movement along the y-axis.
- **New Input System Utilization**: Built to work with Unity's New Input System.
- **Camera Speed Modes**: Different speed modes available using modifier inputs (trigger buttons).

[Feature video (Vimeo)](https://vimeo.com/886964462)

## Requirements

- A **gamepad** is required (mouse & keyboard currently not supported). Feel free to modify the script to add this support.
- Your project must have the **New Input System** package imported and activated.

## Installation

1. Download [UnityCinematicControl.unitypackage](https://github.com/andreasbaumde/UnityCinematicControl/raw/main/UnityCinematicControl.unitypackage)
2. Ensure you have a camera in your scene tagged as `MainCamera`.
3. Add the `CameraController` component to this game object.
4. Adjust the LayerMask field to mark the layers the fly-to function can fly to.
5. Drag the canvas prefab into your scene to use the camera UI.
6. Ensure you have TextMesh Pro in your project for the UI text elements.
7. Include the sprite for the crosshair in your project.

## Keybinds

- **Movement**: Use the left stick to move at normal speed.
- **Fly-To**: Press the left stick to activate the fly-to function.
- **Camera Rotation**: Use the right stick to look around/change camera rotation.
- **Toggle Easing**: Press the right stick to toggle easing.
- **Vertical Movement**: Use `A` to move up and `B` to move down.
- **Field of View (FOV)**: `X` to increase and `Y` to decrease FOV.
- **Speed Modifiers**: Use `LT` + left stick for slow speed (0.5x), `RT` + left stick for fast speed (2.5x).
- **Speed Adjustments**: `LB`/`RB` to decrease/increase movement speed.
- **Vertical Speed Adjustment**: `D-pad Up` + `LB`/`RB` to adjust vertical movement speed.
- **Rotation Speed Adjustment**: `D-pad Right` + `LB`/`RB` to adjust rotation speed.
- **Easing Time Adjustment**: `D-pad Down` + `LB`/`RB` to adjust easing time.
- **FOV Change Rate**: `D-pad Left` + `LB`/`RB` to adjust the rate of FOV change.
- **Y-Axis Movement Toggle**: Double-tap `D-pad Right` to toggle y-axis movement restriction.
- **UI Visibility**: Press `Select` to toggle UI visibility.
- **Reset FOV**: Press `Start` to reset FOV to its initial value.

## Contributing

Feel free to fork, modify, and send pull requests to improve this tool. Your contributions are greatly appreciated!

---

Happy game developing!