Skip to content

Commit

Permalink
Update docs to reflect new death types and section standards
Browse files Browse the repository at this point in the history
  • Loading branch information
NobleDraconian committed Mar 15, 2024
1 parent 7f644a4 commit a90bb71
Show file tree
Hide file tree
Showing 6 changed files with 105 additions and 66 deletions.
Binary file modified docs/Assets/ObstacleExamples/ExampleLava.rbxm
Binary file not shown.
Binary file modified docs/Assets/ObstacleExamples/ExampleProjectiles.rbxm
Binary file not shown.
Binary file modified docs/Assets/SST_SectionCreatorKit.rbxm
Binary file not shown.
29 changes: 24 additions & 5 deletions docs/Obstacle Documentation/DamageParts.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,32 @@
title: Damage Parts
---

Damage parts are a normal [BasePart](https://create.roblox.com/docs/reference/engine/classes/BasePart) that deals damage to a player if their hitbox comes into contact with it.
Damage parts are a normal [BasePart](https://create.roblox.com/docs/reference/engine/classes/BasePart) that deals damage to a player if their hitbox comes into contact with it. If the damage part has the tag `Hurt`, it will deal 1 heart of damage to the player. If the damage part has the tag `Kill`, it will instantly kill the player.

Additionally, a special string attribute named `KillType` can be applied to the damage part, which will trigger its corresponding hurt / death effect when the player touches it. If this attribute is not present, standard death & hurt animations will be ran instead.

The following damage types are available for `Hurt` parts:

- `Frozen` : The player's avatar will be bounced up a bit while slowly flailing its arms and legs from the cold.
- `Lava` : The player's avatar will be bounced up a bit while quickly flailing its arms and legs from the burn.

The following damage types are available for `Kill` parts:

- `Eaten` : The player's avatar will flail around a bit as it moves down into whatever is swallowing it, then ragdoll
- `Electrocuted` : The player's avatar will rapidly seize in-place as its skeleton flashes visible, then ragdoll
- `Falling` : The player's avatar will enter an uncontrolled fall animation. If the player hits the ground before a respawn is initiated, certain accessories such as shoes will fly off of the avatar and bounce up to the camera while the avatar faceplants.
- `Frozen` : The player's avatar will become encased in a cube of ice that will float to the surface of the damage part, and it will bob there until a respawn is initiated.
- `Portfish` : A giant portfish will jump out of the surface of the damage part and swallow the player. The portfish will then swim back to underneath the surface.
- `Squished` : The player's avatar will be flattened while a "SQUARSH!" sound plays. The avatar will then ragdoll.
- `WaterDrown` : The player's avatar will grab its neck and struggle for breathable air. The avatar will then go limp forward while floating in place.
- `Lava` : The player's avatar will be lit on fire as it quickly flails its arms and legs from the burn. The avatar is bounced upwards, and will then fall downwards, noclipping through anything in its path.
- `Poison` : The player's avatar will either immediately go limp, or it will flail around struggling to stay above the surface only to go limp after. The avatar will then slowly sink beneath the surface.

**Requirements**

- The damage part must have a tag of "DamagePart"
- The damage part must not have any textures applied to it, the animated damage textures will be added at runtime by the game
- The damage part must have a transparency of 0
- The damage part must have a material of `Neon`
- The damage part must have a tag of `Hurt` or `Kill`
- The damage part must not have any textures applied to it, the animated damage textures will be added at runtime by the game if applicable.
- The damage part must have a transparency of 0 if it has the tag `Hurt`.
- The damage part must have a material of `Neon` if it has the tag `Hurt`.

**Example** : [ExampleLava.rbxm](../Assets/ObstacleExamples/ExampleLava.rbxm)
80 changes: 80 additions & 0 deletions docs/Section Documentation/Difficulty.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
---
title: Section difficulty
---

!!! Note
We are only accepting `Easy` sections at this time!

Different section difficulties have different standards. These standards are how we quantify what the difficulty of a section is. The standards apply in a top-down fashion, from harder difficulty to easier difficulty. For example, if hard sections have a standard saying "conveyors cannot have a speed value above 40", then that standard would apply to hard sections and all difficulties below hard (such as medium).

## Impossible and below
- The developers must be able to beat the section consistently given practice
- Avoid artificial difficulty! Some examples of artificial difficulty include:
- Super thin platforms (like 1x1x1 studs,)
- Tricking the player by adding kill parts they won’t be able to see, non-collidable platforms that are fully opaque
- Obstacles that can only be overcome by abusing glitches or requiring certain avatar sizes
- In `Impossible` sections only, obstacles must require precise timing of your avatar's movements
- The section must play and flow like a "platformer" level, not a roblox obby or flood escape 2 level
- Platforms must have a minimum standing width of 10x10 studs, and a minimum height of 1 stud

![](../Assets/images/SectionDesignStandards/image12.png){: style="height:250px;width:250px"}

- Shortcuts / multiple routes are allowed and encouraged, they should be slightly harder than the difficulty they are in, for example if a major shortcut appears in an easy section, it should be medium. In the example below, players are able to go left or right, with the right side being the shortcut:

![](../Assets/images/SectionDesignStandards/image5.png)

- We permit courses that go outside their section using teleporters, these course models CANNOT exceed the height of their parent section. If the section walls are 500 studs high, the height of the part outside the section should be a maximum of 500 studs as well!

![](../Assets/images/SectionDesignStandards/image9.png){: style="height:250px;width:350px"}
![](../Assets/images/SectionDesignStandards/image13.png){: style="height:250px;width:350px"}

- Similar to above, we allow SECRET shortcuts that go outside the tower, the idea is that you hide a teleporter somewhere in the course that takes the player outside the section to a course that is 1-2 tier(s) higher in difficulty than the parent section, but is able to be completed much faster with skill. For example, a secret course inside an easy section should be medium to hard. The teleporter to the secret should be well hidden!

![](../Assets/images/SectionDesignStandards/image2.png){: style="height:250px;width:350px"}
![](../Assets/images/SectionDesignStandards/image15.png){: style="height:250px;width:350px"}

- No damage parts directly on top of ladders and fences, you must add a barrier between the top of the ladder/fence and the damage part if you want one on top:

![](../Assets/images/SectionDesignStandards/image3.png){: style="height:250px;width:250px"}
![](../Assets/images/SectionDesignStandards/image11.png){: style="height:250px;width:250px"}

## Rage inducing and below
- Obstacles must have a noticably slower speed than obstacles found in `Impossible` sections
- The section must be the size of a "standard" section, smaller than roughly half of a large `Impossible` section

## Hard and below
- Obstacles can't require strict / precise timing of movements IF that results in the player falling (being damaged for failure of precise movements is OK)
- The section's segments connecting the stationary / "rest" platforms must be shorter in length than those found in `Rage inducing` sections
- The section's segments connecting the stationary / "rest" platforms must have a noticably lower chance of making the player fall than those found in `Rage inducing` sections

## Medium and below
- The player should be guided on where to go (e.g. signs pointing to the easiest possbile paths), the level flow should be noticably linear

![](../Assets/images/SectionDesignStandards/image4.png){: style="height:250px;width:450px"}

- The player should not be required to do complex movements (e.g. doublejumping in midair underneath a barrier to get to the other side of it)
- Obstacles should be noticably slower than obstacles found in `Hard` sections
- Any danger present (falling, getting hurt, etc) should be easily avoidable to a novice player

## Easy and below
- If ice is present, it cannot require precision of movement
- Obstacle types cannot be combined, they must be standalone. This should be kept simple as we are trying to introduce players to obstacles rather than really challenge them.

![](../Assets/images/SectionDesignStandards/image6.png){: style="height:250px;width:250px"}
![](../Assets/images/SectionDesignStandards/image1.png){: style="height:250px;width:250px"}

- Walljumps should have a platform underneath them to catch players from falling

![](../Assets/images/SectionDesignStandards/image10.png){: style="height:250px;width:250px"}
![](../Assets/images/SectionDesignStandards/image14.png){: style="height:250px;width:250px"}

- Obstacles should be noticably slower than those found in `Medium` sections
- Any danger present (falling, getting hurt) should be easily avoidable to new players with minimal experience in the game

## Cakewalk
- There should be NO danger of falling too far back in the section. Falling should at most make the player lose a few seconds of their time
- Any fall hazards should not also hurt the player upon landing (e.g. player should not be able to fall into a lava pit with a harder escape)
- Any danger (falling, getting hurt) should be avoidable by players with absolutely no experience in the game
- The section should be designed like that of an intro mario level - big platforms, a fun linear level flow, barely "tower" like (external section segments via teleporters are a great use here!)
- The section should introduce players to most mechanics in the game (obstacles and avatar movement)

62 changes: 1 addition & 61 deletions docs/Section Documentation/index.md
Original file line number Diff line number Diff line change
@@ -1,64 +1,4 @@
---
title: Sections
---

!!! Note
We are only accepting `Easy` sections at this time!

## Design standards

- Avoid artificial difficulty! Some examples of artificial difficulty include:
- Super thin platforms (like 1x1x1 studs,)
- Tricking the player by adding kill parts they won’t be able to see, non-collidable platforms that are fully opaque
- Obstacles that can only be overcome by abusing glitches or requiring certain avatar sizes

- Shortcuts / multiple routes are allowed and encouraged, they should be slightly harder than the difficulty they are in, for example if a major shortcut appears in an easy section, it should be medium. In the example below, players are able to go left or right, with the right side being the shortcut:

![](../Assets/images/SectionDesignStandards/image5.png)

- Players should be directed with arrow signs towards the easiest path available, arrows matter the most in `Easy` and `Medium` tiered sections:

![](../Assets/images/SectionDesignStandards/image4.png){: style="height:250px;width:450px"}

- We permit courses that go outside their section using teleporters, these course models CANNOT exceed the height of their parent section. If the section walls are 500 studs high, the height of the part outside the section should be a maximum of 500 studs as well!

![](../Assets/images/SectionDesignStandards/image9.png){: style="height:250px;width:350px"}
![](../Assets/images/SectionDesignStandards/image13.png){: style="height:250px;width:350px"}

- Similar to above, we allow SECRET shortcuts that go outside the tower, the idea is that you hide a teleporter somewhere in the course that takes the player outside the section to a course that is 1-2 tier(s) higher in difficulty than the parent section, but is able to be completed much faster with skill. For example, a secret course inside an easy section should be medium to hard. The teleporter to the secret should be well hidden!

![](../Assets/images/SectionDesignStandards/image2.png){: style="height:250px;width:350px"}
![](../Assets/images/SectionDesignStandards/image15.png){: style="height:250px;width:350px"}

- No damage parts directly on top of ladders and fences, you must add a barrier between the top of the ladder/fence and the damage part if you want one on top:

![](../Assets/images/SectionDesignStandards/image3.png){: style="height:250px;width:250px"}
![](../Assets/images/SectionDesignStandards/image11.png){: style="height:250px;width:250px"}

## Easy standards

Easy sections act as a safe way to introduce players to the mechanics of Super Skyward Towers. It is important that they follow a logical flow of progression such that the player learns and does not become too frustrated. As such, these sections are the **most important** sections of the game.

- Try not to overwhelm the player by combining too many obstacles of different types together, keep things simple as we are trying to introduce players to obstacles rather than really challenge them. Example shown below:

![](../Assets/images/SectionDesignStandards/image6.png){: style="height:250px;width:250px"}
![](../Assets/images/SectionDesignStandards/image1.png){: style="height:250px;width:250px"}

- Wall jumps should usually have a platform underneath to catch players, as shown below:

![](../Assets/images/SectionDesignStandards/image10.png){: style="height:250px;width:250px"}
![](../Assets/images/SectionDesignStandards/image14.png){: style="height:250px;width:250px"}

- Spinners should not be too fast, an AngularVelocity for their HingeConstraint of 0.7 - 1.1 is a good range.
- Moving platforms should not be too fast, a speed of 12 - 18 is a good range
- Conveyors should not be too fast, usually a speed of 15 - 27 is a good range
- Disappearing platforms should not disappear too fast, usually a 2 - 2.5 second wait-time is a good range

- Regular platforms should have a minimum standing width of 10x10 studs, and a minimum height of 1 stud. Try and give players lots of ground to stand on in easy sections:

![](../Assets/images/SectionDesignStandards/image12.png){: style="height:250px;width:250px"}

## Artstyle standards
# Artstyle standards

Super Skyward Towers has a very simplistic art style, we use standard Roblox materials and very few custom textures save for section walls.

Expand Down

0 comments on commit a90bb71

Please sign in to comment.