Jump to content

OniFly: Difference between revisions

1,970 bytes added ,  1 February 2006
no edit summary
No edit summary
No edit summary
Line 1: Line 1:
OniFly is an attempt to add flight to Oni, so that the player and the enemies will be able to move freely in 3D, instead of having to do gravity's bidding.
==Planned features==
==Planned features==
* You press a key to start/stop flying. Same as Bid For Power.
# You press a key to start/stop flying. Same as Bid For Power.
* You can fly up with Jump. Also, if you aim your mouse up and run, you'll run "uphill" through the air. Same with down.
# You can fly up with Jump. You can fly down with crouch.
* When you're knocked over, you fall for a few seconds, then you can start flying again.
# When you move forward, you'll move in the direction the mouse is pointing (ie the direction your head is facing).
* You can move faster than normal.
# When you're knocked over, you fall for a few seconds, then you can start flying again.
* Enemies can move faster than you can.
# You can move faster than normal.
# Enemies can move faster than you can.


And, in best-case scenario, it would lead to this stuff:
And, in best-case scenario, it would lead to this stuff:
Line 13: Line 16:


==Implemented features==
==Implemented features==
TODO
* Characters move in the direction their head is facing. So, the player and AI units can all basically fly.
* Many of the running animations are frozen at one frame. So, people don't look like they're just running through the air.
 


==Bugs==
==Bugs==
Line 34: Line 39:
Potential fix: If we can insert some code into Oni's run loop instead of running an external program, I think we could adjust the player's position before it's drawn to the screen.
Potential fix: If we can insert some code into Oni's run loop instead of running an external program, I think we could adjust the player's position before it's drawn to the screen.


===Clipping/Gravity===
There are currently 2 implemented ways to control the y position. Both have flaws.
====Freezing Y position====
The first way is to read the y position at the start of the level, then just keep writing it and never read it again. This way, the flight rules are the -only- thing in Oni that are capable of changing the player's Y position.
However,
* The collision detection system can't alter the player's Y position -- therefore, it can't stop the player from flying through floors and ceilings.
* Cut-scenes can't change the player's Y position -- so any cut-scene involving an elevator will cause problems.
====Modifying Y position====
The second way is to read the Y position each time we're about to modify it. This way, everything in Oni can change the player's Y position (just like in the normal game).
However, this means gravity can affect the player's position. This makes it very hard to fly!


==Game balancing (keeping it fun)==
Possible options to limit the player's abilities:
* Enemies move faster than you
* Player's flight is limited (using one of the following:)
** You only get flight for a short period after hitting/killing someone; kill several people in a row to fly faster/longer (like Max Payne's bullet time)
** You have a limited amount of Fly Power that must recharge (like Bid For Power)
* You can only fly to a limited height above the ground (don't know if there's any way to implement this)
* You lose health while flying
* All enemies know where you are when you're flying


==Useful findings==
==Useful findings==
Anonymous user