Skip to content

Latest commit

 

History

History
55 lines (28 loc) · 4.91 KB

README.md

File metadata and controls

55 lines (28 loc) · 4.91 KB

CharacterController2D

CharacterController2D is similar to the built-in Unity CharacterController component. It has a similar API (mainly a move method that takes a delta movement) and is a really good base to make a super solid controller using Unity's new 2D goodies.

Two simple demo scenes (one with non-physics based movement and one physics based movement) are included along with a few Spelunky sprites (which obviously should not be used in your game!). An overview video showing how to get started is available on the prime31studios YouTube channel here.

A Word about Physics Based Movement

It is important to note that with regard to the CharacterController2D when the term "physics based movement" is used it does not mean that forces are used to move the player. CharacterController2D is made for cases where you need precision and full control so forces are never used to move the Transform. When the term "physics based movement" is used here it just means that the RigidBody2D's MovePosition method is used to move the Transform. For the CharacterController2D's non physics based movement Transform.Translate is used. In both cases (physics based and non physics based) all movement distance calculations are still made manually by the CharacterController2D.

Demo Scenes

The included demo scenes are minimal to keep things as simple as possible. It has very basic input detection (using the arrow keys to move and jump) and a simple character sprite/Animator setup. This should be simple enough for anyone with a rudimentry knowledge of Unity to read through and understand.

One demo scene (Non-Physics-Based folder) does not use the physics system for movement at all. It handles all movement via Transform.Translate. The other demo scene (Physics-Based folder) does use the physics system to handle movement.

Basic Setup

Setup is pretty simple: drag the CharacterController2D onto your player/enemy GameObject and set the platformMask in the inspector to contain any layers that you want the player to collide with. If you will be using one way platforms, you can set the oneWayPlatformMask as well. Note that one way platforms should be EdgeCollider2Ds. ProTip: make sure your player is on a separate layer than your platforms so that she doesn't try to collide with herself! You will also want to make sure you BoxCollider2D is centered and has a zero horizontal offset. Flipping requires setting the scale.x to -1 so a horizontal offset other than zero will result in the collider jumping around.

From there you can tweak the totalHorizontalRays and totalVerticalRays to your liking. When in the editor rays will be drawn with Debug.DrawRay so that you can make sure the ray resolution is appropriate for your smallest platform size. To turn off ray debugging just comment out the #define DEBUG_CC2D_RAYS line at the top of the CharacterController2D.cs file.

To move the player around just call move and provide it a delta movement (the physical distance the player should move this frame). You can subscribe to the onControllerCollidedEvent to be notified of all collisions if you need them.

In order to be able to receive trigger events (onTriggerEnter/Stay/Exit) the CharacterController2D needs to do some extra setup. If you set createTriggerHelperGameObject to true in Awake the CharacterController2D will create an additional GameObject that will be attached via a joint and it will receive the Unity trigger messages and transform them into events. If you would like you can also create the trigger helper yourself via the createTriggerHelper method.

Special Notes for the Magical Versions of Unity that have Rigidbody2D.MovePosition

If the version of Unity you are using has the Rigidbody2D.MovePosition method and you set usePhysicsForMovement to true some special consideration need to be made:

  • you do not need to use the trigger helper so make sure createTriggerHelperGameObject is set to false. Trigger will work fine when usePhysicsForMovement is true
  • the RigidBody2D on the CharacterController2D should be kinematic
  • the RigidBody2D on the CharacterController2D should have Interpolate set to None or Extrapolate
  • all the usual Unity rules for physics-based movement will also apply: you should only move the CharacterController2D in FixedUpdate, dont gather input in FixedUpdate, etc
  • you may want to experiment with the TimeManager's Fixed Timestep value to get better results

License

Attribution-NonCommercial-ShareAlike 3.0 Unported with simple explanation. You are free to use the CharacterController2D in any and all games that you make. You cannot sell the CharacterController2D directly or as part of a larger game asset.