mirror of
https://github.com/scratchfoundation/Gestouch.git
synced 2024-11-23 07:47:59 -05:00
Update README
This commit is contained in:
parent
2d52729f7c
commit
963c66024e
1 changed files with 26 additions and 17 deletions
|
@ -1,6 +1,6 @@
|
||||||
h1. Gestouch: NUI gestures detection framework for mouse, touch and multitouch AS3 development.
|
h1. Gestouch: multitouch gesture recognition library for Flash (ActionScript) development.
|
||||||
|
|
||||||
Gestouch is a ActionScript library/framework that helps you to deal with single- and multitouch gestures for building better NUI (Natural User Interface).
|
Gestouch is a ActionScript (AS3) library that helps you to deal with single- and multitouch gestures for building better NUI (Natural User Interface).
|
||||||
|
|
||||||
|
|
||||||
h3. Why? There's already gesture support in Flash/AIR!
|
h3. Why? There's already gesture support in Flash/AIR!
|
||||||
|
@ -13,9 +13,9 @@ _Upd:_ With "native way" you also won't get anything out of Stage3D and of custo
|
||||||
h3. What Gestouch does in short?
|
h3. What Gestouch does in short?
|
||||||
|
|
||||||
Well basically there's 3 distinctive tasks to solve.
|
Well basically there's 3 distinctive tasks to solve.
|
||||||
# To provide various input. It can be standard MouseEvents, TouchEvents or more complex things like custom input via TUIO protocol for your hand-made installation. So what we get here is Touches (touch points).
|
# To provide various input. It can be native MouseEvents, TouchEvents or more complex things like custom input via TUIO protocol for your hand-made installation. So what we get here is Touches (touch points).
|
||||||
# To recognize gesture out of touch points. Each type of Gesture has it's own inner algorithms that ...
|
# To recognize gesture analyzing touches. Each type of Gesture has it's own inner algorithms that ...
|
||||||
# To manage gestures relations. Because they may "overlap" and once some has been recognized probably we don't want other to do so.
|
# To manage gestures conflicts. As multiple gestures may be recognized simultaneously, we need to be able to control whether it's allowed or some of them should not be recognized (fail).
|
||||||
|
|
||||||
Gestouch solves these 3 tasks.
|
Gestouch solves these 3 tasks.
|
||||||
I was hardly inspired by Apple team, how they solved this (quite recently to my big surprise! I thought they had it right from the beginning) in they Cocoa-touch UIKit framework. Gestouch is very similar in many ways. But I wouldn't call it "direct port" because 1) the whole architecture was implemented based just on conference videos and user documentation 2) flash platform is a different platform with own specialization, needs, etc.
|
I was hardly inspired by Apple team, how they solved this (quite recently to my big surprise! I thought they had it right from the beginning) in they Cocoa-touch UIKit framework. Gestouch is very similar in many ways. But I wouldn't call it "direct port" because 1) the whole architecture was implemented based just on conference videos and user documentation 2) flash platform is a different platform with own specialization, needs, etc.
|
||||||
|
@ -23,7 +23,7 @@ So I want Gestouch to go far beyond that.
|
||||||
|
|
||||||
Features:
|
Features:
|
||||||
* Pretty neat architecture! Very similar to Apple's UIGestureRecognizers (Cocoa-Touch UIKit)
|
* Pretty neat architecture! Very similar to Apple's UIGestureRecognizers (Cocoa-Touch UIKit)
|
||||||
* Works with any display list hierarchy structures: native DisplayList (pure AS3/Flex/your UI framework), Starling or ND2D (Stage3D), and 3D libs...
|
* Works with any display list hierarchy structures: native DisplayList (pure AS3/Flex/your UI framework), Starling or ND2D (Stage3D) and 3D libs...
|
||||||
* Doesn't require any additional software (may use runtime's build-in touch support)
|
* Doesn't require any additional software (may use runtime's build-in touch support)
|
||||||
* Works across all platforms (where Flash Player or AIR run of course) in exactly same way
|
* Works across all platforms (where Flash Player or AIR run of course) in exactly same way
|
||||||
* Extendable. You can write your own application-specific gestures
|
* Extendable. You can write your own application-specific gestures
|
||||||
|
@ -70,23 +70,32 @@ private function onFreeTransform(event:TransformGestureEvent):void
|
||||||
|
|
||||||
h3. Advanced usage: Starling, ...
|
h3. Advanced usage: Starling, ...
|
||||||
|
|
||||||
Recent changes made it possible to work with "Starling":http://www.starling-framework.org display list objects as well as any one display list hierarchical structures, e.g. other Stage3D frameworks that have display objects hierarchy like "ND2D":https://github.com/nulldesign/nd2d or even 3D libraries.
|
Recent changes made it possible to work with "Starling":http://www.starling-framework.org display list objects as well as any other display list hierarchical structures, e.g. other Stage3D frameworks that have display objects hierarchy like "ND2D":https://github.com/nulldesign/nd2d or even 3D libraries.
|
||||||
In order to use detect gestures with Starling do following:
|
In order to use Gestouch with Starling do the following:
|
||||||
<pre><code>starling = new Starling(MyStarlingRootClass, stage);
|
<pre><code>starling = new Starling(MyStarlingRootClass, stage);
|
||||||
/* setup & start your Starling instance here */
|
/* setup & start your Starling instance here */
|
||||||
|
|
||||||
var gesturesManager:IGesturesManager = GesturesManager.getInstance();
|
// Gestouch initialization step 1 of 3:
|
||||||
// Register instance of StarlingDisplayListAdapter to be used for objects of type starling.display.DisplayObject.
|
// Initialize native (default) input adapter. Needed for non-DisplayList usage.
|
||||||
// What StarlingDisplayListAdapter does: helps to build hierarchy (chain of parents) for any Starling display object
|
Gestouch.inputAdapter ||= new NativeInputAdapter(stage);
|
||||||
// and acts as a adapter for gesture target to provide strong-typed access to methods like globalToLocal() and contains().
|
|
||||||
gesturesManager.addDisplayListAdapter(starling.display.DisplayObject, new StarlingDisplayListAdapter());
|
|
||||||
|
|
||||||
// Initialize and register StarlingInputAdapter.
|
// Gestouch initialization step 2 of 3:
|
||||||
// What StarlingInputAdapter does: populates library with touches for Starling "layer"
|
// Register instance of StarlingDisplayListAdapter to be used for objects of type starling.display.DisplayObject.
|
||||||
gesturesManager.addInputAdapter(new StarlingInputAdapter(starling));
|
// What it does: helps to build hierarchy (chain of parents) for any Starling display object and
|
||||||
|
// acts as a adapter for gesture target to provide strong-typed access to methods like globalToLocal() and contains().
|
||||||
|
Gestouch.addDisplayListAdapter(starling.display.DisplayObject, new StarlingDisplayListAdapter());
|
||||||
|
|
||||||
|
// Gestouch initialization step 3 of 3:
|
||||||
|
// Initialize and register StarlingTouchHitTester.
|
||||||
|
// What it does: finds appropriate target for the new touches (uses Starling Stage#hitTest() method)
|
||||||
|
// What does "-1" mean: priority for this hit-tester. Since Stage3D layer sits behind native DisplayList
|
||||||
|
// we give it lower priority in the sense of interactivity.
|
||||||
|
Gestouch.addTouchHitTester(new StarlingTouchHitTester(starling), -1);
|
||||||
|
// NB! Use Gestouch#removeTouchHitTester() method if you manage multiple Starling instances during
|
||||||
|
// your application lifetime.
|
||||||
</code></pre>
|
</code></pre>
|
||||||
|
|
||||||
Now you can register gesture in familiar way:
|
Now you can register gesture in familiar, exactly same way:
|
||||||
<pre><code>var tap:TapGesture = new TapGesture(starlingSprite);</code></pre>
|
<pre><code>var tap:TapGesture = new TapGesture(starlingSprite);</code></pre>
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue