made with requirebin
Last active
August 28, 2017 16:53
-
-
Save jtenner/f71a39927ec3bd34d51cee862bae2a0f to your computer and use it in GitHub Desktop.
requirebin sketch
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const repatch = require('repatch'); | |
const e2d = require('e2d'); | |
const components = []; | |
const app = { pointer: false, mouseData: null, activeRegions: null }; | |
const ctx = document.createElement('canvas').getContext('2d'); | |
ctx.canvas.width = 400; | |
ctx.canvas.height = 300; | |
document.body.appendChild(ctx.canvas); | |
e2d.raf(() => { | |
app.mouseData = e2d.mouseData(ctx); | |
app.activeRegions = e2d.activeRegions(ctx); | |
app.pointer = false; | |
components.forEach(x => { | |
const region = app.activeRegions[x.id]; | |
const prevActive = x.active; | |
x.hover = !!region; | |
if (region.clicked) { | |
x.active = true; | |
} | |
if (x.active && x.hover && !app.mouseData.state) { | |
x.onClick(app); | |
} | |
if (!app.mouseData.state) { | |
x.active = false; | |
} | |
x.dirty = x.update(app) || x.dirty || (prevActive !== x.active); | |
}); | |
components.sort((x, y) => x.zIndex < y.zIndex ? -1 : x.zIndex > y.zIndex ? 1 : 0); | |
const view = components.map(x => x.dirty ? x._cache = x.render() : x._cache); | |
components.forEach(x => (x.dirty = false, true)); | |
e2d.render( | |
e2d.clearRect(ctx.canvas.width, ctx.canvas.height), | |
view, | |
ctx | |
); | |
}) | |
let id = -1; | |
class Component { | |
constructor({ position = [0, 0], scale = [1, 1], rotation = 0, alpha = 0, center = [0, 0], onClick = x => {} }) { | |
this.id = (++id).toString(36); | |
this.position = position; | |
this.scale = scale; | |
this.center = center; | |
this.rotation = rotaion; | |
this.alpha = alpha; | |
this.dirty = true; | |
this.active = false; | |
this.hover = false; | |
this._cache = []; | |
this.onClick = onClick; | |
} | |
render(...children) { | |
return e2d.translate(this.position[0], this.position[1], | |
e2d.rotate(this.rotation, | |
e2d.scale(this.scale[0], this.scale[1], | |
e2d.translate(-this.center[0], -this.center[1], ...children) | |
) | |
) | |
); | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
setTimeout(function(){ | |
;require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({"repatch":[function(require,module,exports){ | |
(function (global, factory) { | |
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : | |
typeof define === 'function' && define.amd ? define(['exports'], factory) : | |
(factory((global.Repatch = {}))); | |
}(this, (function (exports) { 'use strict'; | |
var thunkFactory = function (extraArgument) { | |
var thunk = (function (store) { return function (next) { return function (reducer) { | |
if (typeof reducer !== 'function') | |
throw new Error('Thunk reducer must return a function'); | |
var result = reducer(store.getState()); | |
if (typeof result === 'function') | |
return result(store.dispatch, store.getState, extraArgument); | |
else | |
return next(function (_) { return result; }); | |
}; }; }); | |
thunk.withExtraArgument = thunkFactory; | |
return thunk; | |
}; | |
var thunk = thunkFactory(); | |
var Store = (function () { | |
function Store(initialState) { | |
var _this = this; | |
this.listeners = []; | |
this.getState = function () { return _this.state; }; | |
this.dispatch = function (reducer) { | |
if (typeof reducer !== 'function') | |
throw new Error('Reducer is not a function: dispatch takes only reducers as functions.'); | |
_this.state = reducer(_this.state); | |
_this.listeners.forEach(function (listener) { return listener(); }); | |
return _this.state; | |
}; | |
this.subscribe = function (listener) { | |
if (typeof listener !== 'function') | |
throw new Error('Listener is not a function: subscribe takes only listeners as functions.'); | |
_this.listeners = _this.listeners.concat([listener]); | |
return function () { return (_this.listeners = _this.listeners.filter(function (lis) { return lis !== listener; })); }; | |
}; | |
this.addMiddleware = function () { | |
var middlewares = []; | |
for (var _i = 0; _i < arguments.length; _i++) { | |
middlewares[_i] = arguments[_i]; | |
} | |
if (middlewares.some(function (middleware) { return typeof middleware !== 'function'; })) | |
throw new Error('Middleware is not a function: addMiddleware takes only middlewares as functions.'); | |
middlewares.forEach(function (middleware) { return (_this.dispatch = middleware(_this)(_this.dispatch)); }); | |
return _this; | |
}; | |
this.state = initialState; | |
} | |
return Store; | |
}()); | |
exports.Store = Store; | |
exports['default'] = Store; | |
exports.thunk = thunk; | |
Object.defineProperty(exports, '__esModule', { value: true }); | |
}))); | |
},{}]},{},[]) | |
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2hvbWUvYWRtaW4vYnJvd3NlcmlmeS1jZG4vbm9kZV9tb2R1bGVzL2Jyb3dzZXJpZnkvbm9kZV9tb2R1bGVzL2Jyb3dzZXItcGFjay9fcHJlbHVkZS5qcyIsInJlcGF0Y2giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUNBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiZ2VuZXJhdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbiBlKHQsbixyKXtmdW5jdGlvbiBzKG8sdSl7aWYoIW5bb10pe2lmKCF0W29dKXt2YXIgYT10eXBlb2YgcmVxdWlyZT09XCJmdW5jdGlvblwiJiZyZXF1aXJlO2lmKCF1JiZhKXJldHVybiBhKG8sITApO2lmKGkpcmV0dXJuIGkobywhMCk7dmFyIGY9bmV3IEVycm9yKFwiQ2Fubm90IGZpbmQgbW9kdWxlICdcIitvK1wiJ1wiKTt0aHJvdyBmLmNvZGU9XCJNT0RVTEVfTk9UX0ZPVU5EXCIsZn12YXIgbD1uW29dPXtleHBvcnRzOnt9fTt0W29dWzBdLmNhbGwobC5leHBvcnRzLGZ1bmN0aW9uKGUpe3ZhciBuPXRbb11bMV1bZV07cmV0dXJuIHMobj9uOmUpfSxsLGwuZXhwb3J0cyxlLHQsbixyKX1yZXR1cm4gbltvXS5leHBvcnRzfXZhciBpPXR5cGVvZiByZXF1aXJlPT1cImZ1bmN0aW9uXCImJnJlcXVpcmU7Zm9yKHZhciBvPTA7bzxyLmxlbmd0aDtvKyspcyhyW29dKTtyZXR1cm4gc30pIiwiKGZ1bmN0aW9uIChnbG9iYWwsIGZhY3RvcnkpIHtcblx0dHlwZW9mIGV4cG9ydHMgPT09ICdvYmplY3QnICYmIHR5cGVvZiBtb2R1bGUgIT09ICd1bmRlZmluZWQnID8gZmFjdG9yeShleHBvcnRzKSA6XG5cdHR5cGVvZiBkZWZpbmUgPT09ICdmdW5jdGlvbicgJiYgZGVmaW5lLmFtZCA/IGRlZmluZShbJ2V4cG9ydHMnXSwgZmFjdG9yeSkgOlxuXHQoZmFjdG9yeSgoZ2xvYmFsLlJlcGF0Y2ggPSB7fSkpKTtcbn0odGhpcywgKGZ1bmN0aW9uIChleHBvcnRzKSB7ICd1c2Ugc3RyaWN0JztcblxudmFyIHRodW5rRmFjdG9yeSA9IGZ1bmN0aW9uIChleHRyYUFyZ3VtZW50KSB7XHJcbiAgICB2YXIgdGh1bmsgPSAoZnVuY3Rpb24gKHN0b3JlKSB7IHJldHVybiBmdW5jdGlvbiAobmV4dCkgeyByZXR1cm4gZnVuY3Rpb24gKHJlZHVjZXIpIHtcclxuICAgICAgICBpZiAodHlwZW9mIHJlZHVjZXIgIT09ICdmdW5jdGlvbicpXHJcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignVGh1bmsgcmVkdWNlciBtdXN0IHJldHVybiBhIGZ1bmN0aW9uJyk7XHJcbiAgICAgICAgdmFyIHJlc3VsdCA9IHJlZHVjZXIoc3RvcmUuZ2V0U3RhdGUoKSk7XHJcbiAgICAgICAgaWYgKHR5cGVvZiByZXN1bHQgPT09ICdmdW5jdGlvbicpXHJcbiAgICAgICAgICAgIHJldHVybiByZXN1bHQoc3RvcmUuZGlzcGF0Y2gsIHN0b3JlLmdldFN0YXRlLCBleHRyYUFyZ3VtZW50KTtcclxuICAgICAgICBlbHNlXHJcbiAgICAgICAgICAgIHJldHVybiBuZXh0KGZ1bmN0aW9uIChfKSB7IHJldHVybiByZXN1bHQ7IH0pO1xyXG4gICAgfTsgfTsgfSk7XHJcbiAgICB0aHVuay53aXRoRXh0cmFBcmd1bWVudCA9IHRodW5rRmFjdG9yeTtcclxuICAgIHJldHVybiB0aHVuaztcclxufTtcclxudmFyIHRodW5rID0gdGh1bmtGYWN0b3J5KCk7XG5cbnZhciBTdG9yZSA9IChmdW5jdGlvbiAoKSB7XHJcbiAgICBmdW5jdGlvbiBTdG9yZShpbml0aWFsU3RhdGUpIHtcclxuICAgICAgICB2YXIgX3RoaXMgPSB0aGlzO1xyXG4gICAgICAgIHRoaXMubGlzdGVuZXJzID0gW107XHJcbiAgICAgICAgdGhpcy5nZXRTdGF0ZSA9IGZ1bmN0aW9uICgpIHsgcmV0dXJuIF90aGlzLnN0YXRlOyB9O1xyXG4gICAgICAgIHRoaXMuZGlzcGF0Y2ggPSBmdW5jdGlvbiAocmVkdWNlcikge1xyXG4gICAgICAgICAgICBpZiAodHlwZW9mIHJlZHVjZXIgIT09ICdmdW5jdGlvbicpXHJcbiAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1JlZHVjZXIgaXMgbm90IGEgZnVuY3Rpb246IGRpc3BhdGNoIHRha2VzIG9ubHkgcmVkdWNlcnMgYXMgZnVuY3Rpb25zLicpO1xyXG4gICAgICAgICAgICBfdGhpcy5zdGF0ZSA9IHJlZHVjZXIoX3RoaXMuc3RhdGUpO1xyXG4gICAgICAgICAgICBfdGhpcy5saXN0ZW5lcnMuZm9yRWFjaChmdW5jdGlvbiAobGlzdGVuZXIpIHsgcmV0dXJuIGxpc3RlbmVyKCk7IH0pO1xyXG4gICAgICAgICAgICByZXR1cm4gX3RoaXMuc3RhdGU7XHJcbiAgICAgICAgfTtcclxuICAgICAgICB0aGlzLnN1YnNjcmliZSA9IGZ1bmN0aW9uIChsaXN0ZW5lcikge1xyXG4gICAgICAgICAgICBpZiAodHlwZW9mIGxpc3RlbmVyICE9PSAnZnVuY3Rpb24nKVxyXG4gICAgICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdMaXN0ZW5lciBpcyBub3QgYSBmdW5jdGlvbjogc3Vic2NyaWJlIHRha2VzIG9ubHkgbGlzdGVuZXJzIGFzIGZ1bmN0aW9ucy4nKTtcclxuICAgICAgICAgICAgX3RoaXMubGlzdGVuZXJzID0gX3RoaXMubGlzdGVuZXJzLmNvbmNhdChbbGlzdGVuZXJdKTtcclxuICAgICAgICAgICAgcmV0dXJuIGZ1bmN0aW9uICgpIHsgcmV0dXJuIChfdGhpcy5saXN0ZW5lcnMgPSBfdGhpcy5saXN0ZW5lcnMuZmlsdGVyKGZ1bmN0aW9uIChsaXMpIHsgcmV0dXJuIGxpcyAhPT0gbGlzdGVuZXI7IH0pKTsgfTtcclxuICAgICAgICB9O1xyXG4gICAgICAgIHRoaXMuYWRkTWlkZGxld2FyZSA9IGZ1bmN0aW9uICgpIHtcclxuICAgICAgICAgICAgdmFyIG1pZGRsZXdhcmVzID0gW107XHJcbiAgICAgICAgICAgIGZvciAodmFyIF9pID0gMDsgX2kgPCBhcmd1bWVudHMubGVuZ3RoOyBfaSsrKSB7XHJcbiAgICAgICAgICAgICAgICBtaWRkbGV3YXJlc1tfaV0gPSBhcmd1bWVudHNbX2ldO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGlmIChtaWRkbGV3YXJlcy5zb21lKGZ1bmN0aW9uIChtaWRkbGV3YXJlKSB7IHJldHVybiB0eXBlb2YgbWlkZGxld2FyZSAhPT0gJ2Z1bmN0aW9uJzsgfSkpXHJcbiAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ01pZGRsZXdhcmUgaXMgbm90IGEgZnVuY3Rpb246IGFkZE1pZGRsZXdhcmUgdGFrZXMgb25seSBtaWRkbGV3YXJlcyBhcyBmdW5jdGlvbnMuJyk7XHJcbiAgICAgICAgICAgIG1pZGRsZXdhcmVzLmZvckVhY2goZnVuY3Rpb24gKG1pZGRsZXdhcmUpIHsgcmV0dXJuIChfdGhpcy5kaXNwYXRjaCA9IG1pZGRsZXdhcmUoX3RoaXMpKF90aGlzLmRpc3BhdGNoKSk7IH0pO1xyXG4gICAgICAgICAgICByZXR1cm4gX3RoaXM7XHJcbiAgICAgICAgfTtcclxuICAgICAgICB0aGlzLnN0YXRlID0gaW5pdGlhbFN0YXRlO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIFN0b3JlO1xyXG59KCkpO1xuXG5leHBvcnRzLlN0b3JlID0gU3RvcmU7XG5leHBvcnRzWydkZWZhdWx0J10gPSBTdG9yZTtcbmV4cG9ydHMudGh1bmsgPSB0aHVuaztcblxuT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsICdfX2VzTW9kdWxlJywgeyB2YWx1ZTogdHJ1ZSB9KTtcblxufSkpKTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXJlcGF0Y2guanMubWFwXG4iXX0= | |
require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({"e2d":[function(require,module,exports){ | |
(function webpackUniversalModuleDefinition(root, factory) { | |
if(typeof exports === 'object' && typeof module === 'object') | |
module.exports = factory(); | |
else if(typeof define === 'function' && define.amd) | |
define([], factory); | |
else if(typeof exports === 'object') | |
exports["e2d"] = factory(); | |
else | |
root["e2d"] = factory(); | |
})(this, function() { | |
return /******/ (function(modules) { // webpackBootstrap | |
/******/ // The module cache | |
/******/ var installedModules = {}; | |
/******/ // The require function | |
/******/ function __webpack_require__(moduleId) { | |
/******/ // Check if module is in cache | |
/******/ if(installedModules[moduleId]) | |
/******/ return installedModules[moduleId].exports; | |
/******/ // Create a new module (and put it into the cache) | |
/******/ var module = installedModules[moduleId] = { | |
/******/ i: moduleId, | |
/******/ l: false, | |
/******/ exports: {} | |
/******/ }; | |
/******/ // Execute the module function | |
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); | |
/******/ // Flag the module as loaded | |
/******/ module.l = true; | |
/******/ // Return the exports of the module | |
/******/ return module.exports; | |
/******/ } | |
/******/ // expose the modules object (__webpack_modules__) | |
/******/ __webpack_require__.m = modules; | |
/******/ // expose the module cache | |
/******/ __webpack_require__.c = installedModules; | |
/******/ // identity function for calling harmony imports with the correct context | |
/******/ __webpack_require__.i = function(value) { return value; }; | |
/******/ // define getter function for harmony exports | |
/******/ __webpack_require__.d = function(exports, name, getter) { | |
/******/ if(!__webpack_require__.o(exports, name)) { | |
/******/ Object.defineProperty(exports, name, { | |
/******/ configurable: false, | |
/******/ enumerable: true, | |
/******/ get: getter | |
/******/ }); | |
/******/ } | |
/******/ }; | |
/******/ // getDefaultExport function for compatibility with non-harmony modules | |
/******/ __webpack_require__.n = function(module) { | |
/******/ var getter = module && module.__esModule ? | |
/******/ function getDefault() { return module['default']; } : | |
/******/ function getModuleExports() { return module; }; | |
/******/ __webpack_require__.d(getter, 'a', getter); | |
/******/ return getter; | |
/******/ }; | |
/******/ // Object.prototype.hasOwnProperty.call | |
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; | |
/******/ // __webpack_public_path__ | |
/******/ __webpack_require__.p = ""; | |
/******/ // Load entry module and return exports | |
/******/ return __webpack_require__(__webpack_require__.s = 58); | |
/******/ }) | |
/************************************************************************/ | |
/******/ ([ | |
/* 0 */ | |
/***/ function(module, exports) { | |
class Instruction { | |
constructor(type, props) { | |
this.type = type; | |
this.props = props; | |
return Object.seal(this); | |
} | |
} | |
Object.seal(Instruction); | |
Object.seal(Instruction.prototype); | |
module.exports = Instruction; | |
/***/ }, | |
/* 1 */ | |
/***/ function(module, exports) { | |
let transformPoints = (points, matrix) => { | |
let result = [], | |
x, y; | |
for(let i = 0; i < points.length; i++) { | |
[x, y] = points[i]; | |
result.push([ | |
matrix[0] * x + matrix[2] * y + matrix[4], | |
matrix[1] * x + matrix[3] * y + matrix[5] | |
]); | |
} | |
return result; | |
}; | |
module.exports = transformPoints; | |
/***/ }, | |
/* 2 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0), | |
cache = new Instruction('beginPath'); | |
let beginPath = () => cache; | |
module.exports = beginPath; | |
/***/ }, | |
/* 3 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let cache = new Instruction('closePath'); | |
let closePath = () => cache; | |
module.exports = closePath; | |
/***/ }, | |
/* 4 */ | |
/***/ function(module, exports) { | |
let cycleMouseData = (ctx) => { | |
let mouseData = ctx.canvas[Symbol.for('mouseData')]; | |
if (mouseData) { | |
mouseData.dx = mouseData.x - mouseData.previousX; | |
mouseData.dy = mouseData.y - mouseData.previousY; | |
mouseData.previousX = mouseData.x; | |
mouseData.previousY = mouseData.y; | |
mouseData.clicked = 0; | |
} | |
}; | |
module.exports = cycleMouseData; | |
/***/ }, | |
/* 5 */ | |
/***/ function(module, exports) { | |
let det = 0; | |
let invertMatrix = ([a, b, c, d, e, f]) => ( | |
det = 1 / (a * d - c * b), | |
[ | |
d * det, | |
-c * det, | |
-b * det, | |
a * det, | |
(b * f - e * d) * det, | |
(e * b - a * f) * det | |
] | |
); | |
module.exports = invertMatrix; | |
/***/ }, | |
/* 6 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let lineTo = (x, y) => new Instruction('lineTo', { x, y }); | |
module.exports = lineTo; | |
/***/ }, | |
/* 7 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let moveTo = (x, y) => new Instruction('moveTo', { x, y }); | |
module.exports = moveTo; | |
/***/ }, | |
/* 8 */ | |
/***/ function(module, exports) { | |
let pointInRect = ([px, py], [[x, y], [width, height]]) => px > x && py > y && px < width && py < height; | |
module.exports = pointInRect; | |
/***/ }, | |
/* 9 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('restore'); | |
let setTransform = (matrix, ...children) => [ | |
new Instruction('setTransform', [ | |
matrix[0], | |
matrix[1], | |
matrix[2], | |
matrix[3], | |
matrix[4], | |
matrix[5] | |
]), | |
children, | |
end | |
]; | |
module.exports = setTransform; | |
/***/ }, | |
/* 10 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let pointInPolygon = __webpack_require__(57); | |
let transformPoints = __webpack_require__(1); | |
let invertMatrix = __webpack_require__(5); | |
let pointInRect = __webpack_require__(8); | |
let matrix = new Float64Array(6); | |
module.exports = (ctx) => { | |
let regions = ctx.canvas[Symbol.for('regions')], | |
mousePoints = ctx.canvas[Symbol.for('mousePoints')], | |
mouseData = ctx.canvas[Symbol.for('mouseData')], | |
results = {}; | |
//the mouse might have held still, add the current mouse position | |
if (mousePoints.length === 0) { | |
mousePoints.push([mouseData.x, mouseData.y, mouseData.state]); | |
} | |
for(let region of regions) { | |
//invert the region matrix and transform the mouse points | |
let transformedMousePoints = transformPoints(mousePoints, invertMatrix(region.matrix)); | |
//the mouse points are now relative to the mouse region | |
if (!region.polygon) { | |
for (let mousePoint of transformedMousePoints) { | |
if (pointInRect(mousePoint, region.points)) { | |
region.hover = true; | |
region.clicked = !!mouseData.clicked; | |
results[region.id] = region; | |
break; | |
} | |
} | |
continue; | |
} | |
//loop over each point until one is matched | |
for(let mousePoint of transformedMousePoints) { | |
if (pointInPolygon(mousePoint, region.points)) { | |
region.hover = true; | |
region.clicked = !!mouseData.clicked; | |
results[region.id] = region; | |
break; | |
} | |
} | |
} | |
return results; | |
}; | |
/***/ }, | |
/* 11 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0), | |
pi2 = Math.PI * 2; | |
let arc = (...args) => { | |
let [x, y, r, startAngle, endAngle, counterclockwise] = args; | |
let props = { x: 0, y: 0, r: x, startAngle: 0, endAngle: pi2, counterclockwise: false }; | |
if (args.length > 3) { | |
props.startAngle = startAngle; | |
props.endAngle = endAngle; | |
props.counterclockwise = !!counterclockwise; | |
} | |
if (args.length > 1){ | |
props.x = x; | |
props.y = y; | |
props.r = r; | |
} | |
return new Instruction("arc", props); | |
}; | |
module.exports = arc; | |
/***/ }, | |
/* 12 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let arcTo = (x1, y1, x2, y2, r) => new Instruction('arcTo', { x1, y1, x2, y2, r }); | |
module.exports = arcTo; | |
/***/ }, | |
/* 13 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let bezierCurveTo = (cp1x, cp1y, cp2x, cp2y, x, y) => new Instruction('bezierCurveTo', { | |
cp1x, | |
cp1y, | |
cp2x, | |
cp2y, | |
x, | |
y | |
}); | |
module.exports = bezierCurveTo; | |
/***/ }, | |
/* 14 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let clearRect = (...args) => new Instruction('clearRect', | |
args.length > 2 ? | |
{ x: args[0], y: args[1], width: args[2], height: args[3] } : | |
{ x: 0, y: 0, width: args[0], height: args[1] } | |
); | |
module.exports = clearRect; | |
/***/ }, | |
/* 15 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let begin = new Instruction('beginClip'), | |
performClip = new Instruction('clip'), | |
end = new Instruction('endClip'); | |
let clip = (path, ...children) => [ | |
begin, | |
path, | |
performClip, | |
children, | |
end | |
]; | |
module.exports = clip; | |
/***/ }, | |
/* 16 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let cache = new Instruction('clipPath'); | |
let clipPath = () => cache; | |
module.exports = clipPath; | |
/***/ }, | |
/* 17 */ | |
/***/ function(module, exports) { | |
let createRegularPolygon = (radius = 0, position = [0, 0], sides = 3) => { | |
let polygon = []; | |
for(let i = 0; i < sides; i++) { | |
polygon.push([ | |
position[0] + radius * Math.cos(Math.PI * 2 * i / sides), | |
position[1] + radius * Math.sin(Math.PI * 2 * i / sides) | |
]); | |
} | |
return polygon; | |
}; | |
module.exports = createRegularPolygon; | |
/***/ }, | |
/* 18 */ | |
/***/ function(module, exports) { | |
let concat = [].concat; | |
let createWrapper = (...args) => { | |
for(let i = 0; i < args.length; i++) { | |
//parse and flatten the arguments | |
while (args[i] && args[i].constructor === Array) { | |
args = concat.apply([], args).filter(Boolean); | |
} | |
if (!args[i]) { | |
continue; | |
} | |
let { type } = args[i]; | |
if (type === 'placeholder') { | |
// i is set to the placeholder index now | |
//now grab all the elements to the left of the placeHolder | |
let left = args.splice(0, i); | |
//remove the placeHolder from the array | |
args.shift(); | |
return (...children) => [left, children, args]; | |
} | |
} | |
throw new Error('Could not find placeholder, did you forget the e2d.placeHolder() call?'); | |
}; | |
module.exports = concat; | |
/***/ }, | |
/* 19 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let drawImage = (...args) => { | |
let [img, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight] = args; | |
if (args.length === 9) { | |
return new Instruction('drawImageSource', { | |
img, | |
sx, | |
sy, | |
sWidth, | |
sHeight, | |
dx, | |
dy, | |
dWidth, | |
dHeight | |
}); | |
} | |
if (args.length >= 5) { | |
return new Instruction('drawImageSize', { | |
img, | |
dx: sx, | |
dy: sy, | |
dWidth: sWidth, | |
dHeight: sHeight | |
}); | |
} | |
if (args.length >= 3) { | |
return new Instruction('drawImage', { | |
img, | |
dx: sx, | |
dy: sy | |
}); | |
} | |
return new Instruction('drawImage', { | |
img, | |
dx: 0, | |
dy: 0 | |
}); | |
}; | |
module.exports = drawImage; | |
/***/ }, | |
/* 20 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0), | |
pi2 = Math.PI * 2; | |
let ellipse = (...args) => { | |
let [x, y, radiusX, radiusY, rotation, startAngle, endAngle, anticlockwise] = args; | |
let props = { x: 0, y: 0, radiusX: x, radiusY: y, rotation: 0, startAngle: 0, endAngle: pi2, anticlockwise: false }; | |
if (args.length > 5) { | |
props.startAngle = startAngle; | |
props.endAngle = endAngle; | |
props.anticlockwise = !!anticlockwise; | |
} | |
if (args.length > 4) { | |
props.rotation = rotation; | |
} | |
if (args.length > 2){ | |
props.x = x; | |
props.y = y; | |
props.radiusX = radiusX; | |
props.radiusY = radiusY; | |
} | |
return new Instruction("ellipse", props); | |
}; | |
module.exports = ellipse; | |
/***/ }, | |
/* 21 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let cache = new Instruction('fill'); | |
let fill = () => cache; | |
module.exports = fill; | |
/***/ }, | |
/* 22 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0), | |
pi2 = Math.PI * 2; | |
let fillArc = (...args) => { | |
let [x, y, r, startAngle, endAngle, counterclockwise] = args; | |
let props = { x: 0, y: 0, r: x, startAngle: 0, endAngle: pi2, counterclockwise: false }; | |
if (args.length > 3) { | |
props.startAngle = startAngle; | |
props.endAngle = endAngle; | |
props.counterclockwise = !!counterclockwise; | |
} | |
if (args.length >= 2) { | |
props.x = x; | |
props.y = y; | |
props.r = r; | |
} | |
return new Instruction("fillArc", props); | |
}; | |
module.exports = fillArc; | |
/***/ }, | |
/* 23 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let fillRect = (...args) => new Instruction('fillRect', | |
args.length > 2 ? | |
{ x: args[0], y: args[1], width: args[2], height: args[3] } : | |
{ x: 0, y: 0, width: args[0], height: args[1] } | |
); | |
module.exports = fillRect; | |
/***/ }, | |
/* 24 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('endFillStyle'); | |
let fillStyle = (value, ...children) => [ | |
new Instruction('fillStyle', { value }), | |
children, | |
end | |
]; | |
module.exports = fillStyle; | |
/***/ }, | |
/* 25 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let fillText = (...args) => { | |
let [text, x, y, maxWidth] = args; | |
if (args.length < 4) { | |
maxWidth = null; | |
} | |
if (args.length < 3) { | |
x = 0; | |
y = 0; | |
} | |
return new Instruction('fillText', { text, x, y, maxWidth }); | |
}; | |
module.exports = fillText; | |
/***/ }, | |
/* 26 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('endGlobalAlpha'); | |
let globalAlpha = (value, ...children) => [ | |
new Instruction('globalAlpha', { value }), | |
children, | |
end | |
]; | |
module.exports = globalAlpha; | |
/***/ }, | |
/* 27 */ | |
/***/ function(module, exports, __webpack_require__) { | |
var Instruction = __webpack_require__(0); | |
let end = new Instruction('endGlobalCompositeOperation'); | |
let globalCompositeOperation = (value, ...children) => [ | |
new Instruction('globalCompositeOperation', { value }), | |
children, | |
end | |
]; | |
module.exports = globalCompositeOperation; | |
/***/ }, | |
/* 28 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let hitRect = (id, ...args) => { | |
let [x, y, width, height] = args; | |
if (args.length <= 3) { | |
width = x; | |
height = y; | |
x = 0; | |
y = 0; | |
} | |
return new Instruction('hitRect', { | |
id, | |
points: [ | |
[x, y], | |
[x + width, y + height] | |
] | |
}); | |
}; | |
module.exports = hitRect; | |
/***/ }, | |
/* 29 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let hitRegion = (id, points) => new Instruction('hitRegion', { id, points }); | |
module.exports = hitRegion; | |
/***/ }, | |
/* 30 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('endImageSmoothingEnabled'); | |
let imageSmoothingEnabled = (value, ...children) => [ | |
new Instruction('imageSmoothingEnabled', { value }), | |
children, | |
end | |
]; | |
module.exports = imageSmoothingEnabled; | |
/***/ }, | |
/* 31 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let keycode = __webpack_require__(56); | |
module.exports = (ctx) => { | |
let { canvas } = ctx; | |
//mouseData | |
canvas[Symbol.for('mouseData')] = { | |
x: 0, | |
y: 0, | |
dx: 0, | |
dy: 0, | |
previousX: 0, | |
previousY: 0, | |
state: false, | |
clicked: 0 | |
}; | |
let keys = canvas[Symbol.for('keyData')] = {}; | |
for (let name in keycode.code) { | |
if (keycode.code.hasOwnProperty(name)) { | |
keys[name] = false; | |
} | |
} | |
//mouse regions | |
canvas[Symbol.for('regions')] = []; | |
canvas[Symbol.for('mousePoints')] = []; | |
//make the canvas receive touch and mouse events | |
canvas.tabIndex = 1; | |
let mouseMove = (evt) => { | |
let { clientX, clientY } = evt; | |
//get left and top coordinates | |
let { left, top } = canvas.getBoundingClientRect(); | |
let mouseData = canvas[Symbol.for('mouseData')]; | |
let point = [clientX - left, clientY - top, mouseData.state]; | |
mouseData.x = point[0]; | |
mouseData.y = point[1]; | |
let points = canvas[Symbol.for('mousePoints')]; | |
points.push(point); | |
//store the last 100 stored positions for hover detection | |
if (points.length > 100) { | |
points.splice(0, points.length - 100); | |
} | |
evt.preventDefault(); | |
return false; | |
}; | |
canvas.addEventListener('mousemove', (evt) => mouseMove(evt)); | |
canvas.addEventListener('mousedown', (evt) => { | |
let { target } = evt; | |
if (target === canvas) { | |
let mouseData = canvas[Symbol.for('mouseData')]; | |
if (!mouseData.state) { | |
mouseData.clicked += 1; | |
} | |
mouseData.state = true; | |
return mouseMove(evt); | |
} | |
}); | |
canvas.addEventListener('mouseup', (evt) => { | |
let mouseData = canvas[Symbol.for('mouseData')]; | |
mouseData.state = false; | |
return mouseMove(evt); | |
}); | |
canvas.addEventListener('keydown', (evt) => { | |
canvas[Symbol.for('keyData')][keycode(evt.keyCode)] = true; | |
evt.preventDefault(); | |
return false; | |
}); | |
canvas.addEventListener('keyup', (evt) => { | |
canvas[Symbol.for('keyData')][keycode(evt.keyCode)] = false; | |
evt.preventDefault(); | |
return false; | |
}); | |
}; | |
/***/ }, | |
/* 32 */ | |
/***/ function(module, exports) { | |
module.exports = (ctx) => ctx.canvas[Symbol.for('keyData')]; | |
/***/ }, | |
/* 33 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('endLineStyle'); | |
let lineStyle = (value, ...children) => { | |
value = value || {}; | |
var result = { | |
lineWidth: null, | |
lineCap: null, | |
lineJoin: null, | |
miterLimit: null, | |
lineDash: null, | |
lineDashOffset: null | |
}; | |
if (typeof value.lineWidth !== 'undefined') { | |
result.lineWidth = value.lineWidth; | |
} | |
if (typeof value.lineCap !== 'undefined') { | |
result.lineCap = value.lineCap; | |
} | |
if (typeof value.lineJoin !== 'undefined') { | |
result.lineJoin = value.lineJoin; | |
} | |
if (typeof value.miterLimit !== 'undefined') { | |
result.miterLimit = value.miterLimit; | |
} | |
if (typeof value.lineDash !== 'undefined') { | |
result.lineDash = value.lineDash || []; | |
} | |
if (typeof value.lineDashOffset !== 'undefined') { | |
result.lineDashOffset = value.lineDashOffset; | |
} | |
return [ | |
new Instruction('lineStyle', result), | |
children, | |
end | |
]; | |
}; | |
module.exports = lineStyle; | |
/***/ }, | |
/* 34 */ | |
/***/ function(module, exports) { | |
module.exports = (ctx) => ctx.canvas[Symbol.for('mouseData')]; | |
/***/ }, | |
/* 35 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let moveTo = __webpack_require__(7), lineTo = __webpack_require__(6); | |
let moveToLineTo = (point, index) => index === 0 ? | |
moveTo(point[0], point[1]) : | |
lineTo(point[0], point[1]); | |
module.exports = moveToLineTo; | |
/***/ }, | |
/* 36 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let beginPath = __webpack_require__(2)(), | |
closePath = __webpack_require__(3)(); | |
let path = (...children) => [ | |
beginPath, | |
children, | |
closePath | |
]; | |
module.exports = path; | |
/***/ }, | |
/* 37 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let cache = new Instruction('placeholder'); | |
let placeHolder = () => cache; | |
module.exports = placeHolder; | |
/***/ }, | |
/* 38 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let quadraticCurveTo = (cpx, cpy, x, y) => new Instruction('quadraticCurveTo', { | |
cpx, | |
cpy, | |
x, | |
y | |
}); | |
module.exports = quadraticCurveTo; | |
/***/ }, | |
/* 39 */ | |
/***/ function(module, exports) { | |
let raf = (func) => { | |
requestAnimationFrame(() => raf(func)); | |
return func(); | |
}; | |
module.exports = raf; | |
/***/ }, | |
/* 40 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let rect = (...args) => new Instruction('rect', | |
args.length > 2 ? | |
{ x: args[0], y: args[1], width: args[2], height: args[3] } : | |
{ x: 0, y: 0, width: args[0], height: args[1] } | |
); | |
module.exports = rect; | |
/***/ }, | |
/* 41 */ | |
/***/ function(module, exports, __webpack_require__) { | |
//initialize all the properties | |
let identity = [1, 0, 0, 1, 0, 0], | |
matrix = new Float64Array(identity), | |
fillStyleStack = [], | |
strokeStyleStack = [], | |
lineStyleStack = [], | |
textStyleStack = [], | |
shadowStyleStack = [], | |
globalCompositeOperationStack = [], | |
globalAlphaStack = [], | |
imageSmoothingEnabledStack = [], | |
transformStack = new Float64Array(501 * 6), | |
transformStackIndex = 6, | |
concat = [].concat, | |
supportsEllipse = false; | |
if (typeof CanvasRenderingContext2D !== 'undefined') { | |
supportsEllipse = CanvasRenderingContext2D.prototype.hasOwnProperty('ellipse'); | |
} | |
//transform points function | |
const transformPoints = __webpack_require__(1); | |
const cycleMouseData = __webpack_require__(4); | |
const increaseTransformStackSize = () => { | |
let cache = transformStack; | |
transformStack = new Float64Array(transformStack.length + 600); //add 100 more | |
transformStack.set(cache); | |
return this; | |
}; | |
transformStack.set(identity); | |
const PI2 = Math.PI * 2; | |
let empty = (target) => target && target.splice(0, target.length); | |
module.exports = (...args) => { | |
let children = args.slice(0, -1), | |
ctx = args[args.length - 1]; | |
let regions = ctx.canvas[Symbol.for('regions')], | |
mousePoints = ctx.canvas[Symbol.for('mousePoints')], | |
extensions = ctx.canvas[Symbol.for('extensions')]; | |
let cache; | |
cycleMouseData(ctx); | |
empty(regions); | |
empty(mousePoints); | |
let len = children.length; | |
//flatten children during the loop process to save cpu | |
for (let i = 0; i < len; i++) { | |
let child = children[i]; | |
//flattening algorithm | |
if (child && child.constructor === Array) { | |
children = concat.apply([], children); | |
child = children[i]; | |
//repeat as necessary | |
while (child && child.constructor === Array) { | |
children = concat.apply([], children); | |
child = children[i]; | |
} | |
len = children.length; | |
} | |
//child must be truthy | |
if (!child) { | |
continue; | |
} | |
let { props, type } = child; | |
if (type === 'transform') { | |
//copy transformStack values to matrix | |
matrix[0] = transformStack[transformStackIndex - 6]; | |
matrix[1] = transformStack[transformStackIndex - 5]; | |
matrix[2] = transformStack[transformStackIndex - 4]; | |
matrix[3] = transformStack[transformStackIndex - 3]; | |
matrix[4] = transformStack[transformStackIndex - 2]; | |
matrix[5] = transformStack[transformStackIndex - 1]; | |
//increase the index | |
transformStackIndex += 6; | |
if (transformStackIndex > transformStack.length) { | |
increaseTransformStackSize(); | |
} | |
//perform the transform math | |
transformStack[transformStackIndex - 6] = //d | |
matrix[0] * props[0] + matrix[2] * props[1]; | |
transformStack[transformStackIndex - 5] = //b | |
matrix[1] * props[0] + matrix[3] * props[1]; | |
transformStack[transformStackIndex - 4] = //c | |
matrix[0] * props[2] + matrix[2] * props[3]; | |
transformStack[transformStackIndex - 3] = //d | |
matrix[1] * props[2] + matrix[3] * props[3]; | |
transformStack[transformStackIndex - 2] = //e | |
matrix[0] * props[4] + matrix[2] * props[5] + matrix[4]; | |
transformStack[transformStackIndex - 1] = //f | |
matrix[1] * props[4] + matrix[3] * props[5] + matrix[5]; | |
//modify the ctx | |
ctx.setTransform( | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
); | |
continue; | |
} | |
if (type === 'setTransform') { | |
transformStackIndex += 6; | |
if (transformStackIndex > transformStack.length) { | |
increaseTransformStackSize(); | |
} | |
transformStack[transformStackIndex - 6] = props[0];//a | |
transformStack[transformStackIndex - 5] = props[1];//b | |
transformStack[transformStackIndex - 4] = props[2];//c | |
transformStack[transformStackIndex - 3] = props[3];//d | |
transformStack[transformStackIndex - 2] = props[4];//e | |
transformStack[transformStackIndex - 1] = props[5];//f | |
ctx.setTransform(props[0], props[1], props[2], props[3], props[4], props[5]); | |
continue; | |
} | |
if (type === 'scale') { | |
matrix[0] = transformStack[transformStackIndex - 6]; | |
matrix[1] = transformStack[transformStackIndex - 5]; | |
matrix[2] = transformStack[transformStackIndex - 4]; | |
matrix[3] = transformStack[transformStackIndex - 3]; | |
matrix[4] = transformStack[transformStackIndex - 2]; | |
matrix[5] = transformStack[transformStackIndex - 1]; | |
transformStackIndex += 6; | |
if (transformStackIndex > transformStack.length) { | |
increaseTransformStackSize(); | |
} | |
transformStack[transformStackIndex - 6] = matrix[0] * props.x; //a | |
transformStack[transformStackIndex - 5] = matrix[1] * props.x; //b | |
transformStack[transformStackIndex - 4] = matrix[2] * props.y; //c | |
transformStack[transformStackIndex - 3] = matrix[3] * props.y; //d | |
transformStack[transformStackIndex - 2] = matrix[4]; //e | |
transformStack[transformStackIndex - 1] = matrix[5]; //f | |
ctx.setTransform( | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
); | |
continue; | |
} | |
if (type === 'translate') { | |
matrix[0] = transformStack[transformStackIndex - 6]; | |
matrix[1] = transformStack[transformStackIndex - 5]; | |
matrix[2] = transformStack[transformStackIndex - 4]; | |
matrix[3] = transformStack[transformStackIndex - 3]; | |
matrix[4] = transformStack[transformStackIndex - 2]; | |
matrix[5] = transformStack[transformStackIndex - 1]; | |
transformStackIndex += 6; | |
if (transformStackIndex > transformStack.length) { | |
increaseTransformStackSize(); | |
} | |
transformStack[transformStackIndex - 6] = matrix[0]; //a | |
transformStack[transformStackIndex - 5] = matrix[1]; //b | |
transformStack[transformStackIndex - 4] = matrix[2]; //c | |
transformStack[transformStackIndex - 3] = matrix[3]; //d | |
transformStack[transformStackIndex - 2] = matrix[4] + matrix[0] * props.x + matrix[2] * props.y; //e | |
transformStack[transformStackIndex - 1] = matrix[5] + matrix[1] * props.x + matrix[3] * props.y; //f | |
ctx.setTransform( | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
); | |
continue; | |
} | |
if (type === 'rotate') { | |
matrix[0] = transformStack[transformStackIndex - 6]; | |
matrix[1] = transformStack[transformStackIndex - 5]; | |
matrix[2] = transformStack[transformStackIndex - 4]; | |
matrix[3] = transformStack[transformStackIndex - 3]; | |
matrix[4] = transformStack[transformStackIndex - 2]; | |
matrix[5] = transformStack[transformStackIndex - 1]; | |
transformStackIndex += 6; | |
if (transformStackIndex > transformStack.length) { | |
increaseTransformStackSize(); | |
} | |
transformStack[transformStackIndex - 6] = | |
matrix[0] * props.cos + matrix[2] * props.sin; //a | |
transformStack[transformStackIndex - 5] = | |
matrix[1] * props.cos + matrix[3] * props.sin; //b | |
transformStack[transformStackIndex - 4] = | |
matrix[0] * -props.sin + matrix[2] * props.cos; //c | |
transformStack[transformStackIndex - 3] = | |
matrix[1] * -props.sin + matrix[3] * props.cos; //d | |
transformStack[transformStackIndex - 2] = matrix[4]; //e | |
transformStack[transformStackIndex - 1] = matrix[5];//f | |
ctx.setTransform( | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
); | |
continue; | |
} | |
if (type === 'skewX') { | |
matrix[0] = transformStack[transformStackIndex - 6]; | |
matrix[1] = transformStack[transformStackIndex - 5]; | |
matrix[2] = transformStack[transformStackIndex - 4]; | |
matrix[3] = transformStack[transformStackIndex - 3]; | |
matrix[4] = transformStack[transformStackIndex - 2]; | |
matrix[5] = transformStack[transformStackIndex - 1]; | |
transformStackIndex += 6; | |
if (transformStackIndex > transformStack.length) { | |
increaseTransformStackSize(); | |
} | |
transformStack[transformStackIndex - 6] = matrix[0]; //a | |
transformStack[transformStackIndex - 5] = matrix[1]; //b | |
transformStack[transformStackIndex - 4] = //c | |
matrix[0] * props.x + matrix[2]; | |
transformStack[transformStackIndex - 3] = //d | |
matrix[1] * props.x + matrix[3]; | |
transformStack[transformStackIndex - 2] = matrix[4]; //e | |
transformStack[transformStackIndex - 1] = matrix[5]; //f | |
ctx.setTransform( | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
); | |
continue; | |
} | |
if (type === 'skewY') { | |
matrix[0] = transformStack[transformStackIndex - 6]; | |
matrix[1] = transformStack[transformStackIndex - 5]; | |
matrix[2] = transformStack[transformStackIndex - 4]; | |
matrix[3] = transformStack[transformStackIndex - 3]; | |
matrix[4] = transformStack[transformStackIndex - 2]; | |
matrix[5] = transformStack[transformStackIndex - 1]; | |
transformStackIndex += 6; | |
if (transformStackIndex > transformStack.length) { | |
increaseTransformStackSize(); | |
} | |
transformStack[transformStackIndex - 6] = | |
matrix[0] * 1 + matrix[2] * props.y; //a | |
transformStack[transformStackIndex - 5] = | |
matrix[1] * 1 + matrix[3] * props.y; //b | |
transformStack[transformStackIndex - 4] = matrix[2]; //c | |
transformStack[transformStackIndex - 3] = matrix[3]; //d | |
transformStack[transformStackIndex - 2] = matrix[4]; //e | |
transformStack[transformStackIndex - 1] = matrix[5]; //f | |
ctx.setTransform( | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
); | |
continue; | |
} | |
if (type === 'restore') { | |
transformStackIndex -= 6; | |
matrix[0] = transformStack[transformStackIndex - 6]; | |
matrix[1] = transformStack[transformStackIndex - 5]; | |
matrix[2] = transformStack[transformStackIndex - 4]; | |
matrix[3] = transformStack[transformStackIndex - 3]; | |
matrix[4] = transformStack[transformStackIndex - 2]; | |
matrix[5] = transformStack[transformStackIndex - 1]; | |
ctx.setTransform(matrix[0], matrix[1], matrix[2], matrix[3], matrix[4], matrix[5]); | |
continue; | |
} | |
if (type === 'fillRect') { | |
ctx.fillRect(props.x, props.y, props.width, props.height); | |
continue; | |
} | |
if (type === 'strokeRect') { | |
ctx.strokeRect(props.x, props.y, props.width, props.height); | |
continue; | |
} | |
if (type === 'clearRect') { | |
ctx.clearRect(props.x, props.y, props.width, props.height); | |
continue; | |
} | |
if (type === 'rect') { | |
ctx.rect(props.x, props.y, props.width, props.height); | |
continue; | |
} | |
if (type === 'fillStyle') { | |
fillStyleStack.push(ctx.fillStyle); | |
ctx.fillStyle = props.value; | |
continue; | |
} | |
if (type === 'strokeStyle') { | |
strokeStyleStack.push(ctx.strokeStyle); | |
ctx.strokeStyle = props.value; | |
continue; | |
} | |
if (type === 'endFillStyle') { | |
ctx.fillStyle = fillStyleStack.pop(); | |
continue; | |
} | |
if (type === 'endStrokeStyle') { | |
ctx.strokeStyle = strokeStyleStack.pop(); | |
continue; | |
} | |
if (type === 'lineStyle') { | |
lineStyleStack.push({ | |
lineWidth: ctx.lineWidth, | |
lineCap: ctx.lineCap, | |
lineJoin: ctx.lineJoin, | |
miterLimit: ctx.miterLimit, | |
lineDash: ctx.getLineDash(), | |
lineDashOffset: ctx.lineDashOffset | |
}); | |
if (props.lineWidth !== null) { | |
ctx.lineWidth = props.lineWidth; | |
} | |
if (props.lineCap !== null) { | |
ctx.lineCap = props.lineCap; | |
} | |
if (props.lineJoin !== null) { | |
ctx.lineJoin = props.lineJoin; | |
} | |
if (props.miterLimit !== null) { | |
ctx.miterLimit = props.miterLimit; | |
} | |
if (props.lineDash !== null) { | |
ctx.setLineDash(props.lineDash); | |
} | |
if (props.lineDashOffset !== null) { | |
ctx.lineDashOffset = props.lineDashOffset; | |
} | |
continue; | |
} | |
if (type === 'endLineStyle') { | |
cache = lineStyleStack.pop(); | |
ctx.lineWidth = cache.lineWidth; | |
ctx.lineCap = cache.lineCap; | |
ctx.lineJoin = cache.lineJoin; | |
ctx.miterLimit = cache.miterLimit; | |
ctx.setLineDash(cache.lineDash); | |
ctx.lineDashOffset = cache.lineDashOffset; | |
continue; | |
} | |
if (type === 'textStyle') { | |
textStyleStack.push({ | |
font: ctx.font, | |
textAlign: ctx.textAlign, | |
textBaseline: ctx.textBaseline, | |
direction: ctx.direction | |
}); | |
if (props.font !== null) { | |
ctx.font = props.font; | |
} | |
if (props.textAlign !== null) { | |
ctx.textAlign = props.textAlign; | |
} | |
if (props.textBaseline !== null) { | |
ctx.textBaseline = props.textBaseline; | |
} | |
if (props.direction !== null) { | |
ctx.direction = props.direction; | |
} | |
continue; | |
} | |
if (type === 'endTextStyle') { | |
cache = textStyleStack.pop(); | |
ctx.font = cache.font; | |
ctx.textAlign = cache.textAlign; | |
ctx.textBaseline = cache.textBaseline; | |
ctx.direction = cache.direction; | |
continue; | |
} | |
if (type === 'shadowStyle') { | |
shadowStyleStack.push({ | |
shadowBlur: ctx.shadowBlur, | |
shadowColor: ctx.shadowColor, | |
shadowOffsetX: ctx.shadowOffsetX, | |
shadowOffsetY: ctx.shadowOffsetY | |
}); | |
if (props.shadowBlur !== null) { | |
ctx.shadowBlur = props.shadowBlur; | |
} | |
if (props.shadowColor !== null) { | |
ctx.shadowColor = props.shadowColor; | |
} | |
if (props.shadowOffsetX !== null) { | |
ctx.shadowOffsetX = props.shadowOffsetX; | |
} | |
if (props.shadowOffsetY !== null) { | |
ctx.shadowOffsetY = props.shadowOffsetY; | |
} | |
continue; | |
} | |
if (type === 'endShadowStyle') { | |
cache = shadowStyleStack.pop(); | |
ctx.shadowBlur = cache.shadowBlur; | |
ctx.shadowColor = cache.shadowColor; | |
ctx.shadowOffsetX = cache.shadowOffsetX; | |
ctx.shadowOffsetY = cache.shadowOffsetY; | |
continue; | |
} | |
if (type === 'strokeText') { | |
if (props.maxWidth) { | |
ctx.strokeText(props.text, props.x, props.y, props.maxWidth); | |
continue; | |
} | |
ctx.strokeText(props.text, props.x, props.y); | |
continue; | |
} | |
if (type === 'fillText') { | |
if (props.maxWidth) { | |
ctx.fillText(props.text, props.x, props.y, props.maxWidth); | |
continue; | |
} | |
ctx.fillText(props.text, props.x, props.y); | |
continue; | |
} | |
if (type === 'drawImage') { | |
ctx.drawImage(props.img, props.dx, props.dy); | |
continue; | |
} | |
if (type === 'drawImageSize') { | |
ctx.drawImage(props.img, props.dx, props.dy, props.dWidth, props.dHeight); | |
continue; | |
} | |
if (type === 'drawImageSource') { | |
ctx.drawImage(props.img, props.sx, props.sy, props.sWidth, props.sHeight, props.dx, props.dy, props.dWidth, props.dHeight); | |
continue; | |
} | |
if (type === 'strokeArc') { | |
ctx.beginPath(); | |
ctx.arc(props.x, props.y, props.r, props.startAngle, props.endAngle, props.counterclockwise); | |
ctx.closePath(); | |
ctx.stroke(); | |
continue; | |
} | |
if (type === 'fillArc') { | |
ctx.beginPath(); | |
ctx.arc(props.x, props.y, props.r, props.startAngle, props.endAngle, props.counterclockwise); | |
ctx.closePath(); | |
ctx.fill(); | |
continue; | |
} | |
if (type === 'moveTo') { | |
ctx.moveTo(props.x, props.y); | |
continue; | |
} | |
if (type === 'lineTo') { | |
ctx.lineTo(props.x, props.y); | |
continue; | |
} | |
if (type === 'bezierCurveTo') { | |
ctx.bezierCurveTo(props.cp1x, props.cp1y, props.cp2x, props.cp2y, props.x, props.y); | |
continue; | |
} | |
if (type === 'quadraticCurveTo') { | |
ctx.quadraticCurveTo(props.cpx, props.cpy, props.x, props.y); | |
continue; | |
} | |
if (type === 'arc') { | |
ctx.arc(props.x, props.y, props.r, props.startAngle, props.endAngle, props.counterclockwise); | |
continue; | |
} | |
if (type === 'arcTo') { | |
ctx.arcTo(props.x1, props.y1, props.x2, props.y2, props.r); | |
continue; | |
} | |
if (type === 'ellipse') { | |
//if the method is provided by the browser | |
if (supportsEllipse) { | |
ctx.ellipse( | |
props.x, | |
props.y, | |
props.radiusX, | |
props.radiusY, | |
props.rotation, | |
props.startAngle, | |
props.endAngle, | |
props.anticlockwise | |
); | |
continue; | |
} | |
ctx.save(); | |
ctx.translate(props.x, props.y); | |
ctx.rotate(props.rotation); | |
ctx.scale(props.radiusX, props.radiusY); | |
ctx.arc(0, 0, 1, props.startAngle, props.endAngle, props.anticlockwise); | |
ctx.restore(); | |
continue; | |
} | |
if (type === 'globalCompositeOperation') { | |
globalCompositeOperationStack.push(ctx.globalCompositeOperation); | |
ctx.globalCompositeOperation = props.value; | |
continue; | |
} | |
if (type === 'endGlobalCompositeOperation') { | |
ctx.globalCompositeOperation = globalCompositeOperationStack.pop(); | |
continue; | |
} | |
if (type === 'fill') { | |
ctx.fill(); | |
continue; | |
} | |
if (type === 'stroke') { | |
ctx.stroke(); | |
continue; | |
} | |
if (type === 'beginClip') { | |
ctx.save(); | |
ctx.beginPath(); | |
continue; | |
} | |
if (type === 'clip') { | |
ctx.clip(); | |
continue; | |
} | |
if (type === 'endClip') { | |
ctx.restore(); | |
continue; | |
} | |
if (type === 'beginPath') { | |
ctx.beginPath(); | |
continue; | |
} | |
if (type === 'closePath') { | |
ctx.closePath(); | |
continue; | |
} | |
if (type === 'globalAlpha') { | |
globalAlphaStack.push(ctx.globalAlpha); | |
ctx.globalAlpha *= props.value; | |
continue; | |
} | |
if (type === 'endGlobalAlpha') { | |
ctx.globalAlpha = globalAlphaStack.pop(); | |
continue; | |
} | |
if (type === 'hitRect' && regions) { | |
cache = [ | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
]; | |
regions.push({ | |
id: props.id, | |
points: props.points, | |
matrix: cache, | |
//rectangle! | |
polygon: false, | |
hover: false, | |
touched: false, | |
clicked: false | |
}); | |
} | |
if (type === 'hitRegion' && regions) { | |
cache = [ | |
transformStack[transformStackIndex - 6], | |
transformStack[transformStackIndex - 5], | |
transformStack[transformStackIndex - 4], | |
transformStack[transformStackIndex - 3], | |
transformStack[transformStackIndex - 2], | |
transformStack[transformStackIndex - 1] | |
]; | |
regions.push({ | |
id: props.id, | |
points: props.points, | |
matrix: cache, | |
polygon: true, | |
hover: false, | |
touched: false, | |
clicked: false | |
}); | |
continue; | |
} | |
if (type === 'imageSmoothingEnabled') { | |
imageSmoothingEnabledStack.push(ctx.imageSmoothingEnabled); | |
ctx.imageSmoothingEnabled = props.value; | |
continue; | |
} | |
if (type === 'endImageSmoothingEnabled') { | |
ctx.imageSmoothingEnabled = imageSmoothingEnabledStack.pop(); | |
continue; | |
} | |
if (extensions && extensions[type]) { | |
extensions[type](props, ctx); | |
continue; | |
} | |
} | |
}; | |
/***/ }, | |
/* 42 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let setTransform = __webpack_require__(9); | |
let resetTransform = (...children) => setTransform([1, 0, 0, 1, 0, 0], children); | |
module.exports = resetTransform; | |
/***/ }, | |
/* 43 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('restore'); | |
let rotate = (r, ...children) => [ | |
new Instruction('rotate', { cos: Math.cos(r), sin: Math.sin(r) }), | |
children, | |
end | |
]; | |
module.exports = rotate; | |
/***/ }, | |
/* 44 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('restore'); | |
let scale = (x, y, ...children) => { | |
if (typeof y !== 'number') { | |
children = [y].concat(children); | |
y = x; | |
} | |
return [ | |
new Instruction('scale', { x, y }), | |
children, | |
end | |
]; | |
}; | |
module.exports = scale; | |
/***/ }, | |
/* 45 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('endShadowStyle'); | |
let shadowStyle = (value, ...children) => { | |
value = value || {}; | |
var result = { | |
shadowBlur: null, | |
shadowColor: null, | |
shadowOffsetX: null, | |
shadowOffsetY: null | |
}; | |
if (typeof value.shadowBlur !== 'undefined') { | |
result.shadowBlur = value.shadowBlur; | |
} | |
if (typeof value.shadowColor !== 'undefined') { | |
result.shadowColor = value.shadowColor; | |
} | |
if (typeof value.shadowOffsetX !== 'undefined') { | |
result.shadowOffsetX = value.shadowOffsetX; | |
} | |
if (typeof value.direction !== 'undefined') { | |
result.shadowOffsetY = value.shadowOffsetY; | |
} | |
return [ | |
new Instruction('shadowStyle', value), | |
children, | |
end | |
]; | |
}; | |
module.exports = shadowStyle; | |
/***/ }, | |
/* 46 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('restore'); | |
let skewX = (x, ...children) => [ | |
new Instruction('skewX', { x: Math.tan(x) }), | |
children, | |
end | |
]; | |
module.exports = skewX; | |
/***/ }, | |
/* 47 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('restore'); | |
let skewY = (x, ...children) => [ | |
new Instruction('skewY', { y: Math.tan(y) }), | |
children, | |
end | |
]; | |
module.exports = skewY; | |
/***/ }, | |
/* 48 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let cache = new Instruction('stroke'); | |
let stroke = () => cache; | |
module.exports = stroke; | |
/***/ }, | |
/* 49 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0), | |
pi2 = Math.PI * 2; | |
let strokeArc = (...args) => { | |
let [x, y, r, startAngle, endAngle, counterclockwise] = args; | |
let props = { x: 0, y: 0, r: x, startAngle: 0, endAngle: pi2, counterclockwise: false }; | |
if (args.length > 3) { | |
props.startAngle = startAngle; | |
props.endAngle = endAngle; | |
props.counterclockwise = !!counterclockwise; | |
} | |
if (args.length > 1){ | |
props.x = x; | |
props.y = y; | |
props.r = r; | |
} | |
return new Instruction("strokeArc", props); | |
}; | |
module.exports = strokeArc; | |
/***/ }, | |
/* 50 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let strokeRect = (...args) => new Instruction('strokeRect', | |
args.length > 2 ? | |
{ x: args[0], y: args[1], width: args[2], height: args[3] } : | |
{ x: 0, y: 0, width: args[0], height: args[1] } | |
); | |
module.exports = strokeRect; | |
/***/ }, | |
/* 51 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('endStrokeStyle'); | |
let strokeStyle = (value, ...children) => [ | |
new Instruction('strokeStyle', { value }), | |
children, | |
end | |
]; | |
module.exports = strokeStyle; | |
/***/ }, | |
/* 52 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let strokeText = (...args) => { | |
let [text, x, y, maxWidth] = args; | |
if (args.length < 4) { | |
maxWidth = null; | |
} | |
if (args.length < 3) { | |
x = 0; | |
y = 0; | |
} | |
return new Instruction('strokeText', { | |
text, | |
x, | |
y, | |
maxWidth | |
}); | |
}; | |
module.exports = strokeText; | |
/***/ }, | |
/* 53 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('endTextStyle'); | |
let textStyle = (value, ...children) => { | |
value = value || {}; | |
var result = { | |
font: null, | |
textAlign: null, | |
textBaseline: null, | |
direction: null | |
}; | |
if (typeof value.font !== 'undefined') { | |
result.font = value.font; | |
} | |
if (typeof value.textAlign !== 'undefined') { | |
result.textAlign = value.textAlign; | |
} | |
if (typeof value.textBaseline !== 'undefined') { | |
result.textBaseline = value.textBaseline; | |
} | |
if (typeof value.direction !== 'undefined') { | |
result.direction = value.direction; | |
} | |
return [ | |
new Instruction('textStyle', result), | |
children, | |
end | |
]; | |
}; | |
module.exports = textStyle; | |
/***/ }, | |
/* 54 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('restore'); | |
let transform = (values, ...children) => { | |
return [ | |
new Instruction('transform',[ | |
values[0], | |
values[1], | |
values[2], | |
values[3], | |
values[4], | |
values[5] | |
]), | |
children, | |
end | |
]; | |
}; | |
module.exports = transform; | |
/***/ }, | |
/* 55 */ | |
/***/ function(module, exports, __webpack_require__) { | |
let Instruction = __webpack_require__(0); | |
let end = new Instruction('restore'); | |
let translate = (x, y, ...children) => [ | |
new Instruction('translate', { x: x, y: y }), | |
children, | |
end | |
]; | |
module.exports = translate; | |
/***/ }, | |
/* 56 */ | |
/***/ function(module, exports) { | |
// Source: http://jsfiddle.net/vWx8V/ | |
// http://stackoverflow.com/questions/5603195/full-list-of-javascript-keycodes | |
/** | |
* Conenience method returns corresponding value for given keyName or keyCode. | |
* | |
* @param {Mixed} keyCode {Number} or keyName {String} | |
* @return {Mixed} | |
* @api public | |
*/ | |
exports = module.exports = function(searchInput) { | |
// Keyboard Events | |
if (searchInput && 'object' === typeof searchInput) { | |
var hasKeyCode = searchInput.which || searchInput.keyCode || searchInput.charCode | |
if (hasKeyCode) searchInput = hasKeyCode | |
} | |
// Numbers | |
if ('number' === typeof searchInput) return names[searchInput] | |
// Everything else (cast to string) | |
var search = String(searchInput) | |
// check codes | |
var foundNamedKey = codes[search.toLowerCase()] | |
if (foundNamedKey) return foundNamedKey | |
// check aliases | |
var foundNamedKey = aliases[search.toLowerCase()] | |
if (foundNamedKey) return foundNamedKey | |
// weird character? | |
if (search.length === 1) return search.charCodeAt(0) | |
return undefined | |
} | |
/** | |
* Get by name | |
* | |
* exports.code['enter'] // => 13 | |
*/ | |
var codes = exports.code = exports.codes = { | |
'backspace': 8, | |
'tab': 9, | |
'enter': 13, | |
'shift': 16, | |
'ctrl': 17, | |
'alt': 18, | |
'pause/break': 19, | |
'caps lock': 20, | |
'esc': 27, | |
'space': 32, | |
'page up': 33, | |
'page down': 34, | |
'end': 35, | |
'home': 36, | |
'left': 37, | |
'up': 38, | |
'right': 39, | |
'down': 40, | |
'insert': 45, | |
'delete': 46, | |
'command': 91, | |
'left command': 91, | |
'right command': 93, | |
'numpad *': 106, | |
'numpad +': 107, | |
'numpad -': 109, | |
'numpad .': 110, | |
'numpad /': 111, | |
'num lock': 144, | |
'scroll lock': 145, | |
'my computer': 182, | |
'my calculator': 183, | |
';': 186, | |
'=': 187, | |
',': 188, | |
'-': 189, | |
'.': 190, | |
'/': 191, | |
'`': 192, | |
'[': 219, | |
'\\': 220, | |
']': 221, | |
"'": 222 | |
} | |
// Helper aliases | |
var aliases = exports.aliases = { | |
'windows': 91, | |
'⇧': 16, | |
'⌥': 18, | |
'⌃': 17, | |
'⌘': 91, | |
'ctl': 17, | |
'control': 17, | |
'option': 18, | |
'pause': 19, | |
'break': 19, | |
'caps': 20, | |
'return': 13, | |
'escape': 27, | |
'spc': 32, | |
'pgup': 33, | |
'pgdn': 34, | |
'ins': 45, | |
'del': 46, | |
'cmd': 91 | |
} | |
/*! | |
* Programatically add the following | |
*/ | |
// lower case chars | |
for (i = 97; i < 123; i++) codes[String.fromCharCode(i)] = i - 32 | |
// numbers | |
for (var i = 48; i < 58; i++) codes[i - 48] = i | |
// function keys | |
for (i = 1; i < 13; i++) codes['f'+i] = i + 111 | |
// numpad keys | |
for (i = 0; i < 10; i++) codes['numpad '+i] = i + 96 | |
/** | |
* Get by code | |
* | |
* exports.name[13] // => 'Enter' | |
*/ | |
var names = exports.names = exports.title = {} // title for backward compat | |
// Create reverse mapping | |
for (i in codes) names[codes[i]] = i | |
// Add aliases | |
for (var alias in aliases) { | |
codes[alias] = aliases[alias] | |
} | |
/***/ }, | |
/* 57 */ | |
/***/ function(module, exports) { | |
module.exports = function (point, vs) { | |
// ray-casting algorithm based on | |
// http://www.ecse.rpi.edu/Homepages/wrf/Research/Short_Notes/pnpoly.html | |
var x = point[0], y = point[1]; | |
var inside = false; | |
for (var i = 0, j = vs.length - 1; i < vs.length; j = i++) { | |
var xi = vs[i][0], yi = vs[i][1]; | |
var xj = vs[j][0], yj = vs[j][1]; | |
var intersect = ((yi > y) != (yj > y)) | |
&& (x < (xj - xi) * (y - yi) / (yj - yi) + xi); | |
if (intersect) inside = !inside; | |
} | |
return inside; | |
}; | |
/***/ }, | |
/* 58 */ | |
/***/ function(module, exports, __webpack_require__) { | |
module.exports = { | |
'activeRegions': __webpack_require__(10), | |
'arc': __webpack_require__(11), | |
'arcTo': __webpack_require__(12), | |
'beginPath': __webpack_require__(2), | |
'bezierCurveTo': __webpack_require__(13), | |
'clearRect': __webpack_require__(14), | |
'clip': __webpack_require__(15), | |
'clipPath': __webpack_require__(16), | |
'closePath': __webpack_require__(3), | |
'createRegularPolygon': __webpack_require__(17), | |
'createWrapper': __webpack_require__(18), | |
'cycleMouseData': __webpack_require__(4), | |
'drawImage': __webpack_require__(19), | |
'ellipse': __webpack_require__(20), | |
'fill': __webpack_require__(21), | |
'fillArc': __webpack_require__(22), | |
'fillRect': __webpack_require__(23), | |
'fillStyle': __webpack_require__(24), | |
'fillText': __webpack_require__(25), | |
'globalAlpha': __webpack_require__(26), | |
'globalCompositeOperation': __webpack_require__(27), | |
'hitRect': __webpack_require__(28), | |
'hitRegion': __webpack_require__(29), | |
'imageSmoothingEnabled': __webpack_require__(30), | |
'initialize': __webpack_require__(31), | |
'Instruction': __webpack_require__(0), | |
'invertMatrix': __webpack_require__(5), | |
'keyData': __webpack_require__(32), | |
'lineStyle': __webpack_require__(33), | |
'lineTo': __webpack_require__(6), | |
'mouseData': __webpack_require__(34), | |
'moveTo': __webpack_require__(7), | |
'moveToLineTo': __webpack_require__(35), | |
'path': __webpack_require__(36), | |
'placeHolder': __webpack_require__(37), | |
'pointInRect': __webpack_require__(8), | |
'quadraticCurveTo': __webpack_require__(38), | |
'raf': __webpack_require__(39), | |
'rect': __webpack_require__(40), | |
'render': __webpack_require__(41), | |
'resetTransform': __webpack_require__(42), | |
'rotate': __webpack_require__(43), | |
'scale': __webpack_require__(44), | |
'setTransform': __webpack_require__(9), | |
'shadowStyle': __webpack_require__(45), | |
'skewX': __webpack_require__(46), | |
'skewY': __webpack_require__(47), | |
'stroke': __webpack_require__(48), | |
'strokeArc': __webpack_require__(49), | |
'strokeRect': __webpack_require__(50), | |
'strokeStyle': __webpack_require__(51), | |
'strokeText': __webpack_require__(52), | |
'textStyle': __webpack_require__(53), | |
'transform': __webpack_require__(54), | |
'transformPoints': __webpack_require__(1), | |
'translate': __webpack_require__(55) | |
}; | |
/***/ } | |
/******/ ]); | |
}); | |
},{}]},{},[]) | |
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/browser-pack/_prelude.js","e2d"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"e2d\"] = factory();\n\telse\n\t\troot[\"e2d\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n\n\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 58);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ function(module, exports) {\n\nclass Instruction {\r\n  constructor(type, props) {\r\n    this.type = type;\r\n    this.props = props;\r\n    return Object.seal(this);\r\n  }\r\n}\r\n\r\nObject.seal(Instruction);\r\nObject.seal(Instruction.prototype);\r\n\r\nmodule.exports = Instruction;\r\n\n\n/***/ },\n/* 1 */\n/***/ function(module, exports) {\n\nlet transformPoints = (points, matrix) => {\r\n  let result = [],\r\n      x, y;\r\n\r\n  for(let i = 0; i < points.length; i++) {\r\n    [x, y] = points[i];\r\n    result.push([\r\n      matrix[0] * x + matrix[2] * y + matrix[4],\r\n      matrix[1] * x + matrix[3] * y + matrix[5]\r\n    ]);\r\n  }\r\n  return result;\r\n};\r\n\r\nmodule.exports = transformPoints;\r\n\n\n/***/ },\n/* 2 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0),\r\n  cache = new Instruction('beginPath');\r\n\r\nlet beginPath = () => cache;\r\n\r\nmodule.exports = beginPath;\n\n/***/ },\n/* 3 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet cache = new Instruction('closePath');\r\n\r\nlet closePath = () => cache;\r\n\r\nmodule.exports = closePath;\r\n\n\n/***/ },\n/* 4 */\n/***/ function(module, exports) {\n\n\r\nlet cycleMouseData = (ctx) => {\r\n  let mouseData = ctx.canvas[Symbol.for('mouseData')];\r\n  if (mouseData) {\r\n    mouseData.dx = mouseData.x - mouseData.previousX;\r\n    mouseData.dy = mouseData.y - mouseData.previousY;\r\n\r\n    mouseData.previousX = mouseData.x;\r\n    mouseData.previousY = mouseData.y;\r\n\r\n    mouseData.clicked = 0;\r\n  }\r\n};\r\n\r\nmodule.exports = cycleMouseData;\n\n/***/ },\n/* 5 */\n/***/ function(module, exports) {\n\nlet det = 0;\r\nlet invertMatrix = ([a, b, c, d, e, f]) => (\r\n  det = 1 / (a * d - c * b),\r\n  [\r\n    d * det,\r\n    -c * det,\r\n    -b * det,\r\n    a * det,\r\n    (b * f - e * d) * det,\r\n    (e * b - a * f) * det\r\n  ]\r\n);\r\n module.exports = invertMatrix;\n\n/***/ },\n/* 6 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet lineTo = (x, y) => new Instruction('lineTo', { x, y });\r\n\r\nmodule.exports = lineTo;\r\n\n\n/***/ },\n/* 7 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet moveTo = (x, y) => new Instruction('moveTo', { x, y });\r\n\r\nmodule.exports = moveTo;\r\n\n\n/***/ },\n/* 8 */\n/***/ function(module, exports) {\n\nlet pointInRect = ([px, py], [[x, y], [width, height]]) => px > x && py > y && px < width && py < height;\r\n\r\nmodule.exports = pointInRect;\n\n/***/ },\n/* 9 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('restore');\r\n\r\nlet setTransform = (matrix, ...children) => [\r\n  new Instruction('setTransform', [\r\n    matrix[0],\r\n    matrix[1],\r\n    matrix[2],\r\n    matrix[3],\r\n    matrix[4],\r\n    matrix[5]\r\n  ]),\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = setTransform;\n\n/***/ },\n/* 10 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet pointInPolygon = __webpack_require__(57);\r\nlet transformPoints = __webpack_require__(1);\r\nlet invertMatrix = __webpack_require__(5);\r\nlet pointInRect = __webpack_require__(8);\r\n\r\nlet matrix = new Float64Array(6);\r\n\r\nmodule.exports = (ctx) => {\r\n  let regions = ctx.canvas[Symbol.for('regions')],\r\n    mousePoints = ctx.canvas[Symbol.for('mousePoints')],\r\n    mouseData = ctx.canvas[Symbol.for('mouseData')],\r\n    results = {};\r\n\r\n  //the mouse might have held still, add the current mouse position\r\n  if (mousePoints.length === 0) {\r\n    mousePoints.push([mouseData.x, mouseData.y, mouseData.state]);\r\n  }\r\n\r\n  for(let region of regions) {\r\n\r\n    //invert the region matrix and transform the mouse points\r\n    let transformedMousePoints = transformPoints(mousePoints, invertMatrix(region.matrix));\r\n    //the mouse points are now relative to the mouse region\r\n\r\n    if (!region.polygon) {\r\n      for (let mousePoint of transformedMousePoints) {\r\n        if (pointInRect(mousePoint, region.points)) {\r\n          region.hover = true;\r\n          region.clicked = !!mouseData.clicked;\r\n          results[region.id] = region;\r\n          break;\r\n        }\r\n      }\r\n      continue;\r\n    }\r\n\r\n    //loop over each point until one is matched\r\n    for(let mousePoint of transformedMousePoints) {\r\n      if (pointInPolygon(mousePoint, region.points)) {\r\n        region.hover = true;\r\n        region.clicked = !!mouseData.clicked;\r\n        results[region.id] = region;\r\n        break;\r\n      }\r\n    }\r\n  }\r\n  return results;\r\n};\n\n/***/ },\n/* 11 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0),\r\n    pi2 = Math.PI * 2;\r\n\r\nlet arc = (...args) => {\r\n  let  [x, y, r, startAngle, endAngle, counterclockwise] = args;\r\n  let props = { x: 0, y: 0, r: x, startAngle: 0, endAngle: pi2, counterclockwise: false };\r\n\r\n\r\n  if (args.length > 3) {\r\n    props.startAngle = startAngle;\r\n    props.endAngle = endAngle;\r\n    props.counterclockwise = !!counterclockwise;\r\n  }\r\n\r\n  if (args.length > 1){\r\n    props.x = x;\r\n    props.y = y;\r\n    props.r = r;\r\n  }\r\n\r\n  return new Instruction(\"arc\",  props);\r\n};\r\n\r\nmodule.exports = arc;\r\n\n\n/***/ },\n/* 12 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet arcTo = (x1, y1, x2, y2, r) => new Instruction('arcTo', { x1, y1, x2, y2, r });\r\n\r\nmodule.exports = arcTo;\r\n\n\n/***/ },\n/* 13 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet bezierCurveTo = (cp1x, cp1y, cp2x, cp2y, x, y) => new Instruction('bezierCurveTo', {\r\n  cp1x,\r\n  cp1y,\r\n  cp2x,\r\n  cp2y,\r\n  x,\r\n  y\r\n});\r\n\r\n\r\nmodule.exports = bezierCurveTo;\r\n\n\n/***/ },\n/* 14 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet clearRect = (...args) => new Instruction('clearRect',\r\n  args.length > 2 ?\r\n    { x: args[0], y: args[1], width: args[2], height: args[3] } :\r\n    { x: 0, y: 0, width: args[0], height: args[1] }\r\n);\r\n\r\n\r\nmodule.exports = clearRect;\r\n\n\n/***/ },\n/* 15 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet begin = new Instruction('beginClip'),\r\n  performClip = new Instruction('clip'),\r\n  end = new Instruction('endClip');\r\n\r\nlet clip = (path, ...children) => [\r\n  begin,\r\n  path,\r\n  performClip,\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = clip;\r\n\n\n/***/ },\n/* 16 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet cache = new Instruction('clipPath');\r\n\r\nlet clipPath = () => cache;\r\n\r\nmodule.exports = clipPath;\r\n\n\n/***/ },\n/* 17 */\n/***/ function(module, exports) {\n\nlet createRegularPolygon = (radius = 0, position = [0, 0], sides = 3) => {\r\n  let polygon = [];\r\n  for(let i = 0; i < sides; i++) {\r\n    polygon.push([\r\n      position[0] + radius * Math.cos(Math.PI * 2 * i / sides),\r\n      position[1] + radius * Math.sin(Math.PI * 2 * i / sides)\r\n    ]);\r\n  }\r\n  return polygon;\r\n};\r\n\r\nmodule.exports = createRegularPolygon;\r\n\n\n/***/ },\n/* 18 */\n/***/ function(module, exports) {\n\nlet concat = [].concat;\r\n\r\nlet createWrapper = (...args) => {\r\n  for(let i = 0; i < args.length; i++) {\r\n    //parse and flatten the arguments\r\n    while (args[i] && args[i].constructor === Array) {\r\n      args = concat.apply([], args).filter(Boolean);\r\n    }\r\n\r\n    if (!args[i]) {\r\n      continue;\r\n    }\r\n\r\n    let { type } = args[i];\r\n    if (type === 'placeholder') {\r\n      // i is set to the placeholder index now\r\n\r\n      //now grab all the elements to the left of the placeHolder\r\n      let left = args.splice(0, i);\r\n\r\n      //remove the placeHolder from the array\r\n      args.shift();\r\n\r\n      return (...children) => [left, children, args];\r\n    }\r\n  }\r\n\r\n  throw new Error('Could not find placeholder, did you forget the e2d.placeHolder() call?');\r\n};\r\n\r\nmodule.exports = concat;\r\n\n\n/***/ },\n/* 19 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet drawImage = (...args) => {\r\n  let [img, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight] = args;\r\n\r\n  if (args.length === 9) {\r\n    return new Instruction('drawImageSource', {\r\n      img,\r\n      sx,\r\n      sy,\r\n      sWidth,\r\n      sHeight,\r\n      dx,\r\n      dy,\r\n      dWidth,\r\n      dHeight\r\n    });\r\n  }\r\n\r\n  if (args.length >= 5) {\r\n    return new Instruction('drawImageSize', {\r\n      img,\r\n      dx: sx,\r\n      dy: sy,\r\n      dWidth: sWidth,\r\n      dHeight: sHeight\r\n    });\r\n  }\r\n\r\n  if (args.length >= 3) {\r\n    return new Instruction('drawImage', {\r\n      img,\r\n      dx: sx,\r\n      dy: sy\r\n    });\r\n  }\r\n\r\n  return new Instruction('drawImage', {\r\n    img,\r\n    dx: 0,\r\n    dy: 0\r\n  });\r\n};\r\n\r\nmodule.exports = drawImage;\r\n\n\n/***/ },\n/* 20 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0),\r\n    pi2 = Math.PI * 2;\r\n\r\nlet ellipse = (...args) => {\r\n  let [x, y, radiusX, radiusY, rotation, startAngle, endAngle, anticlockwise] = args;\r\n\r\n  let props = { x: 0, y: 0, radiusX: x, radiusY: y, rotation: 0, startAngle: 0, endAngle: pi2, anticlockwise: false };\r\n\r\n  if (args.length > 5) {\r\n    props.startAngle = startAngle;\r\n    props.endAngle = endAngle;\r\n    props.anticlockwise = !!anticlockwise;\r\n  }\r\n\r\n  if (args.length > 4) {\r\n    props.rotation = rotation;\r\n  }\r\n\r\n  if (args.length > 2){\r\n    props.x = x;\r\n    props.y = y;\r\n    props.radiusX = radiusX;\r\n    props.radiusY = radiusY;\r\n  }\r\n\r\n  return new Instruction(\"ellipse\",  props);\r\n};\r\n\r\nmodule.exports = ellipse;\r\n\n\n/***/ },\n/* 21 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet cache = new Instruction('fill');\r\n\r\nlet fill = () => cache;\r\n\r\nmodule.exports = fill;\r\n\n\n/***/ },\n/* 22 */\n/***/ function(module, exports, __webpack_require__) {\n\n\r\n\r\nlet Instruction = __webpack_require__(0),\r\n    pi2 = Math.PI * 2;\r\n\r\nlet fillArc = (...args) => {\r\n  let [x, y, r, startAngle, endAngle, counterclockwise] = args;\r\n  let props = { x: 0, y: 0, r: x, startAngle: 0, endAngle: pi2, counterclockwise: false };\r\n\r\n\r\n  if (args.length > 3) {\r\n    props.startAngle = startAngle;\r\n    props.endAngle = endAngle;\r\n    props.counterclockwise = !!counterclockwise;\r\n  }\r\n\r\n  if (args.length >= 2) {\r\n    props.x = x;\r\n    props.y = y;\r\n    props.r = r;\r\n  }\r\n\r\n  return new Instruction(\"fillArc\",  props);\r\n};\r\n\r\nmodule.exports = fillArc;\r\n\n\n/***/ },\n/* 23 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet fillRect = (...args) => new Instruction('fillRect',\r\n  args.length > 2 ?\r\n    { x: args[0], y: args[1], width: args[2], height: args[3] } :\r\n    { x: 0, y: 0, width: args[0], height: args[1] }\r\n);\r\n\r\nmodule.exports = fillRect;\r\n\n\n/***/ },\n/* 24 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('endFillStyle');\r\n\r\nlet fillStyle = (value, ...children) => [\r\n    new Instruction('fillStyle', { value }),\r\n    children,\r\n    end\r\n];\r\n\r\nmodule.exports = fillStyle;\r\n\n\n/***/ },\n/* 25 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet fillText = (...args) => {\r\n  let [text, x, y, maxWidth] = args;\r\n  if (args.length < 4) {\r\n    maxWidth = null;\r\n  }\r\n  if (args.length < 3) {\r\n    x = 0;\r\n    y = 0;\r\n  }\r\n  return new Instruction('fillText', { text, x, y, maxWidth });\r\n};\r\n\r\nmodule.exports = fillText;\n\n/***/ },\n/* 26 */\n/***/ function(module, exports, __webpack_require__) {\n\n\r\n\r\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('endGlobalAlpha');\r\n\r\nlet globalAlpha = (value, ...children) => [\r\n  new Instruction('globalAlpha', { value }),\r\n  children,\r\n  end\r\n];\r\nmodule.exports = globalAlpha;\r\n\n\n/***/ },\n/* 27 */\n/***/ function(module, exports, __webpack_require__) {\n\n\r\n\r\nvar Instruction = __webpack_require__(0);\r\n\r\nlet end = new Instruction('endGlobalCompositeOperation');\r\n\r\nlet globalCompositeOperation = (value, ...children) => [\r\n  new Instruction('globalCompositeOperation', { value }),\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = globalCompositeOperation;\r\n\n\n/***/ },\n/* 28 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet hitRect = (id, ...args) => {\r\n  let [x, y, width, height] = args;\r\n  if (args.length <= 3) {\r\n    width = x;\r\n    height = y;\r\n    x = 0;\r\n    y = 0;\r\n  }\r\n  return new Instruction('hitRect', {\r\n    id,\r\n    points: [\r\n      [x, y],\r\n      [x + width, y + height]\r\n    ]\r\n  });\r\n};\r\n\r\nmodule.exports = hitRect;\n\n/***/ },\n/* 29 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet hitRegion = (id, points) => new Instruction('hitRegion', { id, points });\r\n\r\nmodule.exports = hitRegion;\r\n\n\n/***/ },\n/* 30 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('endImageSmoothingEnabled');\r\n\r\nlet imageSmoothingEnabled = (value, ...children) => [\r\n  new Instruction('imageSmoothingEnabled', { value }),\r\n  children,\r\n  end\r\n];\r\nmodule.exports = imageSmoothingEnabled;\r\n\n\n/***/ },\n/* 31 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet keycode = __webpack_require__(56);\r\n\r\nmodule.exports = (ctx) => {\r\n  let { canvas } = ctx;\r\n\r\n  //mouseData\r\n  canvas[Symbol.for('mouseData')] = {\r\n    x: 0,\r\n    y: 0,\r\n    dx: 0,\r\n    dy: 0,\r\n    previousX: 0,\r\n    previousY: 0,\r\n    state: false,\r\n    clicked: 0\r\n  };\r\n\r\n  let keys = canvas[Symbol.for('keyData')] = {};\r\n\r\n  for (let name in keycode.code) {\r\n    if (keycode.code.hasOwnProperty(name)) {\r\n      keys[name] = false;\r\n    }\r\n  }\r\n\r\n  //mouse regions\r\n  canvas[Symbol.for('regions')] = [];\r\n  canvas[Symbol.for('mousePoints')] = [];\r\n\r\n  //make the canvas receive touch and mouse events\r\n  canvas.tabIndex = 1;\r\n\r\n  let mouseMove = (evt) => {\r\n    let { clientX, clientY } = evt;\r\n    //get left and top coordinates\r\n    let { left, top } = canvas.getBoundingClientRect();\r\n\r\n    let mouseData = canvas[Symbol.for('mouseData')];\r\n\r\n    let point = [clientX - left, clientY - top, mouseData.state];\r\n\r\n    mouseData.x = point[0];\r\n    mouseData.y = point[1];\r\n\r\n    let points = canvas[Symbol.for('mousePoints')];\r\n\r\n    points.push(point);\r\n\r\n    //store the last 100 stored positions for hover detection\r\n    if (points.length > 100) {\r\n      points.splice(0, points.length - 100);\r\n    }\r\n\r\n    evt.preventDefault();\r\n    return false;\r\n  };\r\n\r\n  canvas.addEventListener('mousemove', (evt) => mouseMove(evt));\r\n  canvas.addEventListener('mousedown', (evt) => {\r\n    let { target } = evt;\r\n    if (target === canvas) {\r\n      let mouseData = canvas[Symbol.for('mouseData')];\r\n\r\n      if (!mouseData.state) {\r\n        mouseData.clicked += 1;\r\n      }\r\n\r\n      mouseData.state = true;\r\n      return mouseMove(evt);\r\n    }\r\n  });\r\n  canvas.addEventListener('mouseup', (evt) => {\r\n    let mouseData = canvas[Symbol.for('mouseData')];\r\n    mouseData.state = false;\r\n    return mouseMove(evt);\r\n  });\r\n  canvas.addEventListener('keydown', (evt) => {\r\n    canvas[Symbol.for('keyData')][keycode(evt.keyCode)] = true;\r\n    evt.preventDefault();\r\n    return false;\r\n  });\r\n  canvas.addEventListener('keyup', (evt) => {\r\n    canvas[Symbol.for('keyData')][keycode(evt.keyCode)] = false;\r\n    evt.preventDefault();\r\n    return false;\r\n  });\r\n};\n\n/***/ },\n/* 32 */\n/***/ function(module, exports) {\n\nmodule.exports = (ctx) => ctx.canvas[Symbol.for('keyData')];\n\n/***/ },\n/* 33 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('endLineStyle');\r\n\r\nlet lineStyle = (value, ...children) => {\r\n\r\n  value = value || {};\r\n  var result = {\r\n    lineWidth: null,\r\n    lineCap: null,\r\n    lineJoin: null,\r\n    miterLimit: null,\r\n    lineDash: null,\r\n    lineDashOffset: null\r\n  };\r\n\r\n  if (typeof value.lineWidth !== 'undefined') {\r\n    result.lineWidth = value.lineWidth;\r\n  }\r\n  if (typeof value.lineCap !== 'undefined') {\r\n    result.lineCap = value.lineCap;\r\n  }\r\n  if (typeof value.lineJoin !== 'undefined') {\r\n    result.lineJoin = value.lineJoin;\r\n  }\r\n  if (typeof value.miterLimit !== 'undefined') {\r\n    result.miterLimit = value.miterLimit;\r\n  }\r\n  if (typeof value.lineDash !== 'undefined') {\r\n    result.lineDash = value.lineDash || [];\r\n  }\r\n  if (typeof value.lineDashOffset !== 'undefined') {\r\n    result.lineDashOffset = value.lineDashOffset;\r\n  }\r\n  return [\r\n    new Instruction('lineStyle', result),\r\n    children,\r\n    end\r\n  ];\r\n};\r\n\r\nmodule.exports = lineStyle;\r\n\n\n/***/ },\n/* 34 */\n/***/ function(module, exports) {\n\nmodule.exports = (ctx) => ctx.canvas[Symbol.for('mouseData')];\n\n/***/ },\n/* 35 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet moveTo = __webpack_require__(7), lineTo = __webpack_require__(6);\r\n\r\nlet moveToLineTo = (point, index) => index === 0 ?\r\n  moveTo(point[0], point[1]) :\r\n  lineTo(point[0], point[1]);\r\n\r\nmodule.exports = moveToLineTo;\r\n\n\n/***/ },\n/* 36 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet beginPath = __webpack_require__(2)(),\r\n    closePath = __webpack_require__(3)();\r\n\r\nlet path = (...children) => [\r\n  beginPath,\r\n  children,\r\n  closePath\r\n];\r\n\r\nmodule.exports = path;\r\n\n\n/***/ },\n/* 37 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet cache = new Instruction('placeholder');\r\nlet placeHolder = () => cache;\r\n\r\nmodule.exports = placeHolder;\r\n\n\n/***/ },\n/* 38 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet quadraticCurveTo = (cpx, cpy, x, y) => new Instruction('quadraticCurveTo', {\r\n  cpx,\r\n  cpy,\r\n  x,\r\n  y\r\n});\r\n\r\nmodule.exports = quadraticCurveTo;\r\n\n\n/***/ },\n/* 39 */\n/***/ function(module, exports) {\n\nlet raf = (func) => {\r\n  requestAnimationFrame(() => raf(func));\r\n  return func();\r\n};\r\n\r\nmodule.exports = raf;\n\n/***/ },\n/* 40 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet rect = (...args) => new Instruction('rect',\r\n  args.length > 2 ?\r\n    { x: args[0], y: args[1], width: args[2], height: args[3] } :\r\n    { x: 0, y: 0, width: args[0], height: args[1] }\r\n);\r\n\r\nmodule.exports = rect;\r\n\n\n/***/ },\n/* 41 */\n/***/ function(module, exports, __webpack_require__) {\n\n\r\n//initialize all the properties\r\n\r\nlet identity = [1, 0, 0, 1, 0, 0],\r\n  matrix = new Float64Array(identity),\r\n  fillStyleStack = [],\r\n  strokeStyleStack = [],\r\n  lineStyleStack = [],\r\n  textStyleStack = [],\r\n  shadowStyleStack = [],\r\n  globalCompositeOperationStack = [],\r\n  globalAlphaStack = [],\r\n  imageSmoothingEnabledStack = [],\r\n  transformStack = new Float64Array(501 * 6),\r\n  transformStackIndex = 6,\r\n  concat = [].concat,\r\n  supportsEllipse = false;\r\n\r\nif (typeof CanvasRenderingContext2D !== 'undefined') {\r\n  supportsEllipse = CanvasRenderingContext2D.prototype.hasOwnProperty('ellipse');\r\n}\r\n\r\n//transform points function\r\nconst transformPoints = __webpack_require__(1);\r\nconst cycleMouseData = __webpack_require__(4);\r\n\r\nconst increaseTransformStackSize = () => {\r\n  let cache = transformStack;\r\n  transformStack = new Float64Array(transformStack.length + 600); //add 100 more\r\n  transformStack.set(cache);\r\n  return this;\r\n};\r\n\r\ntransformStack.set(identity);\r\n\r\nconst PI2 = Math.PI * 2;\r\n\r\nlet empty = (target) => target && target.splice(0, target.length);\r\n\r\nmodule.exports = (...args) => {\r\n  let children = args.slice(0, -1),\r\n   ctx = args[args.length - 1];\r\n\r\n  let regions = ctx.canvas[Symbol.for('regions')],\r\n    mousePoints = ctx.canvas[Symbol.for('mousePoints')],\r\n    extensions = ctx.canvas[Symbol.for('extensions')];\r\n\r\n  let cache;\r\n\r\n  cycleMouseData(ctx);\r\n\r\n  empty(regions);\r\n  empty(mousePoints);\r\n\r\n  let len = children.length;\r\n\r\n  //flatten children during the loop process to save cpu\r\n  for (let i = 0; i < len; i++) {\r\n    let child = children[i];\r\n\r\n    //flattening algorithm\r\n    if (child && child.constructor === Array) {\r\n      children = concat.apply([], children);\r\n      child = children[i];\r\n\r\n      //repeat as necessary\r\n      while (child && child.constructor === Array) {\r\n        children = concat.apply([], children);\r\n        child = children[i];\r\n      }\r\n\r\n      len = children.length;\r\n    }\r\n\r\n    //child must be truthy\r\n    if (!child) {\r\n      continue;\r\n    }\r\n\r\n    let { props, type } = child;\r\n\r\n    if (type === 'transform') {\r\n\r\n      //copy transformStack values to matrix\r\n      matrix[0] = transformStack[transformStackIndex - 6];\r\n      matrix[1] = transformStack[transformStackIndex - 5];\r\n      matrix[2] = transformStack[transformStackIndex - 4];\r\n      matrix[3] = transformStack[transformStackIndex - 3];\r\n      matrix[4] = transformStack[transformStackIndex - 2];\r\n      matrix[5] = transformStack[transformStackIndex - 1];\r\n\r\n      //increase the index\r\n      transformStackIndex += 6;\r\n      if (transformStackIndex > transformStack.length) {\r\n        increaseTransformStackSize();\r\n      }\r\n\r\n      //perform the transform math\r\n      transformStack[transformStackIndex - 6] = //d\r\n        matrix[0] * props[0] + matrix[2] * props[1];\r\n      transformStack[transformStackIndex - 5] = //b\r\n        matrix[1] * props[0] + matrix[3] * props[1];\r\n      transformStack[transformStackIndex - 4] = //c\r\n        matrix[0] * props[2] + matrix[2] * props[3];\r\n      transformStack[transformStackIndex - 3] = //d\r\n        matrix[1] * props[2] + matrix[3] * props[3];\r\n      transformStack[transformStackIndex - 2] = //e\r\n        matrix[0] * props[4] + matrix[2] * props[5] + matrix[4];\r\n      transformStack[transformStackIndex - 1] = //f\r\n        matrix[1] * props[4] + matrix[3] * props[5] + matrix[5];\r\n\r\n      //modify the ctx\r\n      ctx.setTransform(\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      );\r\n      continue;\r\n    }\r\n\r\n    if (type === 'setTransform') {\r\n      transformStackIndex += 6;\r\n      if (transformStackIndex > transformStack.length) {\r\n        increaseTransformStackSize();\r\n      }\r\n\r\n      transformStack[transformStackIndex - 6] = props[0];//a\r\n      transformStack[transformStackIndex - 5] = props[1];//b\r\n      transformStack[transformStackIndex - 4] = props[2];//c\r\n      transformStack[transformStackIndex - 3] = props[3];//d\r\n      transformStack[transformStackIndex - 2] = props[4];//e\r\n      transformStack[transformStackIndex - 1] = props[5];//f\r\n      ctx.setTransform(props[0], props[1], props[2], props[3], props[4], props[5]);\r\n\r\n      continue;\r\n    }\r\n\r\n    if (type === 'scale') {\r\n      matrix[0] = transformStack[transformStackIndex - 6];\r\n      matrix[1] = transformStack[transformStackIndex - 5];\r\n      matrix[2] = transformStack[transformStackIndex - 4];\r\n      matrix[3] = transformStack[transformStackIndex - 3];\r\n      matrix[4] = transformStack[transformStackIndex - 2];\r\n      matrix[5] = transformStack[transformStackIndex - 1];\r\n\r\n      transformStackIndex += 6;\r\n      if (transformStackIndex > transformStack.length) {\r\n        increaseTransformStackSize();\r\n      }\r\n\r\n      transformStack[transformStackIndex - 6] = matrix[0] * props.x; //a\r\n      transformStack[transformStackIndex - 5] = matrix[1] * props.x; //b\r\n      transformStack[transformStackIndex - 4] = matrix[2] * props.y; //c\r\n      transformStack[transformStackIndex - 3] = matrix[3] * props.y; //d\r\n      transformStack[transformStackIndex - 2] = matrix[4]; //e\r\n      transformStack[transformStackIndex - 1] = matrix[5]; //f\r\n\r\n      ctx.setTransform(\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      );\r\n\r\n      continue;\r\n    }\r\n\r\n    if (type === 'translate') {\r\n      matrix[0] = transformStack[transformStackIndex - 6];\r\n      matrix[1] = transformStack[transformStackIndex - 5];\r\n      matrix[2] = transformStack[transformStackIndex - 4];\r\n      matrix[3] = transformStack[transformStackIndex - 3];\r\n      matrix[4] = transformStack[transformStackIndex - 2];\r\n      matrix[5] = transformStack[transformStackIndex - 1];\r\n\r\n      transformStackIndex += 6;\r\n      if (transformStackIndex > transformStack.length) {\r\n        increaseTransformStackSize();\r\n      }\r\n\r\n      transformStack[transformStackIndex - 6] = matrix[0]; //a\r\n      transformStack[transformStackIndex - 5] = matrix[1]; //b\r\n      transformStack[transformStackIndex - 4] = matrix[2]; //c\r\n      transformStack[transformStackIndex - 3] = matrix[3]; //d\r\n      transformStack[transformStackIndex - 2] = matrix[4] + matrix[0] * props.x + matrix[2] * props.y; //e\r\n      transformStack[transformStackIndex - 1] = matrix[5] + matrix[1] * props.x + matrix[3] * props.y; //f\r\n\r\n      ctx.setTransform(\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      );\r\n      continue;\r\n    }\r\n\r\n    if (type === 'rotate') {\r\n      matrix[0] = transformStack[transformStackIndex - 6];\r\n      matrix[1] = transformStack[transformStackIndex - 5];\r\n      matrix[2] = transformStack[transformStackIndex - 4];\r\n      matrix[3] = transformStack[transformStackIndex - 3];\r\n      matrix[4] = transformStack[transformStackIndex - 2];\r\n      matrix[5] = transformStack[transformStackIndex - 1];\r\n\r\n      transformStackIndex += 6;\r\n      if (transformStackIndex > transformStack.length) {\r\n        increaseTransformStackSize();\r\n      }\r\n\r\n      transformStack[transformStackIndex - 6] =\r\n        matrix[0] * props.cos + matrix[2] * props.sin; //a\r\n      transformStack[transformStackIndex - 5] =\r\n        matrix[1] * props.cos + matrix[3] * props.sin; //b\r\n      transformStack[transformStackIndex - 4] =\r\n        matrix[0] * -props.sin + matrix[2] * props.cos; //c\r\n      transformStack[transformStackIndex - 3] =\r\n        matrix[1] * -props.sin + matrix[3] * props.cos; //d\r\n      transformStack[transformStackIndex - 2] = matrix[4]; //e\r\n      transformStack[transformStackIndex - 1] = matrix[5];//f\r\n\r\n      ctx.setTransform(\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      );\r\n      continue;\r\n    }\r\n\r\n    if (type === 'skewX') {\r\n      matrix[0] = transformStack[transformStackIndex - 6];\r\n      matrix[1] = transformStack[transformStackIndex - 5];\r\n      matrix[2] = transformStack[transformStackIndex - 4];\r\n      matrix[3] = transformStack[transformStackIndex - 3];\r\n      matrix[4] = transformStack[transformStackIndex - 2];\r\n      matrix[5] = transformStack[transformStackIndex - 1];\r\n\r\n      transformStackIndex += 6;\r\n      if (transformStackIndex > transformStack.length) {\r\n        increaseTransformStackSize();\r\n      }\r\n\r\n      transformStack[transformStackIndex - 6] = matrix[0]; //a\r\n      transformStack[transformStackIndex - 5] = matrix[1]; //b\r\n      transformStack[transformStackIndex - 4] = //c\r\n        matrix[0] * props.x + matrix[2];\r\n      transformStack[transformStackIndex - 3] = //d\r\n        matrix[1] * props.x + matrix[3];\r\n      transformStack[transformStackIndex - 2] = matrix[4]; //e\r\n      transformStack[transformStackIndex - 1] = matrix[5]; //f\r\n\r\n\r\n      ctx.setTransform(\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      );\r\n      continue;\r\n    }\r\n\r\n    if (type === 'skewY') {\r\n      matrix[0] = transformStack[transformStackIndex - 6];\r\n      matrix[1] = transformStack[transformStackIndex - 5];\r\n      matrix[2] = transformStack[transformStackIndex - 4];\r\n      matrix[3] = transformStack[transformStackIndex - 3];\r\n      matrix[4] = transformStack[transformStackIndex - 2];\r\n      matrix[5] = transformStack[transformStackIndex - 1];\r\n\r\n      transformStackIndex += 6;\r\n      if (transformStackIndex > transformStack.length) {\r\n        increaseTransformStackSize();\r\n      }\r\n\r\n      transformStack[transformStackIndex - 6] =\r\n        matrix[0] * 1 + matrix[2] * props.y; //a\r\n      transformStack[transformStackIndex - 5] =\r\n        matrix[1] * 1 + matrix[3] * props.y; //b\r\n      transformStack[transformStackIndex - 4] = matrix[2]; //c\r\n      transformStack[transformStackIndex - 3] = matrix[3]; //d\r\n\r\n      transformStack[transformStackIndex - 2] = matrix[4]; //e\r\n      transformStack[transformStackIndex - 1] = matrix[5]; //f\r\n\r\n      ctx.setTransform(\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      );\r\n      continue;\r\n    }\r\n\r\n    if (type === 'restore') {\r\n      transformStackIndex -= 6;\r\n      matrix[0] = transformStack[transformStackIndex - 6];\r\n      matrix[1] = transformStack[transformStackIndex - 5];\r\n      matrix[2] = transformStack[transformStackIndex - 4];\r\n      matrix[3] = transformStack[transformStackIndex - 3];\r\n      matrix[4] = transformStack[transformStackIndex - 2];\r\n      matrix[5] = transformStack[transformStackIndex - 1];\r\n\r\n      ctx.setTransform(matrix[0], matrix[1], matrix[2], matrix[3], matrix[4], matrix[5]);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'fillRect') {\r\n      ctx.fillRect(props.x, props.y, props.width, props.height);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'strokeRect') {\r\n      ctx.strokeRect(props.x, props.y, props.width, props.height);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'clearRect') {\r\n      ctx.clearRect(props.x, props.y, props.width, props.height);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'rect') {\r\n      ctx.rect(props.x, props.y, props.width, props.height);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'fillStyle') {\r\n      fillStyleStack.push(ctx.fillStyle);\r\n      ctx.fillStyle = props.value;\r\n      continue;\r\n    }\r\n\r\n    if (type === 'strokeStyle') {\r\n      strokeStyleStack.push(ctx.strokeStyle);\r\n      ctx.strokeStyle = props.value;\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endFillStyle') {\r\n      ctx.fillStyle = fillStyleStack.pop();\r\n\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endStrokeStyle') {\r\n      ctx.strokeStyle = strokeStyleStack.pop();\r\n      continue;\r\n    }\r\n    if (type === 'lineStyle') {\r\n      lineStyleStack.push({\r\n        lineWidth: ctx.lineWidth,\r\n        lineCap: ctx.lineCap,\r\n        lineJoin: ctx.lineJoin,\r\n        miterLimit: ctx.miterLimit,\r\n        lineDash: ctx.getLineDash(),\r\n        lineDashOffset: ctx.lineDashOffset\r\n      });\r\n\r\n      if (props.lineWidth !== null) {\r\n        ctx.lineWidth = props.lineWidth;\r\n      }\r\n      if (props.lineCap !== null) {\r\n        ctx.lineCap = props.lineCap;\r\n      }\r\n      if (props.lineJoin !== null) {\r\n        ctx.lineJoin = props.lineJoin;\r\n      }\r\n      if (props.miterLimit !== null) {\r\n        ctx.miterLimit = props.miterLimit;\r\n      }\r\n      if (props.lineDash !== null) {\r\n        ctx.setLineDash(props.lineDash);\r\n      }\r\n\r\n      if (props.lineDashOffset !== null) {\r\n        ctx.lineDashOffset = props.lineDashOffset;\r\n      }\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endLineStyle') {\r\n      cache = lineStyleStack.pop();\r\n      ctx.lineWidth = cache.lineWidth;\r\n      ctx.lineCap = cache.lineCap;\r\n      ctx.lineJoin = cache.lineJoin;\r\n      ctx.miterLimit = cache.miterLimit;\r\n      ctx.setLineDash(cache.lineDash);\r\n      ctx.lineDashOffset = cache.lineDashOffset;\r\n      continue;\r\n    }\r\n\r\n    if (type === 'textStyle') {\r\n      textStyleStack.push({\r\n        font: ctx.font,\r\n        textAlign: ctx.textAlign,\r\n        textBaseline: ctx.textBaseline,\r\n        direction: ctx.direction\r\n      });\r\n      if (props.font !== null) {\r\n        ctx.font = props.font;\r\n      }\r\n      if (props.textAlign !== null) {\r\n        ctx.textAlign = props.textAlign;\r\n      }\r\n      if (props.textBaseline !== null) {\r\n        ctx.textBaseline = props.textBaseline;\r\n      }\r\n      if (props.direction !== null) {\r\n        ctx.direction = props.direction;\r\n      }\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endTextStyle') {\r\n      cache = textStyleStack.pop();\r\n      ctx.font = cache.font;\r\n      ctx.textAlign = cache.textAlign;\r\n      ctx.textBaseline = cache.textBaseline;\r\n      ctx.direction = cache.direction;\r\n      continue;\r\n    }\r\n\r\n    if (type === 'shadowStyle') {\r\n      shadowStyleStack.push({\r\n        shadowBlur: ctx.shadowBlur,\r\n        shadowColor: ctx.shadowColor,\r\n        shadowOffsetX: ctx.shadowOffsetX,\r\n        shadowOffsetY: ctx.shadowOffsetY\r\n      });\r\n      if (props.shadowBlur !== null) {\r\n        ctx.shadowBlur = props.shadowBlur;\r\n      }\r\n      if (props.shadowColor !== null) {\r\n        ctx.shadowColor = props.shadowColor;\r\n      }\r\n      if (props.shadowOffsetX !== null) {\r\n        ctx.shadowOffsetX = props.shadowOffsetX;\r\n      }\r\n      if (props.shadowOffsetY !== null) {\r\n        ctx.shadowOffsetY = props.shadowOffsetY;\r\n      }\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endShadowStyle') {\r\n      cache = shadowStyleStack.pop();\r\n      ctx.shadowBlur = cache.shadowBlur;\r\n      ctx.shadowColor = cache.shadowColor;\r\n      ctx.shadowOffsetX = cache.shadowOffsetX;\r\n      ctx.shadowOffsetY = cache.shadowOffsetY;\r\n      continue;\r\n    }\r\n\r\n    if (type === 'strokeText') {\r\n      if (props.maxWidth) {\r\n        ctx.strokeText(props.text, props.x, props.y, props.maxWidth);\r\n        continue;\r\n      }\r\n      ctx.strokeText(props.text, props.x, props.y);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'fillText') {\r\n      if (props.maxWidth) {\r\n        ctx.fillText(props.text, props.x, props.y, props.maxWidth);\r\n        continue;\r\n      }\r\n      ctx.fillText(props.text, props.x, props.y);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'drawImage') {\r\n      ctx.drawImage(props.img, props.dx, props.dy);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'drawImageSize') {\r\n      ctx.drawImage(props.img, props.dx, props.dy, props.dWidth, props.dHeight);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'drawImageSource') {\r\n      ctx.drawImage(props.img, props.sx, props.sy, props.sWidth, props.sHeight, props.dx, props.dy, props.dWidth, props.dHeight);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'strokeArc') {\r\n      ctx.beginPath();\r\n      ctx.arc(props.x, props.y, props.r, props.startAngle, props.endAngle, props.counterclockwise);\r\n      ctx.closePath();\r\n      ctx.stroke();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'fillArc') {\r\n      ctx.beginPath();\r\n      ctx.arc(props.x, props.y, props.r, props.startAngle, props.endAngle, props.counterclockwise);\r\n      ctx.closePath();\r\n      ctx.fill();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'moveTo') {\r\n      ctx.moveTo(props.x, props.y);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'lineTo') {\r\n      ctx.lineTo(props.x, props.y);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'bezierCurveTo') {\r\n      ctx.bezierCurveTo(props.cp1x, props.cp1y, props.cp2x, props.cp2y, props.x, props.y);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'quadraticCurveTo') {\r\n      ctx.quadraticCurveTo(props.cpx, props.cpy, props.x, props.y);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'arc') {\r\n      ctx.arc(props.x, props.y, props.r, props.startAngle, props.endAngle, props.counterclockwise);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'arcTo') {\r\n      ctx.arcTo(props.x1, props.y1, props.x2, props.y2, props.r);\r\n      continue;\r\n    }\r\n\r\n    if (type === 'ellipse') {\r\n      //if the method is provided by the browser\r\n      if (supportsEllipse) {\r\n        ctx.ellipse(\r\n          props.x,\r\n          props.y,\r\n          props.radiusX,\r\n          props.radiusY,\r\n          props.rotation,\r\n          props.startAngle,\r\n          props.endAngle,\r\n          props.anticlockwise\r\n        );\r\n        continue;\r\n      }\r\n      ctx.save();\r\n      ctx.translate(props.x, props.y);\r\n      ctx.rotate(props.rotation);\r\n      ctx.scale(props.radiusX, props.radiusY);\r\n      ctx.arc(0, 0, 1, props.startAngle, props.endAngle, props.anticlockwise);\r\n      ctx.restore();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'globalCompositeOperation') {\r\n      globalCompositeOperationStack.push(ctx.globalCompositeOperation);\r\n      ctx.globalCompositeOperation = props.value;\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endGlobalCompositeOperation') {\r\n      ctx.globalCompositeOperation = globalCompositeOperationStack.pop();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'fill') {\r\n      ctx.fill();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'stroke') {\r\n      ctx.stroke();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'beginClip') {\r\n      ctx.save();\r\n      ctx.beginPath();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'clip') {\r\n      ctx.clip();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endClip') {\r\n      ctx.restore();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'beginPath') {\r\n      ctx.beginPath();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'closePath') {\r\n      ctx.closePath();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'globalAlpha') {\r\n      globalAlphaStack.push(ctx.globalAlpha);\r\n      ctx.globalAlpha *= props.value;\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endGlobalAlpha') {\r\n      ctx.globalAlpha = globalAlphaStack.pop();\r\n      continue;\r\n    }\r\n\r\n    if (type === 'hitRect' && regions) {\r\n      cache = [\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      ];\r\n\r\n      regions.push({\r\n        id: props.id,\r\n        points: props.points,\r\n        matrix: cache,\r\n        //rectangle!\r\n        polygon: false,\r\n        hover: false,\r\n        touched: false,\r\n        clicked: false\r\n      });\r\n    }\r\n\r\n    if (type === 'hitRegion' && regions) {\r\n      cache = [\r\n        transformStack[transformStackIndex - 6],\r\n        transformStack[transformStackIndex - 5],\r\n        transformStack[transformStackIndex - 4],\r\n        transformStack[transformStackIndex - 3],\r\n        transformStack[transformStackIndex - 2],\r\n        transformStack[transformStackIndex - 1]\r\n      ];\r\n\r\n      regions.push({\r\n        id: props.id,\r\n        points: props.points,\r\n        matrix: cache,\r\n        polygon: true,\r\n        hover: false,\r\n        touched: false,\r\n        clicked: false\r\n      });\r\n\r\n      continue;\r\n    }\r\n\r\n    if (type === 'imageSmoothingEnabled') {\r\n      imageSmoothingEnabledStack.push(ctx.imageSmoothingEnabled);\r\n      ctx.imageSmoothingEnabled = props.value;\r\n\r\n      continue;\r\n    }\r\n\r\n    if (type === 'endImageSmoothingEnabled') {\r\n      ctx.imageSmoothingEnabled = imageSmoothingEnabledStack.pop();\r\n      continue;\r\n    }\r\n\r\n    if (extensions && extensions[type]) {\r\n      extensions[type](props, ctx);\r\n      continue;\r\n    }\r\n  }\r\n};\n\n/***/ },\n/* 42 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet setTransform = __webpack_require__(9);\r\n\r\nlet resetTransform = (...children) => setTransform([1, 0, 0, 1, 0, 0], children);\r\n\r\nmodule.exports = resetTransform;\n\n/***/ },\n/* 43 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('restore');\r\n\r\nlet rotate = (r, ...children) => [\r\n  new Instruction('rotate', { cos: Math.cos(r), sin: Math.sin(r) }),\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = rotate;\r\n\n\n/***/ },\n/* 44 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('restore');\r\n\r\nlet scale = (x, y, ...children) => {\r\n  if (typeof y !== 'number') {\r\n    children = [y].concat(children);\r\n    y = x;\r\n  }\r\n\r\n  return [\r\n    new Instruction('scale', { x, y }),\r\n    children,\r\n    end\r\n  ];\r\n};\r\n\r\nmodule.exports = scale;\r\n\n\n/***/ },\n/* 45 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('endShadowStyle');\r\n\r\nlet shadowStyle = (value, ...children) => {\r\n  value = value || {};\r\n  var result = {\r\n    shadowBlur: null,\r\n    shadowColor: null,\r\n    shadowOffsetX: null,\r\n    shadowOffsetY: null\r\n  };\r\n\r\n  if (typeof value.shadowBlur !== 'undefined') {\r\n    result.shadowBlur = value.shadowBlur;\r\n  }\r\n  if (typeof value.shadowColor !== 'undefined') {\r\n    result.shadowColor = value.shadowColor;\r\n  }\r\n  if (typeof value.shadowOffsetX !== 'undefined') {\r\n    result.shadowOffsetX = value.shadowOffsetX;\r\n  }\r\n  if (typeof value.direction !== 'undefined') {\r\n    result.shadowOffsetY = value.shadowOffsetY;\r\n  }\r\n\r\n  return [\r\n    new Instruction('shadowStyle', value),\r\n    children,\r\n    end\r\n  ];\r\n};\r\n\r\nmodule.exports = shadowStyle;\r\n\n\n/***/ },\n/* 46 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('restore');\r\n\r\nlet skewX = (x, ...children) => [\r\n  new Instruction('skewX', { x: Math.tan(x) }),\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = skewX;\r\n\n\n/***/ },\n/* 47 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('restore');\r\n\r\nlet skewY = (x, ...children) => [\r\n  new Instruction('skewY', { y: Math.tan(y) }),\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = skewY;\r\n\n\n/***/ },\n/* 48 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet cache = new Instruction('stroke');\r\n\r\nlet stroke = () => cache;\r\nmodule.exports = stroke;\r\n\n\n/***/ },\n/* 49 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0),\r\n    pi2 = Math.PI * 2;\r\n\r\nlet strokeArc = (...args) => {\r\n  let [x, y, r, startAngle, endAngle, counterclockwise] = args;\r\n  let props = { x: 0, y: 0, r: x, startAngle: 0, endAngle: pi2, counterclockwise: false };\r\n\r\n\r\n  if (args.length > 3) {\r\n    props.startAngle = startAngle;\r\n    props.endAngle = endAngle;\r\n    props.counterclockwise = !!counterclockwise;\r\n  }\r\n\r\n  if (args.length > 1){\r\n    props.x = x;\r\n    props.y = y;\r\n    props.r = r;\r\n  }\r\n\r\n  return new Instruction(\"strokeArc\",  props);\r\n};\r\n\r\nmodule.exports = strokeArc;\r\n\n\n/***/ },\n/* 50 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet strokeRect = (...args) => new Instruction('strokeRect',\r\n  args.length > 2 ?\r\n    { x: args[0], y: args[1], width: args[2], height: args[3] } :\r\n    { x: 0, y: 0, width: args[0], height: args[1] }\r\n);\r\n\r\nmodule.exports = strokeRect;\r\n\n\n/***/ },\n/* 51 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('endStrokeStyle');\r\n\r\nlet strokeStyle = (value, ...children) => [\r\n  new Instruction('strokeStyle', { value }),\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = strokeStyle;\r\n\n\n/***/ },\n/* 52 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\n\r\nlet strokeText = (...args) => {\r\n  let [text, x, y, maxWidth] = args;\r\n\r\n  if (args.length < 4) {\r\n    maxWidth = null;\r\n  }\r\n  if (args.length < 3) {\r\n    x = 0;\r\n    y = 0;\r\n  }\r\n  return new Instruction('strokeText', {\r\n    text,\r\n    x,\r\n    y,\r\n    maxWidth\r\n  });\r\n};\r\n\r\nmodule.exports = strokeText;\n\n/***/ },\n/* 53 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('endTextStyle');\r\n\r\nlet textStyle = (value, ...children) => {\r\n  value = value || {};\r\n  var result = {\r\n    font: null,\r\n    textAlign: null,\r\n    textBaseline: null,\r\n    direction: null\r\n  };\r\n\r\n  if (typeof value.font !== 'undefined') {\r\n    result.font = value.font;\r\n  }\r\n  if (typeof value.textAlign !== 'undefined') {\r\n    result.textAlign = value.textAlign;\r\n  }\r\n  if (typeof value.textBaseline !== 'undefined') {\r\n    result.textBaseline = value.textBaseline;\r\n  }\r\n  if (typeof value.direction !== 'undefined') {\r\n    result.direction = value.direction;\r\n  }\r\n\r\n  return [\r\n    new Instruction('textStyle', result),\r\n    children,\r\n    end\r\n  ];\r\n};\r\n\r\nmodule.exports = textStyle;\r\n\n\n/***/ },\n/* 54 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('restore');\r\n\r\nlet transform = (values, ...children) => {\r\n  return [\r\n    new Instruction('transform',[\r\n      values[0],\r\n      values[1],\r\n      values[2],\r\n      values[3],\r\n      values[4],\r\n      values[5]\r\n    ]),\r\n    children,\r\n    end\r\n  ];\r\n};\r\n\r\n\r\nmodule.exports = transform;\r\n\n\n/***/ },\n/* 55 */\n/***/ function(module, exports, __webpack_require__) {\n\nlet Instruction = __webpack_require__(0);\r\nlet end = new Instruction('restore');\r\n\r\nlet translate = (x, y, ...children) => [\r\n  new Instruction('translate', { x: x, y: y }),\r\n  children,\r\n  end\r\n];\r\n\r\nmodule.exports = translate;\r\n\n\n/***/ },\n/* 56 */\n/***/ function(module, exports) {\n\n// Source: http://jsfiddle.net/vWx8V/\n// http://stackoverflow.com/questions/5603195/full-list-of-javascript-keycodes\n\n/**\n * Conenience method returns corresponding value for given keyName or keyCode.\n *\n * @param {Mixed} keyCode {Number} or keyName {String}\n * @return {Mixed}\n * @api public\n */\n\nexports = module.exports = function(searchInput) {\n  // Keyboard Events\n  if (searchInput && 'object' === typeof searchInput) {\n    var hasKeyCode = searchInput.which || searchInput.keyCode || searchInput.charCode\n    if (hasKeyCode) searchInput = hasKeyCode\n  }\n\n  // Numbers\n  if ('number' === typeof searchInput) return names[searchInput]\n\n  // Everything else (cast to string)\n  var search = String(searchInput)\n\n  // check codes\n  var foundNamedKey = codes[search.toLowerCase()]\n  if (foundNamedKey) return foundNamedKey\n\n  // check aliases\n  var foundNamedKey = aliases[search.toLowerCase()]\n  if (foundNamedKey) return foundNamedKey\n\n  // weird character?\n  if (search.length === 1) return search.charCodeAt(0)\n\n  return undefined\n}\n\n/**\n * Get by name\n *\n *   exports.code['enter'] // => 13\n */\n\nvar codes = exports.code = exports.codes = {\n  'backspace': 8,\n  'tab': 9,\n  'enter': 13,\n  'shift': 16,\n  'ctrl': 17,\n  'alt': 18,\n  'pause/break': 19,\n  'caps lock': 20,\n  'esc': 27,\n  'space': 32,\n  'page up': 33,\n  'page down': 34,\n  'end': 35,\n  'home': 36,\n  'left': 37,\n  'up': 38,\n  'right': 39,\n  'down': 40,\n  'insert': 45,\n  'delete': 46,\n  'command': 91,\n  'left command': 91,\n  'right command': 93,\n  'numpad *': 106,\n  'numpad +': 107,\n  'numpad -': 109,\n  'numpad .': 110,\n  'numpad /': 111,\n  'num lock': 144,\n  'scroll lock': 145,\n  'my computer': 182,\n  'my calculator': 183,\n  ';': 186,\n  '=': 187,\n  ',': 188,\n  '-': 189,\n  '.': 190,\n  '/': 191,\n  '`': 192,\n  '[': 219,\n  '\\\\': 220,\n  ']': 221,\n  \"'\": 222\n}\n\n// Helper aliases\n\nvar aliases = exports.aliases = {\n  'windows': 91,\n  '⇧': 16,\n  '⌥': 18,\n  '⌃': 17,\n  '⌘': 91,\n  'ctl': 17,\n  'control': 17,\n  'option': 18,\n  'pause': 19,\n  'break': 19,\n  'caps': 20,\n  'return': 13,\n  'escape': 27,\n  'spc': 32,\n  'pgup': 33,\n  'pgdn': 34,\n  'ins': 45,\n  'del': 46,\n  'cmd': 91\n}\n\n\n/*!\n * Programatically add the following\n */\n\n// lower case chars\nfor (i = 97; i < 123; i++) codes[String.fromCharCode(i)] = i - 32\n\n// numbers\nfor (var i = 48; i < 58; i++) codes[i - 48] = i\n\n// function keys\nfor (i = 1; i < 13; i++) codes['f'+i] = i + 111\n\n// numpad keys\nfor (i = 0; i < 10; i++) codes['numpad '+i] = i + 96\n\n/**\n * Get by code\n *\n *   exports.name[13] // => 'Enter'\n */\n\nvar names = exports.names = exports.title = {} // title for backward compat\n\n// Create reverse mapping\nfor (i in codes) names[codes[i]] = i\n\n// Add aliases\nfor (var alias in aliases) {\n  codes[alias] = aliases[alias]\n}\n\n\n/***/ },\n/* 57 */\n/***/ function(module, exports) {\n\nmodule.exports = function (point, vs) {\n    // ray-casting algorithm based on\n    // http://www.ecse.rpi.edu/Homepages/wrf/Research/Short_Notes/pnpoly.html\n    \n    var x = point[0], y = point[1];\n    \n    var inside = false;\n    for (var i = 0, j = vs.length - 1; i < vs.length; j = i++) {\n        var xi = vs[i][0], yi = vs[i][1];\n        var xj = vs[j][0], yj = vs[j][1];\n        \n        var intersect = ((yi > y) != (yj > y))\n            && (x < (xj - xi) * (y - yi) / (yj - yi) + xi);\n        if (intersect) inside = !inside;\n    }\n    \n    return inside;\n};\n\n\n/***/ },\n/* 58 */\n/***/ function(module, exports, __webpack_require__) {\n\nmodule.exports = {\n  'activeRegions': __webpack_require__(10),\n  'arc': __webpack_require__(11),\n  'arcTo': __webpack_require__(12),\n  'beginPath': __webpack_require__(2),\n  'bezierCurveTo': __webpack_require__(13),\n  'clearRect': __webpack_require__(14),\n  'clip': __webpack_require__(15),\n  'clipPath': __webpack_require__(16),\n  'closePath': __webpack_require__(3),\n  'createRegularPolygon': __webpack_require__(17),\n  'createWrapper': __webpack_require__(18),\n  'cycleMouseData': __webpack_require__(4),\n  'drawImage': __webpack_require__(19),\n  'ellipse': __webpack_require__(20),\n  'fill': __webpack_require__(21),\n  'fillArc': __webpack_require__(22),\n  'fillRect': __webpack_require__(23),\n  'fillStyle': __webpack_require__(24),\n  'fillText': __webpack_require__(25),\n  'globalAlpha': __webpack_require__(26),\n  'globalCompositeOperation': __webpack_require__(27),\n  'hitRect': __webpack_require__(28),\n  'hitRegion': __webpack_require__(29),\n  'imageSmoothingEnabled': __webpack_require__(30),\n  'initialize': __webpack_require__(31),\n  'Instruction': __webpack_require__(0),\n  'invertMatrix': __webpack_require__(5),\n  'keyData': __webpack_require__(32),\n  'lineStyle': __webpack_require__(33),\n  'lineTo': __webpack_require__(6),\n  'mouseData': __webpack_require__(34),\n  'moveTo': __webpack_require__(7),\n  'moveToLineTo': __webpack_require__(35),\n  'path': __webpack_require__(36),\n  'placeHolder': __webpack_require__(37),\n  'pointInRect': __webpack_require__(8),\n  'quadraticCurveTo': __webpack_require__(38),\n  'raf': __webpack_require__(39),\n  'rect': __webpack_require__(40),\n  'render': __webpack_require__(41),\n  'resetTransform': __webpack_require__(42),\n  'rotate': __webpack_require__(43),\n  'scale': __webpack_require__(44),\n  'setTransform': __webpack_require__(9),\n  'shadowStyle': __webpack_require__(45),\n  'skewX': __webpack_require__(46),\n  'skewY': __webpack_require__(47),\n  'stroke': __webpack_require__(48),\n  'strokeArc': __webpack_require__(49),\n  'strokeRect': __webpack_require__(50),\n  'strokeStyle': __webpack_require__(51),\n  'strokeText': __webpack_require__(52),\n  'textStyle': __webpack_require__(53),\n  'transform': __webpack_require__(54),\n  'transformPoints': __webpack_require__(1),\n  'translate': __webpack_require__(55)\n};\n\n/***/ }\n/******/ ]);\n});"]} | |
const repatch = require('repatch'); | |
const e2d = require('e2d'); | |
const components = []; | |
const app = { pointer: false, mouseData: null, activeRegions: null }; | |
const ctx = document.createElement('canvas').getContext('2d'); | |
ctx.canvas.width = 400; | |
ctx.canvas.height = 300; | |
document.body.appendChild(ctx.canvas); | |
e2d.raf(() => { | |
app.mouseData = e2d.mouseData(ctx); | |
app.activeRegions = e2d.activeRegions(ctx); | |
app.pointer = false; | |
components.forEach(x => { | |
const region = app.activeRegions[x.id]; | |
const prevActive = x.active; | |
x.hover = !!region; | |
if (region.clicked) { | |
x.active = true; | |
} | |
if (x.active && x.hover && !app.mouseData.state) { | |
x.onClick(app); | |
} | |
if (!app.mouseData.state) { | |
x.active = false; | |
} | |
x.dirty = x.update(app) || x.dirty || (prevActive !== x.active); | |
}); | |
components.sort((x, y) => x.zIndex < y.zIndex ? -1 : x.zIndex > y.zIndex ? 1 : 0); | |
const view = components.map(x => x.dirty ? x._cache = x.render() : x._cache); | |
components.forEach(x => (x.dirty = false, true)); | |
e2d.render( | |
e2d.clearRect(ctx.canvas.width, ctx.canvas.height), | |
view, | |
ctx | |
); | |
}) | |
let id = -1; | |
class Component { | |
constructor({ position = [0, 0], scale = [1, 1], rotation = 0, alpha = 0, center = [0, 0], onClick = x => {} }) { | |
this.id = (++id).toString(36); | |
this.position = position; | |
this.scale = scale; | |
this.center = center; | |
this.rotation = rotaion; | |
this.alpha = alpha; | |
this.dirty = true; | |
this.active = false; | |
this.hover = false; | |
this._cache = []; | |
this.onClick = onClick; | |
} | |
render(...children) { | |
return e2d.translate(this.position[0], this.position[1], | |
e2d.rotate(this.rotation, | |
e2d.scale(this.scale[0], this.scale[1], | |
e2d.translate(-this.center[0], -this.center[1], ...children) | |
) | |
) | |
); | |
} | |
} | |
;}, 0) |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{ | |
"name": "requirebin-sketch", | |
"version": "1.0.0", | |
"dependencies": { | |
"repatch": "1.3.2", | |
"e2d": "4.0.0-rc.1" | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!-- contents of this file will be placed inside the <body> --> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!-- contents of this file will be placed inside the <head> --> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment