UNPKG

mediacanvas

Version:

Render videos or images at multiple locations on a canvas simultaneously

124 lines (117 loc) 21.3 kB
(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["MediaCanvas"] = factory(); else root["MediaCanvas"] = factory(); })(window, 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; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ __webpack_require__.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = __webpack_require__(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // 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 = "./build.js"); /******/ }) /************************************************************************/ /******/ ({ /***/ "./build.js": /*!******************!*\ !*** ./build.js ***! \******************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; eval("\n\nmodule.exports = __webpack_require__(/*! ./src/mediacanvas.js */ \"./src/mediacanvas.js\").default;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9NZWRpYUNhbnZhcy8uL2J1aWxkLmpzP2YyNjIiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsInJlcXVpcmUiLCJkZWZhdWx0Il0sIm1hcHBpbmdzIjoiOztBQUFBQSxPQUFPQyxPQUFQLEdBQWlCLG1CQUFBQyxDQUFRLGtEQUFSLEVBQWdDQyxPQUFqRCIsImZpbGUiOiIuL2J1aWxkLmpzLmpzIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuL3NyYy9tZWRpYWNhbnZhcy5qcycpLmRlZmF1bHQ7Il0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./build.js\n"); /***/ }), /***/ "./src/mediacanvas.js": /*!****************************!*\ !*** ./src/mediacanvas.js ***! \****************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar MediaCanvas = exports.MediaCanvas = function () {\n function MediaCanvas(canvas) {\n var width = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : canvas.clientWidth;\n var height = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : canvas.clientHeight;\n\n _classCallCheck(this, MediaCanvas);\n\n this._canvas = canvas;\n this._context = canvas.getContext(\"2d\");\n this._rendering = false;\n\n this.items = [];\n this._coordinateWidth = width;\n this._coordinateHeight = height;\n this._horizontalScale = 1.0;\n this._verticalScale = 1.0;\n this._width = width;\n this._height = height;\n this._canvas.width = width;\n this._canvas.height = height;\n\n this._startPromiseResolver = null;\n this._stopPromiseResolver = null;\n this._requestRenderResolver = null;\n\n this._render = this._render.bind(this);\n }\n\n _createClass(MediaCanvas, [{\n key: \"_render\",\n value: function _render() {\n if (this._context) {\n this._context.clearRect(0, 0, this._width, this._height);\n var _iteratorNormalCompletion = true;\n var _didIteratorError = false;\n var _iteratorError = undefined;\n\n try {\n for (var _iterator = this.items[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n var item = _step.value;\n\n this._context.drawImage(item.src, item.x * this._horizontalScale, item.y * this._verticalScale, item.width * this._horizontalScale, item.height * this._verticalScale);\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally {\n try {\n if (!_iteratorNormalCompletion && _iterator.return) {\n _iterator.return();\n }\n } finally {\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n }\n\n // Schedule another render\n if (this._rendering) requestAnimationFrame(this._render);else {\n if (typeof this._stopPromiseResolver === \"function\") {\n this._stopPromiseResolver();\n this._stopPromiseResolver = null;\n }\n if (typeof this._requestRenderResolver === \"function\") {\n this._requestRenderResolver();\n this._requestRenderResolver = null;\n }\n }\n\n // Fulfill promise\n if (typeof this._startPromiseResolver === \"function\") {\n this._startPromiseResolver();\n this._startPromiseResolver = null;\n }\n }\n }, {\n key: \"setDimensions\",\n value: function setDimensions(width, height) {\n this._width = width;\n this._canvas.width = width;\n this._horizontalScale = width / this._coordinateWidth;\n\n this._height = height;\n this._canvas.height = height;\n this._verticalScale = height / this._coordinateHeight;\n\n if (!this._rendering) this._render();\n }\n }, {\n key: \"matchClientDimensions\",\n value: function matchClientDimensions() {\n this.setDimensions(this._canvas.clientWidth, this._canvas.clientHeight);\n }\n }, {\n key: \"start\",\n value: function start() {\n var _this = this;\n\n return new Promise(function (resolve, reject) {\n if (_this._rendering) reject(new Error(\"The renderer is already started.\"));else {\n _this._rendering = true;\n _this._startPromiseResolver = resolve;\n requestAnimationFrame(_this._render);\n }\n });\n }\n }, {\n key: \"stop\",\n value: function stop() {\n var _this2 = this;\n\n return new Promise(function (resolve, reject) {\n if (_this2._rendering) {\n _this2._stopPromiseResolver = resolve;\n _this2._rendering = false;\n } else reject(new Error(\"The renderer is already stopped.\"));\n });\n }\n }, {\n key: \"requestRender\",\n value: function requestRender() {\n var _this3 = this;\n\n return new Promise(function (resolve, reject) {\n if (_this3._rendering) reject(new Error(\"The renderer is already started.\"));else if (_this3._requestRenderResolver !== null) reject(new Error(\"A render has already been scheduled.\"));else {\n _this3._requestRenderResolver = resolve;\n requestAnimationFrame(_this3._render);\n }\n });\n }\n }, {\n key: \"rendering\",\n get: function get() {\n return this._rendering;\n }\n }, {\n key: \"width\",\n get: function get() {\n return this._width;\n },\n set: function set(width) {\n this.setDimensions(width, this._height);\n }\n }, {\n key: \"height\",\n get: function get() {\n return this._height;\n },\n set: function set(height) {\n this.setDimensions(this._width, height);\n }\n }, {\n key: \"originalWidth\",\n get: function get() {\n return this._coordinateWidth;\n }\n }, {\n key: \"originalHeight\",\n get: function get() {\n return this._coordinateHeight;\n }\n }]);\n\n return MediaCanvas;\n}();\n\nexports.default = MediaCanvas;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://MediaCanvas/./src/mediacanvas.js?8d0b"],"names":["MediaCanvas","canvas","width","clientWidth","height","clientHeight","_canvas","_context","getContext","_rendering","items","_coordinateWidth","_coordinateHeight","_horizontalScale","_verticalScale","_width","_height","_startPromiseResolver","_stopPromiseResolver","_requestRenderResolver","_render","bind","clearRect","item","drawImage","src","x","y","requestAnimationFrame","setDimensions","Promise","resolve","reject","Error"],"mappings":"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","file":"./src/mediacanvas.js.js","sourcesContent":["export class MediaCanvas {\r\n  constructor(canvas, width = canvas.clientWidth, height = canvas.clientHeight) {\r\n    this._canvas = canvas;\r\n    this._context = canvas.getContext(\"2d\");\r\n    this._rendering = false;\r\n\r\n    this.items = [];\r\n    this._coordinateWidth = width;\r\n    this._coordinateHeight = height;\r\n    this._horizontalScale = 1.0;\r\n    this._verticalScale = 1.0;\r\n    this._width = width;\r\n    this._height = height;\r\n    this._canvas.width = width;\r\n    this._canvas.height = height;\r\n\r\n    this._startPromiseResolver = null;\r\n    this._stopPromiseResolver = null;\r\n    this._requestRenderResolver = null;\r\n\r\n    this._render = this._render.bind(this);\r\n  }\r\n\r\n  _render() {\r\n    if (this._context) {\r\n      this._context.clearRect(0, 0, this._width, this._height);\r\n      for (const item of this.items) {\r\n        this._context.drawImage(item.src, \r\n          item.x * this._horizontalScale, \r\n          item.y * this._verticalScale, \r\n          item.width * this._horizontalScale, \r\n          item.height * this._verticalScale\r\n        );\r\n      }\r\n    }\r\n\r\n    // Schedule another render\r\n    if (this._rendering)\r\n      requestAnimationFrame(this._render);\r\n    else {\r\n      if (typeof this._stopPromiseResolver === \"function\") {\r\n        this._stopPromiseResolver();\r\n        this._stopPromiseResolver = null;\r\n      }\r\n      if (typeof this._requestRenderResolver === \"function\") {\r\n        this._requestRenderResolver();\r\n        this._requestRenderResolver = null;\r\n      }\r\n    }\r\n\r\n    // Fulfill promise\r\n    if (typeof this._startPromiseResolver === \"function\") {\r\n      this._startPromiseResolver();\r\n      this._startPromiseResolver = null;\r\n    }\r\n  }\r\n\r\n  get rendering() {\r\n    return this._rendering;\r\n  }\r\n  \r\n  get width() {\r\n    return this._width;\r\n  }\r\n\r\n  set width(width) {\r\n    this.setDimensions(width, this._height);\r\n  }\r\n\r\n  get height() {\r\n    return this._height;\r\n  }\r\n\r\n  set height(height) {\r\n    this.setDimensions(this._width, height);\r\n  }\r\n\r\n  get originalWidth() {\r\n    return this._coordinateWidth;\r\n  }\r\n\r\n  get originalHeight() {\r\n    return this._coordinateHeight;\r\n  }\r\n\r\n  setDimensions(width, height) {\r\n    this._width = width;\r\n    this._canvas.width = width;\r\n    this._horizontalScale = width / this._coordinateWidth;\r\n\r\n    this._height = height;\r\n    this._canvas.height = height;\r\n    this._verticalScale = height / this._coordinateHeight;\r\n\r\n    if (!this._rendering)\r\n      this._render();\r\n  }\r\n\r\n  matchClientDimensions() {\r\n    this.setDimensions(this._canvas.clientWidth, this._canvas.clientHeight);\r\n  }\r\n\r\n  start() {\r\n    return new Promise((resolve, reject) => {\r\n      if (this._rendering)\r\n        reject(new Error(\"The renderer is already started.\"));\r\n      else {\r\n        this._rendering = true;\r\n        this._startPromiseResolver = resolve;\r\n        requestAnimationFrame(this._render);\r\n      }\r\n    });\r\n  }\r\n\r\n  stop() {\r\n    return new Promise((resolve, reject) => {\r\n      if (this._rendering) {\r\n        this._stopPromiseResolver = resolve;\r\n        this._rendering = false;\r\n      }\r\n      else\r\n        reject(new Error(\"The renderer is already stopped.\"));\r\n    });\r\n  }\r\n\r\n  requestRender() {\r\n    return new Promise((resolve, reject) => {\r\n      if (this._rendering)\r\n        reject(new Error(\"The renderer is already started.\"));\r\n      else if (this._requestRenderResolver !== null)\r\n        reject(new Error(\"A render has already been scheduled.\"));\r\n      else {\r\n        this._requestRenderResolver = resolve;\r\n        requestAnimationFrame(this._render);\r\n      }\r\n    });\r\n  }\r\n}\r\n\r\nexport default MediaCanvas;\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/mediacanvas.js\n"); /***/ }) /******/ }); });