Skip to content

Latest commit

 

History

History
73 lines (60 loc) · 4 KB

README.md

File metadata and controls

73 lines (60 loc) · 4 KB

KeypadSystem

A simple keypad system I made for Unity. I built the system for multiple types of usages.
This system can be used pretty easily with these type of games:

  • FPS type game.
  • Mouse click type game

Note: It's far from perfect but I usually build smaller features which I can then integrate into another project and improve upon them then.

The Inspector UI (RaycastSystem is for FPS only)

How to setup the Keypad

You add the script Keypad to an object (Interactions are done with the collider component).

States

states will cover two bool states.

  • Keycode Solved: This is the state if the code has been accepted or the door is open.
  • Permanently Locked: This is the state if the code has been denied or the tries has exceeded max.

Keypad Setup

This is where you set up the type of use, keycode etc

  • Activate By Mouseclick: This is the option to set true if you are building a mouse click game. Simply using the OnMouseClickEvent.
  • Keycode: The keycode for the door. It takes an Integer value.
  • Auto Complete: This is the feature to set true if you want the keypad to automatically accept if the code is correct.

Keypad Extra

Keypad Extra contains the features to limit the tries on the keypad.

  • Limit Tries: This feature should be set to true if you want to limit the users inputs and lock the keypad.
  • Tries Amount: This takes an Integer of how many tries the user can input before it locks itself.

Methods to run

Methods to run is exactly what It sounds like. The setups for these are exactly like setting up the UI events for example, buttons.

  • Access Granted: This method will be activated once the correct keycode has been entered. This method is also ends by invoking Return Control method.
  • Access Denied: This method will be activated once the incorect keycode has been entered above the limited amount. This method is also ends by invoking Return Control method.
  • Return Control: This method acts more like a free method. I, for example, used it to return control to the player once the keypad was closed. I modified the old FirstPersonController in my demoscene and made two methods. One for disabling the controller and I needed the controller to be turned back on AFTER the keypad had been closed.

What code did I have to write to get this demo scene working?

I made 1 script (KeypadExtra.cs) outside of this system and modified the Standard Assets FirstPersonController. KeypadExtra.cs contains 4 public void methods and 4 [SerializeField] fields.

  • The method "OpenDoor" contains the door animation, sound effect and the light indicator. (Just for show) (Set in Keypad)
  • The method "DisableControl" enables the mouse cursor and disables the FirstPersonController component. (Set in RaycastSystem)
  • The method "EnableControl" disables the mouse cursor and enables the FirstPersonController component. (Set in RaycastSystem)
  • The method "DeniedAccess" does only one thing in this case. It turns the red light indicator ON. (Set in Keypad)

I then set these methods by draging the parent object to the method and set it up in the inspector. No need to write a lot of code.

KeypadExtra.cs Source

public class KeypadExtra : MonoBehaviour {
    [SerializeField] GameObject door;
    [SerializeField] FirstPersonController character;
    [SerializeField] Light deniedIndicator;
    [SerializeField] Light accessGrantedIndicator;

    public void OpenDoor() {
        door.GetComponent<Animator>().enabled = true;
        door.GetComponent<AudioSource>().Play();
        accessGrantedIndicator.enabled = true;
    }

    public void DisableControl() {
        character.m_MouseLook.SetCursorLock(false);
        character.enabled = false;
    }

    public void EnableControl() {
        character.m_MouseLook.SetCursorLock(true);
        character.enabled = true;
    }

    public void DeniedAccess() => deniedIndicator.enabled = true;
}