Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/damonoehlman/cani
Canvas Capability Testing #deprecated see[DamonOehlman/feature]
https://github.com/damonoehlman/cani
canvas deprecated
Last synced: 9 days ago
JSON representation
Canvas Capability Testing #deprecated see[DamonOehlman/feature]
- Host: GitHub
- URL: https://github.com/damonoehlman/cani
- Owner: DamonOehlman
- Created: 2011-03-09T10:10:25.000Z (almost 14 years ago)
- Default Branch: master
- Last Pushed: 2011-03-15T01:39:26.000Z (almost 14 years ago)
- Last Synced: 2024-11-08T12:47:05.205Z (2 months ago)
- Topics: canvas, deprecated
- Language: JavaScript
- Homepage:
- Size: 93.8 KB
- Stars: 2
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# CANI (Can I?)
This library has started purely as a feature level detection utility (in the vein of Modernizr) but targeted primarily at building interactive applications using HTML5 canvas (and friends).
This is not meant to be a replacement for Modernizr but rather a suite of runtime checks that can assist you in working with canvas and others across browsers. At the moment it has very few tests, but over time it is expected to grow.
## Usage
Using CANI is simple. At the appropriate time (once the DOM has been initialized), simply call the following:
CANI.test(function(results) {
});
On the first call of this function the registered tests will be run and the results transposed into the global `CANI` object. The results are additionally passed back through the callback.## Canvas Tests
### isPointInPath
`CANI.canvas.pipTransformed`
The current working spec for canvas lists the [inPointInPath](http://www.whatwg.org/specs/web-apps/current-work/multipage/the-canvas-element.html#dom-context-2d-ispointinpath) function as returning true when:
> the point given by the x and y coordinates passed to the method, when treated as coordinates in the canvas coordinate space unaffected by the current transformation.
Unfortunately, this is not consistent across browsers. As such you will need to determine whether you use an position that is unaffected by transforms (translate, scale, rotate) or simply the position of the cursor relative to the canvas.