In this article, I will describe a method to combine Unity’s ragdoll system with STYLY’s Interaction SDK to develop a system for killing enemies using weapons.
You can use humanoid characters/avatars from Unity or similar sources, or you could easily implement them using free assets.
Even beginners can create a simple action or battle game! Let’s take a look at the game-making reference.
We will use the Interaction SDK provided by STYLY. You may want to read through the following manual beforehand for a more detailed explanation.
Sample Scene
Here is a sample scene that describes defeating an enemy using the Interaction SDK with the ragdoll.
Preparing the character
Let’s prepare a character for use in Unity. This time, we will use Mixamo, a 3D character and animation creation tool provided by Adobe.
mixamo : https://www.mixamo.com/#/
If you are new to Mixamo, please refer to this article.
I created a character and a simple animation in Mixamo. In this case, I chose this strong-looking enemy character.
I added an animation to this enemy character. You can choose from a range of animations; this time, I chose [Taunt].
Let’s download the animation in the FBX format and import it into your Unity project.
data:image/s3,"s3://crabby-images/32999/32999707269da0a58be7f798026e98d79b6d1736" alt="img_5f8d147a5ca50 - STYLY Import"
Import
The character assets are FBX data, the character’s name is “Skeletonzombie T Avelange,” and the animation is “Taunt”.
Once the import is complete, adjust the materials and the rig.
With the character’s data selected, select the Materials tab in the Inspector window.
Select the Location item from Use Embedded Materials to Use External Materials (Legacy).
data:image/s3,"s3://crabby-images/5deec/5deec10481f13997a78effe0ffa7ec03ec4f57af" alt="img_5f8d14a8aa389 - STYLY Select Legacy."
Select Legacy.
The appropriate material will now be attached.
data:image/s3,"s3://crabby-images/b2e5a/b2e5a7747950e2ca679d21a5bb66708c00844a0f" alt="img_5f8d14fec858f - STYLY"
Material
Next, let’s adjust the rig. Select the Rig tab in the Inspector window. Under Avatar Type, select Generic as Humanoid.
data:image/s3,"s3://crabby-images/e67ec/e67ec420593f1b5747442ac2a1d66a82991f73b1" alt="img_5f8d2093c4110 - STYLY"
Humanoid
We are now ready to change to the Humanoid type.
Next, let’s prepare the animation. Right-click on the Assets folder in the Project window and select Create > Animator Controller.
data:image/s3,"s3://crabby-images/685d7/685d788ccc531c8eb230816681dce35e6d1be44f" alt="img_5f8d15b301341 - STYLY"
Animator Controller
Let’s name it EnemyAnimator.
data:image/s3,"s3://crabby-images/9c74a/9c74a496173a088e6cda2e4cea54aa5e53b1a6c7" alt="img_5f8d15dad744c - STYLY"
EnemyAnimator
Select the FBX file “skeletonzombie_t_avelange@Taunt” to display the animation file.
data:image/s3,"s3://crabby-images/af90d/af90da0e0a456360d8ac39173d736347e568b2d7" alt="img_5f8d1604d2f5a - STYLY"
Animation
Select the Taunt animation file and copy and paste (or press [CTRL+D]) to duplicate it.
data:image/s3,"s3://crabby-images/8869f/8869f958b1460e3ebbd1923f7648cbb6f06c3f9d" alt="img_5f8d166fc5049 - STYLY Duplicate"
Duplicate
Select the duplicated Taunt animation file and check the “Loop Time” box in the Inspector window.
data:image/s3,"s3://crabby-images/4deb1/4deb1a85b51e13e5763bf5846a47d50f374bb361" alt="img_5f8d19bfd6fbb - STYLY"
Loop Time
Double-click on the EnemyAnimator to display the Animator window.
data:image/s3,"s3://crabby-images/78ed6/78ed69d24dd90baf6466ddf0bedf9cdb788dfc09" alt="img_5f8d16c8d4142 - STYLY Animator Window"
Animator Window
Drag and drop Taunt’s animation file into the Animator window.
Drag and drop the animator file into the “skeletonzombie_t_avelange@Taunt” object in the Hierarchy window.
An animator component will be added to the Inspector window as shown below.
data:image/s3,"s3://crabby-images/d4a3c/d4a3c05e6c6a9002b7acd6dc9302f7f6edf741d4" alt="img_5f8d1a2b4727b - STYLY"
Animator Component
Let’s play it once in this state. The animation will play and loop. The character is now ready to be played.
Preparing the Ragdoll
We now prepare a “Ragdoll” to represent the behavior of a character that has fallen down, just like a person when he or she topples.
A Ragdoll is a way to express behavior using physics operations such as colliders.
To set up the Ragdoll, we will use the Ragdoll Helper from the Unity Assets Store. Ragdoll Helper is a handy asset that converts humanoid avatars into a Ragdoll. Download it from the Assets Store and import it into your project.
data:image/s3,"s3://crabby-images/d1fd5/d1fd5803804548d78db7b9fe40af46df9f6a5626" alt="img_5f8d1ca0a911e - STYLY"
Ragdoll helper
When the import is complete, you will see “Window > BzSoft > Ragdoll Helper” in the top menu bar.
data:image/s3,"s3://crabby-images/5e416/5e4162998c167b69b620c1de90011ecc76d1f974" alt="img_5f8d1cf07af8b - STYLY"
Ragdoll helper
Once the window is open, select the Skeletonzombie object on your scene.
The Ragdoll Helper window should now look like this:
With “Ragdoll” selected at the top of the window, select Create. The Collider will now be attached along the body. It will look like this:
data:image/s3,"s3://crabby-images/50978/5097829122b2c61769c4be5485342cdcc71ce4f6" alt="img_5f8d27fd53817 - STYLY"
Collider
Ragdoll is now ready.
Prepare a ground object so that the character will land on the ground when it falls.
Create a Cube from the Hierarchy window and choose Create > Cube.
Name it “Floor” and transform it as follows:
data:image/s3,"s3://crabby-images/ab422/ab422e825f9290f15edcc0b9d5f26e2a30af8e0f" alt="img_5f8d28a8151b0 - STYLY"
Transform
Let’s also set the Transform of the character’s objects. Do the following:
data:image/s3,"s3://crabby-images/6f599/6f599b0518f313e5cafc952c46949f4eed4d9fbd" alt="img_5f8d29f978717 - STYLY"
Transform
This is how it looks:
data:image/s3,"s3://crabby-images/9b9d9/9b9d92f77642af9de84e31e6de9b0405009b7b24" alt="img_5f91349dc9040 - STYLY Neatly displayed"
Neatly displayed
Finally, we’ll set up a collider to determine if a weapon is a hit.
In addition to the Ragdoll collider, we will add a new Capsule to the scene. Let’s add it in the Hierarchy window by going to Create > Capsule.
Set its name to Collider Object and set its Transform as follows:
data:image/s3,"s3://crabby-images/f9d80/f9d80420781026ae8fd42ece9fe6d5664a963838" alt="img_5f91398ac1117 - STYLY"
Transform
Make the Collider Object a child object of the enemy character.
data:image/s3,"s3://crabby-images/6a3dd/6a3dd91352bf9389c7c48ba99016e3e121437d2c" alt="img_5f913a3970c38 - STYLY Child object"
Child object
We now have the following:
data:image/s3,"s3://crabby-images/04ec6/04ec64469abe90e8268da2102af10169a9fe3ca8" alt="img_5f913a725b08f - STYLY"
Collider Object
Let’s hide the mesh, which will still be visible at this point. Select Collider Object and uncheck the Mesh Renderer in the Inspector window.
data:image/s3,"s3://crabby-images/d966f/d966f1a8c08a0e44b565496a1d5f6b2c70baa7e4" alt="img_5f913ab6c4057 - STYLY"
Mesh Renderer
Now, only Collider will be shown in the scene.
data:image/s3,"s3://crabby-images/091ba/091ba395bebf64ecd2e4da1d75bb8133c02f6c65" alt="img_5f913acfbe733 - STYLY Meshes disappear from the scene."
Meshes disappear from the scene.
Ragdoll preparation is now complete.
Ready for weapons
Next, we need to prepare our weapons. You can prepare a weapon from the asset store, but in this case, it is simplest to prepare a simple stick-shaped weapon via Create > Cube.
Go to Create > Cube and prepare a cube. Name it “Weapon” and Transform it as shown in the image:
data:image/s3,"s3://crabby-images/63702/63702a59346ae5e525bfb79f8430c0008ba57e94" alt="img_5f9135e26c83d - STYLY"
Transform
The image will look like this:
data:image/s3,"s3://crabby-images/47ba7/47ba77342cbb661acf70ad7e9bb706e9f04862f7" alt="img_5f91362bcd595 - STYLY Weapons"
Weapons
Attach a rigidbody from Add Component. Set it up as follows:
data:image/s3,"s3://crabby-images/6ff44/6ff444d2c6c53ce1530b2f1de9e22ff2831ab559" alt="img_5f962da226baa - STYLY"
Rigidbody
All the objects are now ready. In the final step, let’s set up the Interaction SDK.
Setting up the Interaction SDK
I now set up the Interaction SDK.
First, set up the Weapon Interaction SDK. Attach STYLY_Attr_Breaker and STYLY_Attr_Draggable to the Weapon you just created.
STYLY_Attr_Breaker is a script that “destroys the object to which the STYLY_Attr_Breakable component is added”. STYLY_Attr_Draggable is a script that “allows you to grab the object with your pointer”.
You can now grab and move the Weapon object and destroy the STYLY_Attr_Breakable.
Next, we need to disable the animator of the enemy character.
Select the Collider Object and attach STYLY_Attr_Breakable from Add Component to the Interaction SDK.
STYLY_Attr_Breakable is a script that is “destroyed by the object to which the STYLY_Attr_Breaker component is added”. STYLY_Attr_Breaker and STYLY_Attr_Breakable are always used together.
“Breakable” destroys the Collider Object and “On Destroy Event” makes the enemy character’s Animator.enabled false.
Add a List of On Destroy Events.
Add the List by pressing the + button in the bottom right corner.
Drag and drop the skeletonzombie_t_avelange@Taunt object into the None (Object) field.
In the No Function field, choose bool enabled.
data:image/s3,"s3://crabby-images/24c35/24c356ee372d145a0d2c97cdef6560b68908f4d3" alt="img_5f9625ed430fb - STYLY"
bool enabled
Once you have the settings as shown in the image, your task is complete.
data:image/s3,"s3://crabby-images/814a3/814a32e68583a5525788ba6456061b3bfa6020e6" alt="img_5f9627b42e06b - STYLY Completed"
Completed
Play and check
Let’s play the scene in Unity and check it out!
Drag the weapon and try to hit the enemy.
You’ve defeated the enemy! Your job is done.
Upload to STYLY
Upload to STYLY. This time, we’ll upload it in a scene.
If your scene is too large to upload to STYLY, please refer to this article.
Let’s upload the scene you’ve created in your timeline to STYLY.
How to create an account
How to upload a prefab from Unity to STYLY
Learn VR/AR content creation with no prior experience
Learn the basics of Unity and PlayMaker for creating VR/AR content, and learn the process (and creation techniques) of creating attractive content on STYLY. NEWVIEW SCHOOL ONLINE is now open!
- Create VR/AR content without writing any programming code.
- Officially supervised Unity courses available
- Additional elements such as photogrammetric production methods and content lightening
- Learn the concept of creating VR/AR content