Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/justjoeyuk/Advanced_Joystick
A simple Joystick for the Starling Framework. Great for Mobile Use.
https://github.com/justjoeyuk/Advanced_Joystick
Last synced: about 2 months ago
JSON representation
A simple Joystick for the Starling Framework. Great for Mobile Use.
- Host: GitHub
- URL: https://github.com/justjoeyuk/Advanced_Joystick
- Owner: justjoeyuk
- License: other
- Created: 2013-01-12T01:14:31.000Z (about 12 years ago)
- Default Branch: master
- Last Pushed: 2015-09-01T14:15:56.000Z (over 9 years ago)
- Last Synced: 2024-08-04T05:03:55.205Z (5 months ago)
- Language: ActionScript
- Size: 575 KB
- Stars: 21
- Watchers: 11
- Forks: 11
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-actionscript-sorted - Advanced_Joystick - A simple Joystick for the Starling Framework. Great for Mobile Use. (Video Games / Game Controller)
README
WELCOME TO ADVANCED_JOYSTICK
Getting Started
Hey there. If you're reading this, it is likely you are looking for a Joystick solution for Starling. **Well you've
found it!**. This Joystick offers features you'd expect from one, and it runs smoothly with the GPU Acceleration that
Starling provides. To get started, you should:----
- Download the files from the Repository.
- Extract the source files to 'starling/extensions/'
- Check the example project to see how to implement this Joystick.
Usage
Creation and Initialization
The code in Advanced Joystick is **very** simple. Now, lets start with adding a simple JoyStick:import starling.extensions.advancedjoystick.JoyStick;
var myJoystick:Joystick = new Joystick();
myJoystick.setPosition(myJoystick.minOffsetX, clientHeight - myJoystick.minOffsetY);
addChild(myJoystick);The above code would initialize the Joystick with the Default Skin. The Joystick will then be positioned at the
bottom left of the screen since `minOffset` is the total size of the joystick, meaning that it will all be in the
screen. The Joystick is then added to the Starling Display List.If we wanted to load a JoyStick with a Texture from a `TextureAtlas`, then code similiar to the code below should
be used:var holderTexture:Texture = myTextureAtlas.getTexture('joystick_holder');
var stickTexture:Texture = myTextureAtlas.getTexture('joystick_stick');
var myJoystick:JoyStick = new JoyStick( holderTexture, stickTexture, true );This will load a JoyStick which is Custom Skinned. The last parameter is to set whether the JoyStick will start
working immediately. If you set this to false, the Joystick can be manually activated by calling `activate()`.----
Movement and Velocity
Now, for getting the movement from the Joystick, this is also **very** simple. Let's use some simple code to move
a simple object. Let's assume `player` is a Starling Sprite:player.x += myJoystick.velocityX * maxSpeed;
player.y += myJoystick.velocityY * maxSpeed;That's it. Run that code every frame and your object will move according to the Joystick. The values of `velocityX` and
`velocityY` are returned as normalized values, meaning that the value is between -1 and 1. This is for your benefit as
you can multiply this by a maximum value to move and object depending on the distance of the stick from the center of
the holder.----
A few helpful functions
There are 3, more smaller functions that you should know. These are:
- `activate();`
- `deactivate();`
- `changeSkin( holderTexture, stickTexture );`These functions are pretty self-explanitory. If you deactivate the Joystick, touch will not work until it is activated.
The `changeSkin()` accepts 2 Starling Textures. I recommend using a Texture Atlas as these are helpful with Memory in
larger games. There are plenty of tutorials elsewhere for that.
Please Note
If you are not planning on using the default skin of the Joystick, then please open the file 'JoyStick.as' and then
COMMENT OUT these lines of code:----
[Embed( source="skins/default_stick.png" )] private static const dsClassEmbed:Class;
public static const DEFAULT_STICK:Texture = Texture.fromBitmap( new dsClassEmbed() );
[Embed( source="skins/default_holder.png" )] private static const dhClassEmbed:Class;
public static const DEFAULT_HOLDER:Texture = Texture.fromBitmap( new dhClassEmbed() );>/code>