Foumart Games Blog [    ] - [ o ] - [    ] - [    ] - [    ] - [    ] - [    ] - [ x ]
2013-04-10 DisplaceR - Displacement Map Filter Tweener - AS3 Collapse

DisplaceR is a lightweight Displacement Map Filter Tweener targeting Flash Player 9. Written in ActionScript 3.0¹², DisplaceR is built with the idea to be as simple as possible, becoming accessible by all kind of flash developers and designers. Being a static class makes it available anywhere in your project. Tweening is achieved only with one line of code.

Example:
DisplaceR.to(source_mc, map_mc, Regular.easeInOut, 255, 0.5);
Demonstration:



(Before jumping in depth you may recollect the DisplacementMapFilter Documentation)

DisplaceR library provides static mothod "to()" for displacement manipulation of a source display object according the color data of provided map image. Methods such "from()" or "reverse()" may be added in future versions, for now the only other static method available is "dispose()". DisplaceR can also be used as object with "displace" property:

var displacer:DisplaceR = new DisplaceR(source_mc, map_mc);
var tw:Tween = new Tween(displacer,"displace", Regular.easeIn, 0,255,5);
The effect relies entirely on the provided map. In the example above the map is composed of four layered readial gradients in total placed in a movie clip in the Flash IDE - method that I call "hand-made". Of course you can pass a bitmap data generated with script on the fly, update it every frame etc.., but that is another subject :)

Let's look more closely at colors and how to generate displacement map without writting any code. DisplaceR uses the Red Color channel for displacement of pixels in X axis (horizontal) and the Green Color channel for displacement in Y (vertical). If you chose to pass a movie clip as map then it can be constructed of several overlapping colored gradients with blend mode ADD or SUBSTRACT applied to them (pretty much the same way as alpha or erase masks are built). This way we are ensuring that any color data in a layer above will be multiplied or substracted with the layer below in order to produce map with usefull color data. Generation of displacement map in short:


Since Red color channel displaces in X axis while Green color displaces in Y, both need to be able to manipulate the values positively or negatively. Thats why a map which creates no displacement at all is filled with a "middle-color" values of #808000.

#00(negative displacement) - #80(no displacement) - #FF(positive displacement);

Blend Modes are extremelly usefull when generating displacement maps. However we have to conform mathematically how to add/substract hex colors values. Here are how the different blend modes affect color data mixing with transparency:




Finally if you need a callback function you can use "onComplete" property:
DisplaceR.onComplete = function():void { trace("tween finished"); }

DisplaceR Library SWC will be available shortly, in the meanwhile view source at Github³ or download some flash examples from here.


¹ built on top of the DisplacementMapFilter and the native flash Tweener. Compiled is only 4 kb!
² DisplaceR can be easily translated to AS2 in order to target Flash Player 8. Contibutions are wellcome :)
³ current version of the tweener is still in earliest stage of development and it is possible to have flaws.
DisplaceR - Displacement Map Filter Tweener written in ActionScript 3, targeting Flash Player 9. Compiled is only 4kb.AS3, displace, filter, effect, tween, animation, layer, gradient, lightweight, library, blendmode, add, substract
 2017-05-01 JavaScript Sound Effect Generator SoundFX

Every year there is a unique JavaScript game development competition happening for a month, starting at 13th September - the #js13kgames. The Jam has one main characteristic: 13 kilobytes limit of the archived game source, as constrained by Andrzej Mazur - the compo author. I participated in 2016 with Skip'n Glitch - a game contained in a single html file and had no problem compressing the game in 13 kilobytes. However it wouldn't happen easily if some useful lightweight libraries weren't prepared beforehand. One such script is a sound controller from my less than 1kb js libraries. ..


 2016-11-23 JavaScript HTML5 Canvas Lens Flare effect

As the web tech is evolving, the flash player for web browsers is getting more and more obsolete. For example the biggest advertising platform - Google's DoubleClick dropped support for flash ads. I'm not speaking against the flash technology, which is still viable for game development (it can be easily compiled for mobile or wrapped into Steam). However in web there are new heroes and one of them is the HTML Canvas. I've already shared some lightweight JavaScript libraries used in #js13kgames and today I'm sharing another class - Lens Flare effect! ..


 2015-02-28 Get the domain a SWF is hosted in

When creating a flash game for the web it's crucial to know the domain the game SWF is being loaded from. There are numerous ways to embed a SWF in a website and the different methods of obtaining the domain name at run-time are giving different values. For example a game could be hosted in sourcedomain.com but displayed in a web page at another domain, say hotlinkingdomain.com. In this case there is one method to obtain the domain that is hosting the SWF and other methods of obtaining the domain that is embedding (hot linking) that SWF...


 2014-07-03 Check HTML restrictions in SWF. Determine AllowScriptAccess and AllowNetworking with AS3

As I was digging around the allowNetworking setting and how to determine if it's allowed inside flash at runtime, I decided to go deeper and catch other types of embedding restrictions, like the allowScriptAccess parameter. I've seen sites that block outgoing links of certain flash files - in most cases flash games are prevented to access the web, resulting in negative effect over their authors - the game developers...


 2013-05-24 Atrakt 4096 successful entry in Ludum Dare #26 Compo

Atrakt 4096 is minimalist mixture between Sci-Fi action and a sliding puzzle. Vanquish all alien spawns in this level based game, involving not only exploring and fighting but planning, stealth, strategy and logical thinking as well! This game was developed in Flash-AS3 and is an extension of my Attract 4kb engine which consists of 4 kilobytes of code (4 classes)...


 2012-10-23 Attract 4kb a 4096 bytes adventure !

Born in 4kb Games on FlashGameLicense competition. A game that is exactly 4096 bytes :) It's featuring Artificial Intelligence, Fog of War, Player Health, 4 Maps and 12 Levels ! Developed in ActionScript 3 for Flash Player 9. Here is a Github link where you can view the optimized code...



FoumartGames.com Copyright
© 2009-2017 by Noncho Savov
FoumartGames.com is a computer game workshop and arcade website, led by independent game developer. The site showcases games and game prototypes invented and developed by Noncho Savov. Have fun!