UNPKG

react-background-animation

Version:
309 lines (247 loc) 37.3 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 _sketch2 = require("./sketch"); var _buildingStyled = require("./buildingStyled"); 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 CrossBuildingEffect = /*#__PURE__*/ function (_PureComponent) { _inherits(CrossBuildingEffect, _PureComponent); function CrossBuildingEffect(props) { var _this; _classCallCheck(this, CrossBuildingEffect); _this = _possibleConstructorReturn(this, _getPrototypeOf(CrossBuildingEffect).call(this, props)); _this.excuteEffect = _this.excuteEffect.bind(_assertThisInitialized(_this)); return _this; } _createClass(CrossBuildingEffect, [{ key: "excuteEffect", value: function excuteEffect() { (function () { var Building, Skyline, dt, sketch, skylines; var _sketch = (0, _sketch2.getSketch)(window, _sketch2.sketchFactory); if (!sketch) { _sketch = window.Sketch; } sketch = _sketch.create(); sketch.mouse.x = sketch.width / 10; sketch.mouse.y = sketch.height; skylines = []; dt = 1; // BUILDINGS Building = function Building(config) { return this.reset(config); }; Building.prototype.reset = function (config) { this.layer = config.layer; this.x = config.x; this.y = config.y; this.width = config.width; this.height = config.height; this.color = config.color; this.slantedTop = Math.floor(Math.random(0, 10)) === 0; this.slantedTopHeight = this.width / Math.random(2, 4); this.slantedTopDirection = Math.round(Math.random(0, 1)) === 0; this.spireTop = Math.floor(Math.random(0, 15)) === 0; this.spireTopWidth = Math.random(this.width * .01, this.width * .07); this.spireTopHeight = Math.random(10, 20); this.antennaTop = !this.spireTop && Math.floor(Math.random(0, 10)) === 0; this.antennaTopWidth = this.layer / 2; return this.antennaTopHeight = Math.random(5, 20); }; Building.prototype.render = function () { sketch.fillStyle = sketch.strokeStyle = this.color; sketch.lineWidth = 2; sketch.beginPath(); sketch.rect(this.x, this.y, this.width, this.height); sketch.fill(); sketch.stroke(); if (this.slantedTop) { sketch.beginPath(); sketch.moveTo(this.x, this.y); sketch.lineTo(this.x + this.width, this.y); if (this.slantedTopDirection) { sketch.lineTo(this.x + this.width, this.y - this.slantedTopHeight); } else { sketch.lineTo(this.x, this.y - this.slantedTopHeight); } sketch.closePath(); sketch.fill(); sketch.stroke(); } if (this.spireTop) { sketch.beginPath(); sketch.moveTo(this.x + this.width / 2, this.y - this.spireTopHeight); sketch.lineTo(this.x + this.width / 2 + this.spireTopWidth, this.y); sketch.lineTo(this.x + this.width / 2 - this.spireTopWidth, this.y); sketch.closePath(); sketch.fill(); sketch.stroke(); } if (this.antennaTop) { sketch.beginPath(); sketch.moveTo(this.x + this.width / 2, this.y - this.antennaTopHeight); sketch.lineTo(this.x + this.width / 2, this.y); sketch.lineWidth = this.antennaTopWidth; return sketch.stroke(); } }; // SKYLINES Skyline = function Skyline(config) { this.x = 0; this.buildings = []; this.layer = config.layer; this.width = { min: config.width.min, max: config.width.max }; this.height = { min: config.height.min, max: config.height.max }; this.speed = config.speed; this.color = config.color; this.populate(); return this; }; Skyline.prototype.populate = function () { var newHeight, newWidth, results, totalWidth; totalWidth = 0; results = []; while (totalWidth <= sketch.width + this.width.max * 2) { if (window.CP.shouldStopExecution(0)) break; newWidth = Math.round(Math.random(this.width.min, this.width.max)); newHeight = Math.round(Math.random(this.height.min, this.height.max)); this.buildings.push(new Building({ layer: this.layer, x: this.buildings.length === 0 ? 0 : this.buildings[this.buildings.length - 1].x + this.buildings[this.buildings.length - 1].width, y: sketch.height - newHeight, width: newWidth, height: newHeight, color: this.color })); results.push(totalWidth += newWidth); } window.CP.exitedLoop(0); return results; }; Skyline.prototype.update = function () { var firstBuilding, lastBuilding, newHeight, newWidth; this.x -= sketch.mouse.x * this.speed * dt; firstBuilding = this.buildings[0]; if (firstBuilding.width + firstBuilding.x + this.x < 0) { newWidth = Math.round(Math.random(this.width.min, this.width.max)); newHeight = Math.round(Math.random(this.height.min, this.height.max)); lastBuilding = this.buildings[this.buildings.length - 1]; firstBuilding.reset({ layer: this.layer, x: lastBuilding.x + lastBuilding.width, y: sketch.height - newHeight, width: newWidth, height: newHeight, color: this.color }); return this.buildings.push(this.buildings.shift()); } }; Skyline.prototype.render = function () { var i; i = this.buildings.length; sketch.save(); sketch.translate(this.x, (sketch.height - sketch.mouse.y) / 20 * this.layer); while (i--) { if (window.CP.shouldStopExecution(1)) break; this.buildings[i].render(i); } window.CP.exitedLoop(1); return sketch.restore(); }; // SETUP sketch.setup = function () { var i, results; i = 5; results = []; while (i--) { if (window.CP.shouldStopExecution(2)) break; results.push(skylines.push(new Skyline({ layer: i + 1, width: { min: (i + 1) * 30, max: (i + 1) * 40 }, height: { min: 150 - i * 35, max: 300 - i * 35 }, speed: (i + 1) * .003, color: 'hsl( 200, ' + ((i + 1) * 1 + 10) + '%, ' + (75 - i * 13) + '% )' }))); } window.CP.exitedLoop(2); return results; }; // CLEAR sketch.clear = function () { return sketch.clearRect(0, 0, sketch.width, sketch.height); }; // UPDATE sketch.update = function () { var i, results; dt = sketch.dt < .1 ? .1 : sketch.dt / 16; dt = dt > 5 ? 5 : dt; i = skylines.length; results = []; while (i--) { if (window.CP.shouldStopExecution(3)) break; results.push(skylines[i].update(i)); } window.CP.exitedLoop(3); return results; }; // DRAW sketch.draw = function () { var i, results; i = skylines.length; results = []; while (i--) { if (window.CP.shouldStopExecution(4)) break; results.push(skylines[i].render(i)); } window.CP.exitedLoop(4); return results; }; // Mousemove Fix (0, _jquery["default"])(window).on('mousemove', function (e) { sketch.mouse.x = e.pageX; return sketch.mouse.y = e.pageY; }); }).call(this); //# sourceURL=coffeescript } }, { key: "componentDidMount", value: function componentDidMount() { this.excuteEffect(); } }, { key: "render", value: function render() { return _react["default"].createElement("div", { className: this.props.className || '' }, _react["default"].createElement(_buildingStyled.Building, null)); } }]); return CrossBuildingEffect; }(_react.PureComponent); var _default = CrossBuildingEffect; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/cssEffects/crossBuilding/crossBuilding.jsx"],"names":["CrossBuildingEffect","props","excuteEffect","bind","Building","Skyline","dt","sketch","skylines","_sketch","window","sketchFactory","Sketch","create","mouse","x","width","y","height","config","reset","prototype","layer","color","slantedTop","Math","floor","random","slantedTopHeight","slantedTopDirection","round","spireTop","spireTopWidth","spireTopHeight","antennaTop","antennaTopWidth","antennaTopHeight","render","fillStyle","strokeStyle","lineWidth","beginPath","rect","fill","stroke","moveTo","lineTo","closePath","buildings","min","max","speed","populate","newHeight","newWidth","results","totalWidth","CP","shouldStopExecution","push","length","exitedLoop","update","firstBuilding","lastBuilding","shift","i","save","translate","restore","setup","clear","clearRect","draw","on","e","pageX","pageY","call","className","PureComponent"],"mappings":"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","sourcesContent":["import React, { PureComponent } from 'react';\r\nimport _ from 'lodash'\r\nimport $ from 'jquery'\r\nimport { getSketch, sketchFactory } from './sketch'\r\n\r\n// import './building.scss'\r\nimport { Building } from './buildingStyled'\r\n\r\n// const Sketch = getSketch()\r\n\r\nclass CrossBuildingEffect 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 Building, Skyline, dt, sketch, skylines;\r\n\r\n      var _sketch = getSketch(window, sketchFactory);\r\n      if (!sketch) {\r\n        _sketch = window.Sketch\r\n      }\r\n      sketch = _sketch.create()\r\n\r\n      sketch.mouse.x = sketch.width / 10;\r\n\r\n      sketch.mouse.y = sketch.height;\r\n\r\n      skylines = [];\r\n\r\n      dt = 1;\r\n\r\n\r\n      // BUILDINGS\r\n\r\n      Building = function (config) {\r\n        return this.reset(config);\r\n      };\r\n\r\n      Building.prototype.reset = function (config) {\r\n        this.layer = config.layer;\r\n        this.x = config.x;\r\n        this.y = config.y;\r\n        this.width = config.width;\r\n        this.height = config.height;\r\n        this.color = config.color;\r\n        this.slantedTop = Math.floor(Math.random(0, 10)) === 0;\r\n        this.slantedTopHeight = this.width / Math.random(2, 4);\r\n        this.slantedTopDirection = Math.round(Math.random(0, 1)) === 0;\r\n        this.spireTop = Math.floor(Math.random(0, 15)) === 0;\r\n        this.spireTopWidth = Math.random(this.width * .01, this.width * .07);\r\n        this.spireTopHeight = Math.random(10, 20);\r\n        this.antennaTop = !this.spireTop && Math.floor(Math.random(0, 10)) === 0;\r\n        this.antennaTopWidth = this.layer / 2;\r\n        return this.antennaTopHeight = Math.random(5, 20);\r\n      };\r\n\r\n      Building.prototype.render = function () {\r\n        sketch.fillStyle = sketch.strokeStyle = this.color;\r\n        sketch.lineWidth = 2;\r\n        sketch.beginPath();\r\n        sketch.rect(this.x, this.y, this.width, this.height);\r\n        sketch.fill();\r\n        sketch.stroke();\r\n        if (this.slantedTop) {\r\n          sketch.beginPath();\r\n          sketch.moveTo(this.x, this.y);\r\n          sketch.lineTo(this.x + this.width, this.y);\r\n          if (this.slantedTopDirection) {\r\n            sketch.lineTo(this.x + this.width, this.y - this.slantedTopHeight);\r\n          } else {\r\n            sketch.lineTo(this.x, this.y - this.slantedTopHeight);\r\n          }\r\n          sketch.closePath();\r\n          sketch.fill();\r\n          sketch.stroke();\r\n        }\r\n        if (this.spireTop) {\r\n          sketch.beginPath();\r\n          sketch.moveTo(this.x + this.width / 2, this.y - this.spireTopHeight);\r\n          sketch.lineTo(this.x + this.width / 2 + this.spireTopWidth, this.y);\r\n          sketch.lineTo(this.x + this.width / 2 - this.spireTopWidth, this.y);\r\n          sketch.closePath();\r\n          sketch.fill();\r\n          sketch.stroke();\r\n        }\r\n        if (this.antennaTop) {\r\n          sketch.beginPath();\r\n          sketch.moveTo(this.x + this.width / 2, this.y - this.antennaTopHeight);\r\n          sketch.lineTo(this.x + this.width / 2, this.y);\r\n          sketch.lineWidth = this.antennaTopWidth;\r\n          return sketch.stroke();\r\n        }\r\n      };\r\n\r\n\r\n      // SKYLINES\r\n\r\n      Skyline = function (config) {\r\n        this.x = 0;\r\n        this.buildings = [];\r\n        this.layer = config.layer;\r\n        this.width = {\r\n          min: config.width.min,\r\n          max: config.width.max\r\n        };\r\n\r\n        this.height = {\r\n          min: config.height.min,\r\n          max: config.height.max\r\n        };\r\n\r\n        this.speed = config.speed;\r\n        this.color = config.color;\r\n        this.populate();\r\n        return this;\r\n      };\r\n\r\n      Skyline.prototype.populate = function () {\r\n        var newHeight, newWidth, results, totalWidth;\r\n        totalWidth = 0;\r\n        results = [];\r\n        while (totalWidth <= sketch.width + this.width.max * 2) {\r\n          if (window.CP.shouldStopExecution(0)) break;\r\n          newWidth = Math.round(Math.random(this.width.min, this.width.max));\r\n          newHeight = Math.round(Math.random(this.height.min, this.height.max));\r\n          this.buildings.push(new Building({\r\n            layer: this.layer,\r\n            x: this.buildings.length === 0 ? 0 : this.buildings[this.buildings.length - 1].x + this.buildings[this.buildings.length - 1].width,\r\n            y: sketch.height - newHeight,\r\n            width: newWidth,\r\n            height: newHeight,\r\n            color: this.color\r\n          }));\r\n\r\n          results.push(totalWidth += newWidth);\r\n        } window.CP.exitedLoop(0);\r\n        return results;\r\n      };\r\n\r\n      Skyline.prototype.update = function () {\r\n        var firstBuilding, lastBuilding, newHeight, newWidth;\r\n        this.x -= sketch.mouse.x * this.speed * dt;\r\n        firstBuilding = this.buildings[0];\r\n        if (firstBuilding.width + firstBuilding.x + this.x < 0) {\r\n          newWidth = Math.round(Math.random(this.width.min, this.width.max));\r\n          newHeight = Math.round(Math.random(this.height.min, this.height.max));\r\n          lastBuilding = this.buildings[this.buildings.length - 1];\r\n          firstBuilding.reset({\r\n            layer: this.layer,\r\n            x: lastBuilding.x + lastBuilding.width,\r\n            y: sketch.height - newHeight,\r\n            width: newWidth,\r\n            height: newHeight,\r\n            color: this.color\r\n          });\r\n\r\n          return this.buildings.push(this.buildings.shift());\r\n        }\r\n      };\r\n\r\n      Skyline.prototype.render = function () {\r\n        var i;\r\n        i = this.buildings.length;\r\n        sketch.save();\r\n        sketch.translate(this.x, (sketch.height - sketch.mouse.y) / 20 * this.layer);\r\n        while (i--) {\r\n          if (window.CP.shouldStopExecution(1)) break;\r\n          this.buildings[i].render(i);\r\n        } window.CP.exitedLoop(1);\r\n        return sketch.restore();\r\n      };\r\n\r\n\r\n      // SETUP\r\n\r\n      sketch.setup = function () {\r\n        var i, results;\r\n        i = 5;\r\n        results = [];\r\n        while (i--) {\r\n          if (window.CP.shouldStopExecution(2)) break;\r\n          results.push(skylines.push(new Skyline({\r\n            layer: i + 1,\r\n            width: {\r\n              min: (i + 1) * 30,\r\n              max: (i + 1) * 40\r\n            },\r\n\r\n            height: {\r\n              min: 150 - i * 35,\r\n              max: 300 - i * 35\r\n            },\r\n\r\n            speed: (i + 1) * .003,\r\n            color: 'hsl( 200, ' + ((i + 1) * 1 + 10) + '%, ' + (75 - i * 13) + '% )'\r\n          })));\r\n\r\n        } window.CP.exitedLoop(2);\r\n        return results;\r\n      };\r\n\r\n\r\n      // CLEAR\r\n\r\n      sketch.clear = function () {\r\n        return sketch.clearRect(0, 0, sketch.width, sketch.height);\r\n      };\r\n\r\n\r\n      // UPDATE\r\n\r\n      sketch.update = function () {\r\n        var i, results;\r\n        dt = sketch.dt < .1 ? .1 : sketch.dt / 16;\r\n        dt = dt > 5 ? 5 : dt;\r\n        i = skylines.length;\r\n        results = [];\r\n        while (i--) {\r\n          if (window.CP.shouldStopExecution(3)) break;\r\n          results.push(skylines[i].update(i));\r\n        } window.CP.exitedLoop(3);\r\n        return results;\r\n      };\r\n\r\n\r\n      // DRAW\r\n\r\n      sketch.draw = function () {\r\n        var i, results;\r\n        i = skylines.length;\r\n        results = [];\r\n        while (i--) {\r\n          if (window.CP.shouldStopExecution(4)) break;\r\n          results.push(skylines[i].render(i));\r\n        } window.CP.exitedLoop(4);\r\n        return results;\r\n      };\r\n\r\n\r\n      // Mousemove Fix\r\n\r\n      $(window).on('mousemove', function (e) {\r\n        sketch.mouse.x = e.pageX;\r\n        return sketch.mouse.y = e.pageY;\r\n      });\r\n\r\n    }).call(this);\r\n\r\n\r\n    //# sourceURL=coffeescript\r\n  }\r\n\r\n  componentDidMount() {\r\n    this.excuteEffect()\r\n  }\r\n\r\n  render() {\r\n    return (\r\n      <div className={this.props.className || ''}>\r\n        <Building />\r\n      </div>\r\n    )\r\n  }\r\n}\r\n\r\nexport default CrossBuildingEffect"]}