Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mikuauahdark/kazari
Multitouch gesture and input library.
https://github.com/mikuauahdark/kazari
gamedev love2d lua multitouch touchscreen
Last synced: 3 months ago
JSON representation
Multitouch gesture and input library.
- Host: GitHub
- URL: https://github.com/mikuauahdark/kazari
- Owner: MikuAuahDark
- License: zlib
- Created: 2022-12-07T10:27:14.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2022-12-13T14:40:22.000Z (about 2 years ago)
- Last Synced: 2024-08-02T06:17:41.388Z (5 months ago)
- Topics: gamedev, love2d, lua, multitouch, touchscreen
- Language: Lua
- Homepage:
- Size: 41 KB
- Stars: 10
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
Kazari
=====Kazari is a touch gesture input library.
Setup
-----To start, clone the repository. Say you're in your current project directory (directory where `main.lua` reside), run:
```
git clone https://github.com/MikuAuahDark/Kazari libs/kazari
```You can change `libs/kazari` to `libs/hanachirusato` or anywhere else as long as you remember what name to use in `require` later.
To load the library, use `require`:
```lua
local kazari = require("libs.kazari")
```Documentation
-----***********
These functions are available in Kazari 1.0.0.
### `Constraint`
This is pseudo-type that can be used to limit where the touch gesture operates on.
This pseudo-type accept one of these:
* `nil`, which means touch is unbounded.
* Array of numbers in order: `{x position, y position, width, height}`
* Key-value pairs with these structure: `{x = x position, y = y position, w = width, h = height}`
* [NLay's `BaseConstraint` type](https://github.com/MikuAuahDark/NPad93#nlay)### `boolean kazari.is(any object, Class extends BaseGesture> class)`
Check if `object` is an instance of `class` where `class` inherits `BaseGesture`.
Returns: is `object` an instance of `class`?
Example:
```lua
-- Check if object is an instance of BaseGesture
print(kazari.is(object, kazari.BaseGesture))
```### `kazari.BaseGesture`
The `BaseGesture` class. All gesture object inherit this class.
### `boolean BaseGesture:touchpressed(any id, number x, number y, number pressure)`
Send touch pressed event to the gesture. In LÖVE environment, this function should be called in
[`love.touchpressed`](https://love2d.org/wiki/love.touchpressed) with their arguments passed accordingly.Class that derive `BaseGesture` may contain `constraint` as their constructor parameter. It's responsible to ensure
that only touches at those areas defined by `constraint` are consumed.Returns: Is the event consumed?
### `boolean BaseGesture:touchmoved(any id, number x, number y, number dx, number dy, number pressure)`
Send touch moved event to the gesture. In LÖVE environment, this function should be called in
[`love.touchmoved`](https://love2d.org/wiki/love.touchmoved) with their arguments passed accordingly.### `boolean BaseGesture:touchreleased(any id, number x, number y)`
Send touch released event to the gesture. In LÖVE environment, this function should be called in
[`love.touchreleased`](https://love2d.org/wiki/love.touchreleased) with their arguments passed accordingly.### `kazari.ZoomGesture(boolean clip = false, Constraint constraint = nil)`
The `ZoomGesture` class. This gesture class is responsible of performing pinch zoom using 2 fingers.
Calling this function creates `ZoomGesture` instance which is derived from `BaseGesture`.Setting `clip` to `true` restrict each finger movement to the area bounded by `constraint`.
### `void ZoomGesture:onZoom(any context, function func)`
Register function `func` to be called everytime the zoom ratio is updated, additionally passing
`context` as the 1st parameter.The function signature for `func` must follow this convention:
```
void func(any context, number scale, number midX, number midY)
```Where `scale` always starts at 1 first then increase or decrease based on the finger movement. `midX` and `midY`
are middle point of the touch position.### `void ZoomGesture:onZoomComplete(any context, function func)`
Same as above but called when pinch zoom gesture is completed (user lifting their finger).
The function signature for `func` must follow this convention:
```
void func(any context, number scale)
```Where `scale` is the final scale ratio relative to the first time this gesture is performed.
### `kazari.RotateGesture(Constraint constraint = nil)`
The `RotateGesture` class. This gesture class is responsible of performing 2-finger rotate gesture.
Calling this function creates `RotateGesture` instance which is derived from `BaseGesture`.### `void RotateGesture:onRotate(any context, function func)`
Register function `func` to be called everytime the angle is updated, additionally passing
`context` as the 1st parameter.The function signature for `func` must follow this convention:
```
void func(any context, number angle, number da)
```Where `angle` always starts at 0 first then increase or decrease based on the finger movement. `angle`
range can go above `2 * math.pi` (1 turn clockwise) or below `-2 * math.pi` (1 turn counter-clockwise).
`da` is angle difference between last angle update. Positive value means clockwise rotation, negative value
means counter-clockwise rotation.### `void RotateGesture:onRotateComplete(any context, function func)`
Same as above but called when rotate gesture is completed (user lifting their finger) and passes
the final value (with the `da` parameter being `nil`).### `kazari.PanGesture(number minfingers, number maxfingers = minfingers boolean clip = false, Constraint constraint = nil)`
The `PanGesture` class. This gesture class is responsible of reporting x and y movement from `minfingers`
finger(s) (1 included) to `mzxfingers` finger(s) (1 included). Calling this function creates `PanGesture`
instance which is derived from `BaseGesture`.Notes:
* `minfingers` must be at least 1.
* `maxfingers` must be at least `minfingers` (default).
* `clip` clips the position of each finger instead of the average.### `void PanGesture:onMove(any context, function func)`
Register function `func` to be called everytime the average position is updated, additionally passing
`context` as the 1st parameter.The function signature for `func` must follow this convention:
```
void func(any context, number x, number y, number dx, number dy, number pressure)
```Where `x`, `y` are the relative position of the movement and `pressure` are the average pressure across fingers.
Note that on pressure-insensitive touchscreens, `pressure` will be always 1. `dx` and `dy` are position differences
from previous call of this function.### `void PanGesture:onMoveComplete(any context, function func)`
Register function `func` to be called when user lifting their finger and the amount of fingers registered are less
than `minfingers`.The function signature for `func` must follow this convention:
```
void func(any context, number x, number y, number pressure)
```Where `x`, `y` are the final relative position of the movement and `pressure` are the average pressure across fingers.
Note that on pressure-insensitive touchscreens, `pressure` will be always 1.### `void PanGesture:getTouchCount()`
Returns amount of fingers currently the user has in their screen (depends on the `:touch*` method calls). Returns
value from 0 inclusive to `maxfingers` inclusive.### `kazari.TapGesture(number nfingers, number moveThreshold = 32, number altDuration = 0, Constraint constraint = nil)`
The `TapGesture` class. This gesture class is responsible of sending "tap" event with at least `nfingers`
finger(s) (1 included), additionally with option to have "alternative" tap (usually mapped to "right click") when
user holds their finger(s) for at least `altDuration` _time units_. `altDuration` of 0 means the "alternative" tap
is disabled. `moveThreshold` is the maximum _distance unit_ the user finger can move before the tap is cancelled.
Calling this function creates `TapGesture` instance which is derived from `BaseGesture`.The definition of _time unit_ depends entirely on the units of delta time passed in `:update` function. If user
treat the delta time as milliseconds, then the _time unit_ is in milliseconds.The definition of _distance unit_ depends entirely on the user. _Distance units_ may be in virtual resolution
or in pixels, as long as it is a unit that define distance on screen.### `void TapGesture:update(number dt)`
Update the tap gesture for alternate tap. In LÖVE environment, this function should be called in
[`love.update`](https://love2d.org/wiki/love.update) with their arguments passed accordingly.Note that it's okay not to call this function if `altDuration` is set to 0 (where alternate tap events is disabled).
### `void TapGesture:onStart(any context, function func)`
Register function `func` to be called when a tap is initiated, additionally passing `context` as the 1st parameter.
"Tap" is initiated when at least `nfingers` finger(s) are in the bound defined by `constraint`, not moving at all.
The function signature for `func` must follow this convention:
```
void func(any context)
```### `void TapGesture:onCancel(any context, function func)`
Register function `func` to be called when a tap is cancelled, additionally passing `context` as the 1st parameter.
"Tap" is cancelled when the average position of the fingers moves more than `moveThreshold` _distance units_.
The function signature for `func` must follow this convention:
```
void func(any context, number duration)
```Where `duration` is how long user fingers was on the screen before it was cancelled, in _time units_.
### `void TapGesture:onTap(any context, function func)`
Register function `func` to be called when a tap is successfully initiated, additionally passing `context` as the
1st parameter."Tap" is considered success when the average position of the finger moves less than `moveThreshold` _distance units_
and then user release one or more of their finger(s).The function signature for `func` must follow this convention:
```
void func(any context, boolean alternate, number duration)
```Where `alternate` is `true` if `duration` is longer than or equal to `altDuration` (except where `altDuration` is
0, `alternate` will always be `false`) and `duration` is how long user fingers was on the screen before the user
releases one or more of their finger(s) on the screen, in _time units_.