Example link, dynamic click count in parentheses:
Follow my quest to learn Unity. I decided to create yet another clone of a well known game. The idea was inspired by Minimal NES on Flickr. Blocky graphics are part of the experience and not caused by my lack of sprite artistry :)
9/26/2012
Off-topic: Append goo.gl click statistics to shortened links
Today I learned how to append goo.gl click counts to shortened URLs. All you need to do is add this jQuery snippet to your site and mark all shortened links with class="googl".
Example link, dynamic click count in parentheses:
Check out the code at JsFiddle:
Example link, dynamic click count in parentheses:
9/25/2012
Finetuning character movement
At the end of Iteration 001, the character movement felt odd in more then one situation:
- Character got stuck at the of blocks
- First jumping and moving while in air did not work
- Character "floated" along ceilings while jumping
- Movement did not ease out but came to a sudden stop once the controller was released
Let's start with this problems caused by "not reading the manual"... again.
When the character got stuck at the edge of a block it looked like this:
A close look in the scene showed, that regarding Unity everything was quite in order. The character controllers capsule rested savely on the edge. However the little blocky man refused to move even the slightest bit to the right.
The solution to this problem was to simply adjust the "step offset" property. A higher offset allows the character to climb steeper steps. So movement to the right was blocked because the default virtual leg length of one was far to short for my scene. More information on can be found in the Character Controllers API docs.
A step offset of 10 works quite well |
The rest of my evening was consumed by finetuning the PlatformerController.js borrowed from the 2D Gameplay Tutorial.
- In air controls did not work as I expected. I added two additional properties in order to set a minimum and maximum in air velocity:
- Collision with a block above did not end the current jump as vertical speed was not set to zero. The inversion of vertical speed on collision did the trick:
- My first iteration on character animation did not include the adaption of animation speed based on movement speed. I fixed this writing two additional lines of code and once again loved unity for it's simplicity:
I end todays post with one of my favorite quotes:
Dans ses écrits, un sàge Italien
Dit que le mieux est l'ennemi du bien.
~Voltaire
~Voltaire
Having said this, character movement feels good enough for me for today :)
9/11/2012
Sprint 001 is released!
I am happy to announce that I finally finished the first iteration on Blocky Brothers. I.e. the first playable version which acts like a real game. It has a beginning, it has music, it has a logo, enemies, lots of jumping and even a finish condition followed by ending credits!
However do not expect too much :) It is only the first vertical slice with many more bits to follow.
Lessons learned: Making games, even the tiniest ones, includes a lot of work. By now the least part of it is about coding.
Ok, thats enough for today. No time for documentation at 2 AM.
Please note: I haven't yet figured out how to scale everything correctly. I.e. the resolution is fixed to 1000x875. However this shouldn't be a problem for most of the displays out there...
Play in your Browser using Unity Web Player
Download zipped Windows executable
Features included in iteration 001:
Upcoming features with iteration 002:
Font
BIT.TRIP SMALL by FerreTrip
Music
Satisfucktion by Ozzed
8Bit Traveller by Floating Isle
However do not expect too much :) It is only the first vertical slice with many more bits to follow.
Lessons learned: Making games, even the tiniest ones, includes a lot of work. By now the least part of it is about coding.
Ok, thats enough for today. No time for documentation at 2 AM.
Please note: I haven't yet figured out how to scale everything correctly. I.e. the resolution is fixed to 1000x875. However this shouldn't be a problem for most of the displays out there...
Play in your Browser using Unity Web Player
Download zipped Windows executable
Features included in iteration 001:
- Sprite artwork
- Level 1-1
- Goombas
- Basic movement
- Basic collision
- Sprite animation
- Sprite fade effect
- Heads up display
- Scrolling credits
Upcoming features with iteration 002:
- Advanced movement (in air control)
- Death by touching enemies
- Pits
- Death by falling down the pits
- Time counter
- Death by running out of time
- Live counter
Font
BIT.TRIP SMALL by FerreTrip
Music
Satisfucktion by Ozzed
8Bit Traveller by Floating Isle
9/04/2012
Fade Orthello sprites from solid to transparent
Todays task seems to be fairly simple: I want to put a logo sprite at the beginning of level one and fade it out as soon as the game starts. Placing the sprite is not a problem but finding the way to adapt transparency using Orthello is not straight forward... at least if you do not bother reading the manual :)
My first guess to grab and slide the "Alpha" property produced a warning:
Orthello: Alpha value can not be set on this materialReference!
Unfortunately googling for "Orthello materialReference" did not (obviously) produce any useful result. Just the well known "Did you mean: othello ...".
Note to self: Never name anything within the reach of one Levenshtein distance of any popular word if you do not want to loose customers due to Googles suggestions.
Ok, then I'll trial and error my way towards success:
Lessons learned: RTFM (at least page one) even if it's late in the evening!
In short: There are named material references which can be assigned to any sprite. It's also possible to define your own material reference. The one named "alpha" modifies the sprites transparency according to the "Alpha" setting as well as the color tint according to the defined "Tint Color". I left the tint color blank, i.e. used a medium gray, and was now happily able to fade my sprite in and out using the "Alpha" slider.
Creating the script to do the fading was no real problem compared to understanding the property handling:
My first guess to grab and slide the "Alpha" property produced a warning:
Orthello: Alpha value can not be set on this materialReference!
Sprite material properties |
Note to self: Never name anything within the reach of one Levenshtein distance of any popular word if you do not want to loose customers due to Googles suggestions.
Ok, then I'll trial and error my way towards success:
- Unticking the "transparent" checkbox → Ugly black borders where the transparent sprite sections used to be
- Ticking the "Additive" checkbox → Sprite color is added on top of background color
- Changing the "Tint Color" → Another warning
Lessons learned: RTFM (at least page one) even if it's late in the evening!
In short: There are named material references which can be assigned to any sprite. It's also possible to define your own material reference. The one named "alpha" modifies the sprites transparency according to the "Alpha" setting as well as the color tint according to the defined "Tint Color". I left the tint color blank, i.e. used a medium gray, and was now happily able to fade my sprite in and out using the "Alpha" slider.
Creating the script to do the fading was no real problem compared to understanding the property handling:
Subscribe to:
Posts (Atom)