UNPKG

react-background-animation

Version:
263 lines (209 loc) 31.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _react = _interopRequireWildcard(require("react")); var _lodash = _interopRequireDefault(require("lodash")); var _jquery = _interopRequireDefault(require("jquery")); var _mosaicStyled = require("./mosaicStyled"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; if (obj != null) { var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } var MosaicGround = /*#__PURE__*/ function (_PureComponent) { _inherits(MosaicGround, _PureComponent); function MosaicGround(props) { var _this; _classCallCheck(this, MosaicGround); _this = _possibleConstructorReturn(this, _getPrototypeOf(MosaicGround).call(this, props)); _this.excuteEffect = _this.excuteEffect.bind(_assertThisInitialized(_this)); return _this; } _createClass(MosaicGround, [{ key: "excuteEffect", value: function excuteEffect() { (function () { var Photo, addListeners, canvas, createGrid, ctx, gridItem, grids, height, img, imgInfo, imgSrc, imgs, init, magnet, mouse, populateCanvas, _render, resizeCanvas, rotateAndPaintImage, updateMouse, useGrid, width; canvas = document.getElementById('canvas'); ctx = canvas.getContext('2d'); width = canvas.width = window.innerWidth; height = canvas.height = window.innerHeight; imgSrc = canvas.dataset.image; img = new Image(); useGrid = true; imgInfo = {}; imgs = []; grids = []; magnet = 2000; mouse = { x: 1, y: 0 }; init = function init() { addListeners(); img.onload = function (e) { var numberToShow; // Check for firefox. imgInfo.width = e.path ? e.path[0].width : e.target.width; imgInfo.height = e.path ? e.path[0].height : e.target.height; numberToShow = Math.ceil(window.innerWidth / imgInfo.width) * Math.ceil(window.innerHeight / imgInfo.height); if (useGrid) { createGrid(); } populateCanvas(numberToShow * 4); canvas.classList.add('ready'); return _render(); }; return img.src = imgSrc; }; addListeners = function addListeners() { window.addEventListener('resize', resizeCanvas); window.addEventListener('mousemove', updateMouse); return window.addEventListener('touchmove', updateMouse); }; updateMouse = function updateMouse(e) { mouse.x = e.clientX; return mouse.y = e.clientY; }; resizeCanvas = function resizeCanvas() { width = canvas.width = window.innerWidth; return height = canvas.height = window.innerHeight; }; populateCanvas = function populateCanvas(nb) { var i, p, results; i = 0; results = []; while (i <= nb) { p = new Photo(); imgs.push(p); results.push(i++); } return results; }; createGrid = function createGrid() { var c, grid, i, imgScale, item, j, k, l, r, ref, ref1, ref2, results, x, y; imgScale = 0.5; grid = { row: Math.ceil(window.innerWidth / (imgInfo.width * imgScale)), cols: Math.ceil(window.innerHeight / (imgInfo.height * imgScale)), rowWidth: imgInfo.width * imgScale, colHeight: imgInfo.height * imgScale }; for (r = j = 0, ref = grid.row; 0 <= ref ? j < ref : j > ref; r = 0 <= ref ? ++j : --j) { x = r * grid.rowWidth; for (c = k = 0, ref1 = grid.cols; 0 <= ref1 ? k < ref1 : k > ref1; c = 0 <= ref1 ? ++k : --k) { y = c * grid.colHeight; item = new gridItem(x, y, grid.rowWidth, grid.colHeight); grids.push(item); } } results = []; for (i = l = 0, ref2 = grids.length; 0 <= ref2 ? l < ref2 : l > ref2; i = 0 <= ref2 ? ++l : --l) { results.push(grids[i].draw()); } return results; }; gridItem = function gridItem() { var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; var y = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; var w = arguments.length > 2 ? arguments[2] : undefined; var h = arguments.length > 3 ? arguments[3] : undefined; this.draw = function () { ctx.drawImage(img, x, y, w, h); }; }; Photo = function Photo() { var TO_RADIANS, finalX, finalY, forceX, forceY, h, r, seed, w, x, y; seed = Math.random() * (2.5 - 0.7) + 0.7; w = imgInfo.width / seed; h = imgInfo.height / seed; x = window.innerWidth * Math.random(); finalX = x; y = window.innerHeight * Math.random(); finalY = y; console.log("INIT Y :: ".concat(finalY, " || INIT X :: ").concat(finalX)); r = Math.random() * (180 - -180) + -180; forceX = 0; forceY = 0; TO_RADIANS = Math.PI / 180; this.update = function () { var distance, dx, dy, powerX, powerY, x0, x1, y0, y1; x0 = x; y0 = y; x1 = mouse.x; y1 = mouse.y; dx = x1 - x0; dy = y1 - y0; distance = Math.sqrt(dx * dx + dy * dy); powerX = x0 - dx / distance * magnet / distance; powerY = y0 - dy / distance * magnet / distance; forceX = (forceX + (finalX - x0) / 2) / 2.1; forceY = (forceY + (finalY - y0) / 2) / 2.2; x = powerX + forceX; y = powerY + forceY; }; this.draw = function () { return rotateAndPaintImage(ctx, img, r * TO_RADIANS, x, y, w / 2, h / 2, w, h); }; }; rotateAndPaintImage = function rotateAndPaintImage(context, image, angle, positionX, positionY, axisX, axisY, widthX, widthY) { context.translate(positionX, positionY); context.rotate(angle); context.drawImage(image, -axisX, -axisY, widthX, widthY); context.rotate(-angle); return context.translate(-positionX, -positionY); }; _render = function render() { var x, y; x = 0; y = 0; ctx.clearRect(0, 0, width, height); while (y < grids.length) { grids[y].draw(); y++; } while (x < imgs.length) { imgs[x].update(); imgs[x].draw(); x++; } return requestAnimationFrame(_render); }; init(); }).call(this); } }, { key: "componentDidMount", value: function componentDidMount() { this.excuteEffect(); } }, { key: "render", value: function render() { var _this$props$dataImage = this.props.dataImage, dataImage = _this$props$dataImage === void 0 ? 'http://unsplash.it/g/450/200/?random=1' : _this$props$dataImage; return _react["default"].createElement("div", { className: this.props.className || '' }, _react["default"].createElement(_mosaicStyled.Mosaic, null, _react["default"].createElement("canvas", { id: "canvas", "data-image": dataImage }), _react["default"].createElement("div", { className: "intro" }))); } }]); return MosaicGround; }(_react.PureComponent); var _default = MosaicGround; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/cssEffects/mosaicGround/mosaic.jsx"],"names":["MosaicGround","props","excuteEffect","bind","Photo","addListeners","canvas","createGrid","ctx","gridItem","grids","height","img","imgInfo","imgSrc","imgs","init","magnet","mouse","populateCanvas","render","resizeCanvas","rotateAndPaintImage","updateMouse","useGrid","width","document","getElementById","getContext","window","innerWidth","innerHeight","dataset","image","Image","x","y","onload","e","numberToShow","path","target","Math","ceil","classList","add","src","addEventListener","clientX","clientY","nb","i","p","results","push","c","grid","imgScale","item","j","k","l","r","ref","ref1","ref2","row","cols","rowWidth","colHeight","length","draw","w","h","drawImage","TO_RADIANS","finalX","finalY","forceX","forceY","seed","random","console","log","PI","update","distance","dx","dy","powerX","powerY","x0","x1","y0","y1","sqrt","context","angle","positionX","positionY","axisX","axisY","widthX","widthY","translate","rotate","clearRect","requestAnimationFrame","call","dataImage","className","PureComponent"],"mappings":"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","sourcesContent":["import React, { PureComponent } from 'react'\r\nimport _ from 'lodash'\r\nimport $ from 'jquery'\r\n\r\n// import './mosaic.scss'\r\nimport { Mosaic } from './mosaicStyled'\r\n\r\nclass MosaicGround extends PureComponent {\r\n\r\n  constructor(props) {\r\n    super(props)\r\n    this.excuteEffect = this.excuteEffect.bind(this)\r\n  }\r\n\r\n  excuteEffect() {\r\n    (function () {\r\n      var Photo, addListeners, canvas, createGrid, ctx, gridItem, grids, height, img, imgInfo, imgSrc, imgs, init, magnet, mouse, populateCanvas, render, resizeCanvas, rotateAndPaintImage, updateMouse, useGrid, width;\r\n\r\n      canvas = document.getElementById('canvas');\r\n\r\n      ctx = canvas.getContext('2d');\r\n\r\n      width = canvas.width = window.innerWidth;\r\n\r\n      height = canvas.height = window.innerHeight;\r\n\r\n      imgSrc = canvas.dataset.image;\r\n\r\n      img = new Image();\r\n\r\n      useGrid = true;\r\n\r\n      imgInfo = {};\r\n\r\n      imgs = [];\r\n\r\n      grids = [];\r\n\r\n      magnet = 2000;\r\n\r\n      mouse = {\r\n        x: 1,\r\n        y: 0\r\n      };\r\n\r\n\r\n      init = function () {\r\n        addListeners();\r\n        img.onload = function (e) {\r\n          var numberToShow;\r\n          // Check for firefox. \r\n          imgInfo.width = e.path ? e.path[0].width : e.target.width;\r\n          imgInfo.height = e.path ? e.path[0].height : e.target.height;\r\n          numberToShow = Math.ceil(window.innerWidth / imgInfo.width) * Math.ceil(window.innerHeight / imgInfo.height);\r\n          if (useGrid) {\r\n            createGrid();\r\n          }\r\n          populateCanvas(numberToShow * 4);\r\n          canvas.classList.add('ready');\r\n          return render();\r\n        };\r\n        return img.src = imgSrc;\r\n      };\r\n\r\n      addListeners = function () {\r\n        window.addEventListener('resize', resizeCanvas);\r\n        window.addEventListener('mousemove', updateMouse);\r\n        return window.addEventListener('touchmove', updateMouse);\r\n      };\r\n\r\n      updateMouse = function (e) {\r\n        mouse.x = e.clientX;\r\n        return mouse.y = e.clientY;\r\n      };\r\n\r\n      resizeCanvas = function () {\r\n        width = canvas.width = window.innerWidth;\r\n        return height = canvas.height = window.innerHeight;\r\n      };\r\n\r\n      populateCanvas = function (nb) {\r\n        var i, p, results;\r\n        i = 0;\r\n        results = [];\r\n        while (i <= nb) {\r\n          p = new Photo();\r\n          imgs.push(p);\r\n          results.push(i++);\r\n        }\r\n        return results;\r\n      };\r\n\r\n      createGrid = function () {\r\n        var c, grid, i, imgScale, item, j, k, l, r, ref, ref1, ref2, results, x, y;\r\n        imgScale = 0.5;\r\n        grid = {\r\n          row: Math.ceil(window.innerWidth / (imgInfo.width * imgScale)),\r\n          cols: Math.ceil(window.innerHeight / (imgInfo.height * imgScale)),\r\n          rowWidth: imgInfo.width * imgScale,\r\n          colHeight: imgInfo.height * imgScale\r\n        };\r\n\r\n        for (r = j = 0, ref = grid.row; 0 <= ref ? j < ref : j > ref; r = 0 <= ref ? ++j : --j) {\r\n          x = r * grid.rowWidth;\r\n          for (c = k = 0, ref1 = grid.cols; 0 <= ref1 ? k < ref1 : k > ref1; c = 0 <= ref1 ? ++k : --k) {\r\n            y = c * grid.colHeight;\r\n            item = new gridItem(x, y, grid.rowWidth, grid.colHeight);\r\n            grids.push(item);\r\n          }\r\n        }\r\n        results = [];\r\n        for (i = l = 0, ref2 = grids.length; 0 <= ref2 ? l < ref2 : l > ref2; i = 0 <= ref2 ? ++l : --l) {\r\n          results.push(grids[i].draw());\r\n        }\r\n        return results;\r\n      };\r\n\r\n      gridItem = function (x = 0, y = 0, w, h) {\r\n        this.draw = function () {\r\n          ctx.drawImage(img, x, y, w, h);\r\n        };\r\n      };\r\n\r\n      Photo = function () {\r\n        var TO_RADIANS, finalX, finalY, forceX, forceY, h, r, seed, w, x, y;\r\n        seed = Math.random() * (2.5 - 0.7) + 0.7;\r\n        w = imgInfo.width / seed;\r\n        h = imgInfo.height / seed;\r\n        x = window.innerWidth * Math.random();\r\n        finalX = x;\r\n        y = window.innerHeight * Math.random();\r\n        finalY = y;\r\n        console.log(`INIT Y :: ${finalY} || INIT X :: ${finalX}`);\r\n        r = Math.random() * (180 - -180) + -180;\r\n        forceX = 0;\r\n        forceY = 0;\r\n        TO_RADIANS = Math.PI / 180;\r\n        this.update = function () {\r\n          var distance, dx, dy, powerX, powerY, x0, x1, y0, y1;\r\n          x0 = x;\r\n          y0 = y;\r\n          x1 = mouse.x;\r\n          y1 = mouse.y;\r\n          dx = x1 - x0;\r\n          dy = y1 - y0;\r\n          distance = Math.sqrt(dx * dx + dy * dy);\r\n          powerX = x0 - dx / distance * magnet / distance;\r\n          powerY = y0 - dy / distance * magnet / distance;\r\n          forceX = (forceX + (finalX - x0) / 2) / 2.1;\r\n          forceY = (forceY + (finalY - y0) / 2) / 2.2;\r\n          x = powerX + forceX;\r\n          y = powerY + forceY;\r\n        };\r\n        this.draw = function () {\r\n          return rotateAndPaintImage(ctx, img, r * TO_RADIANS, x, y, w / 2, h / 2, w, h);\r\n        };\r\n      };\r\n\r\n      rotateAndPaintImage = function (context, image, angle, positionX, positionY, axisX, axisY, widthX, widthY) {\r\n        context.translate(positionX, positionY);\r\n        context.rotate(angle);\r\n        context.drawImage(image, -axisX, -axisY, widthX, widthY);\r\n        context.rotate(-angle);\r\n        return context.translate(-positionX, -positionY);\r\n      };\r\n\r\n      render = function () {\r\n        var x, y;\r\n        x = 0;\r\n        y = 0;\r\n        ctx.clearRect(0, 0, width, height);\r\n        while (y < grids.length) {\r\n          grids[y].draw();\r\n          y++;\r\n        }\r\n        while (x < imgs.length) {\r\n          imgs[x].update();\r\n          imgs[x].draw();\r\n          x++;\r\n        }\r\n        return requestAnimationFrame(render);\r\n      };\r\n\r\n      init();\r\n\r\n    }).call(this);\r\n  }\r\n\r\n  componentDidMount() {\r\n    this.excuteEffect()\r\n  }\r\n\r\n  render() {\r\n    const { dataImage = 'http://unsplash.it/g/450/200/?random=1' } = this.props\r\n    return (\r\n      <div className={this.props.className || ''}>\r\n        <Mosaic>\r\n          <canvas id=\"canvas\" data-image={dataImage}></canvas>\r\n          <div className=\"intro\"></div>\r\n        </Mosaic>\r\n      </div>\r\n    )\r\n  }\r\n}\r\n\r\nexport default MosaicGround"]}