Skip Cutscenes Button

Here’s my simple tutorial about how to create a “Skip Cutscenes button” in Unity (the logic applies to any other engine too). You can find below the code and the download links.
Download
You can download the free UI “Prompts Pack” clicking here, created by @Xelu.
Code
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.Assertions;
public class HandlerScript : MonoBehaviour
{
//The circle that shows us the overall progress
public Image fillImage;
//Holder of the entire button, used to change its scale
public RectTransform holderRect;
//Start scale of the holder
Vector2 startHolderScale;
//The desired scale we want when we complete the input, i.e. the input percentage is 1
public Vector2 targetHoldercale = new Vector2(1.2f, 1.2f);
private void Awake()
{
//Assures we don't have null references
Assert.IsNotNull(fillImage);
Assert.IsNotNull(holderRect);
startHolderScale = holderRect.localScale;
fillImage.fillAmount=0;
}
//The key we want to press
public KeyCode keyCode = KeyCode.X;
//Speed that increases the progress if we press
public float activeSpeed = .5f;
//How fast the progress decreases if we don't press the desired key
float cooldownSpeed = .6f;
//Prevents the function to be executed more than once
bool functionTriggered = false;
void Update()
{
//Increases or decreases our progress based on our input (and if we didn't already trigger the function)
//No need to clamp, since fillAmount is already clamped by Unity in the [0,1] range
fillImage.fillAmount +=
((Input.GetKey(keyCode) && !functionTriggered) ?
activeSpeed :
-cooldownSpeed) * Time.deltaTime;
//Changes the size of the button based on our progress
holderRect.localScale = Vector2.Lerp(
startHolderScale,
targetHoldercale,
fillImage.fillAmount * fillImage.fillAmount //you can apply an interpolation there, I applied EaseIn
);
//Triggers the function if we didn't already, and the progress/percentage is 1
if (!functionTriggered && fillImage.fillAmount == 1)
{
functionTriggered = true;
Debug.Log("Button pressed completely");
//Do something here
//Skip cutscene or similar
//[...]
}
}
}
Thanks for reading! ❤️
Let us know what you think! We're a small team and we are loving what we do, so any feedback is appreciated ❤️ You can also consider joining the newsletter (either weekly or monthly, we care deeply about it) and never miss our new posts. Cheers!
✦ Join the newsletterMore Posts
How to make a Triplanar Shader in Godot
We made a simple terrain shader for Godot, which lets you apply different textures on based slopes and more. Have fun!
Text Animator for Godot is Out in Early Access!
Text Animator for Godot is out now in Early Access! Start bringing your texts to life in a few clicks and help us shape the future of this tool in Godot! Cheers!
Text Animator is coming to Godot, Unity and Unreal.. with a fresh new look!
Text Animator is coming to Godot, Unreal and Unity UI Toolkit with a fresh new look! Read more.
I'll be doing a workshop at DevGAMM Lisbon this year!
I'll be doing a workshop at DevGAMM Lisbon this year! Designing tools from start to finish and prototyping with Godot, docs and much more. Looking forward to it!
Creating custom inspectors in Godot C# more easily
Creating custom inspectors in Godot can become a bit tedious in C#, so we have built a custom and free addon that handles this for you!
LinkedIn will use your data to train thier AI
Starting November 3rd, 2025, LinkedIn will start using your data to train their AI. Ughh.
Comments