UNPKG

butterchurn

Version:

Butterchurn is a WebGL implementation of the Milkdrop Visualizer

1,206 lines (1,057 loc) 331 kB
(function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(); else if(typeof define === 'function' && define.amd) define("butterchurn", [], factory); else if(typeof exports === 'object') exports["butterchurn"] = factory(); else root["butterchurn"] = 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 = "./src/index.js"); /******/ }) /************************************************************************/ /******/ ({ /***/ "./node_modules/ecma-proposal-math-extensions/reference-implementation/index.js": /*!**************************************************************************************!*\ !*** ./node_modules/ecma-proposal-math-extensions/reference-implementation/index.js ***! \**************************************************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; { const defineMath = (name, assignment) => { var configurable = typeof assignment === "function" ? true : false; var writable = typeof assignment === "function" ? true : false; var enumerable = typeof assignment === "function" ? true : false; Object.defineProperty(Math, name, { configurable: configurable, enumerable: enumerable, writable: writable, value: assignment }); }; defineMath("DEG_PER_RAD", Math.PI / 180); defineMath("RAD_PER_DEG", 180 / Math.PI); const f32A = new Float32Array(1); defineMath("scale", function scale(x, inLow, inHigh, outLow, outHigh) { if (arguments.length === 0) { return NaN; } if (Number.isNaN(x) || Number.isNaN(inLow) || Number.isNaN(inHigh) || Number.isNaN(outLow) || Number.isNaN(outHigh)) { return NaN; } if (x === Infinity || x === -Infinity) { return x; } return (x - inLow) * (outHigh - outLow) / (inHigh - inLow) + outLow; }); defineMath("fscale", function fscale(x, inLow, inHigh, outLow, outHigh) { f32A[0] = Math.scale(x, inLow, inHigh, outLow, outHigh); return f32A[0]; }); defineMath("clamp", function clamp(x, lower, upper) { return Math.min(upper, Math.max(lower, x)); }); defineMath("radians", function radians(degrees) { return degrees * Math.DEG_PER_RAD; }); defineMath("degrees", function degrees(radians) { return radians * Math.RAD_PER_DEG; }); } /***/ }), /***/ "./src/audio/audioLevels.js": /*!**********************************!*\ !*** ./src/audio/audioLevels.js ***! \**********************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return AudioLevels; }); 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; } var AudioLevels = /*#__PURE__*/ function () { function AudioLevels(audio) { _classCallCheck(this, AudioLevels); this.audio = audio; var sampleRate; if (this.audio.audioContext) { sampleRate = this.audio.audioContext.sampleRate; } else { sampleRate = 44100; } var bucketHz = sampleRate / this.audio.fftSize; var bassLow = Math.clamp(Math.round(20 / bucketHz) - 1, 0, this.audio.numSamps - 1); var bassHigh = Math.clamp(Math.round(320 / bucketHz) - 1, 0, this.audio.numSamps - 1); var midHigh = Math.clamp(Math.round(2800 / bucketHz) - 1, 0, this.audio.numSamps - 1); var trebHigh = Math.clamp(Math.round(11025 / bucketHz) - 1, 0, this.audio.numSamps - 1); this.starts = [bassLow, bassHigh, midHigh]; this.stops = [bassHigh, midHigh, trebHigh]; this.val = new Float32Array(3); this.imm = new Float32Array(3); this.att = new Float32Array(3); this.avg = new Float32Array(3); this.longAvg = new Float32Array(3); this.att.fill(1); this.avg.fill(1); this.longAvg.fill(1); } /* eslint-disable camelcase */ _createClass(AudioLevels, [{ key: "updateAudioLevels", value: function updateAudioLevels(fps, frame) { if (this.audio.freqArray.length > 0) { var effectiveFPS = fps; if (!AudioLevels.isFiniteNumber(effectiveFPS) || effectiveFPS < 15) { effectiveFPS = 15; } else if (effectiveFPS > 144) { effectiveFPS = 144; } // Clear for next loop this.imm.fill(0); for (var i = 0; i < 3; i++) { for (var j = this.starts[i]; j < this.stops[i]; j++) { this.imm[i] += this.audio.freqArray[j]; } } for (var _i = 0; _i < 3; _i++) { var rate = void 0; if (this.imm[_i] > this.avg[_i]) { rate = 0.2; } else { rate = 0.5; } rate = AudioLevels.adjustRateToFPS(rate, 30.0, effectiveFPS); this.avg[_i] = this.avg[_i] * rate + this.imm[_i] * (1 - rate); if (frame < 50) { rate = 0.9; } else { rate = 0.992; } rate = AudioLevels.adjustRateToFPS(rate, 30.0, effectiveFPS); this.longAvg[_i] = this.longAvg[_i] * rate + this.imm[_i] * (1 - rate); if (this.longAvg[_i] < 0.001) { this.val[_i] = 1.0; this.att[_i] = 1.0; } else { this.val[_i] = this.imm[_i] / this.longAvg[_i]; this.att[_i] = this.avg[_i] / this.longAvg[_i]; } } } } }, { key: "bass", get: function get() { return this.val[0]; } }, { key: "bass_att", get: function get() { return this.att[0]; } }, { key: "mid", get: function get() { return this.val[1]; } }, { key: "mid_att", get: function get() { return this.att[1]; } }, { key: "treb", get: function get() { return this.val[2]; } }, { key: "treb_att", get: function get() { return this.att[2]; } /* eslint-enable camelcase */ }], [{ key: "isFiniteNumber", value: function isFiniteNumber(num) { return Number.isFinite(num) && !Number.isNaN(num); } }, { key: "adjustRateToFPS", value: function adjustRateToFPS(rate, baseFPS, FPS) { return Math.pow(rate, baseFPS / FPS); } }]); return AudioLevels; }(); /***/ }), /***/ "./src/audio/audioProcessor.js": /*!*************************************!*\ !*** ./src/audio/audioProcessor.js ***! \*************************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return AudioProcessor; }); /* harmony import */ var _fft__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./fft */ "./src/audio/fft.js"); 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; } var AudioProcessor = /*#__PURE__*/ function () { function AudioProcessor(context) { _classCallCheck(this, AudioProcessor); this.numSamps = 512; this.fftSize = this.numSamps * 2; this.fft = new _fft__WEBPACK_IMPORTED_MODULE_0__["default"](this.fftSize, 512, true); if (context) { this.audioContext = context; this.audible = context.createDelay(); this.analyser = context.createAnalyser(); this.analyser.smoothingTimeConstant = 0.0; this.analyser.fftSize = this.fftSize; this.audible.connect(this.analyser); // Split channels this.analyserL = context.createAnalyser(); this.analyserL.smoothingTimeConstant = 0.0; this.analyserL.fftSize = this.fftSize; this.analyserR = context.createAnalyser(); this.analyserR.smoothingTimeConstant = 0.0; this.analyserR.fftSize = this.fftSize; this.splitter = context.createChannelSplitter(2); this.audible.connect(this.splitter); this.splitter.connect(this.analyserL, 0); this.splitter.connect(this.analyserR, 1); } // Initialised once as typed arrays // Used for webaudio API raw (time domain) samples. 0 -> 255 this.timeByteArray = new Uint8Array(this.fftSize); this.timeByteArrayL = new Uint8Array(this.fftSize); this.timeByteArrayR = new Uint8Array(this.fftSize); // Signed raw samples shifted to -128 -> 127 this.timeArray = new Int8Array(this.fftSize); this.timeByteArraySignedL = new Int8Array(this.fftSize); this.timeByteArraySignedR = new Int8Array(this.fftSize); // Temporary array for smoothing this.tempTimeArrayL = new Int8Array(this.fftSize); this.tempTimeArrayR = new Int8Array(this.fftSize); // Undersampled from this.fftSize to this.numSamps this.timeArrayL = new Int8Array(this.numSamps); this.timeArrayR = new Int8Array(this.numSamps); } _createClass(AudioProcessor, [{ key: "sampleAudio", value: function sampleAudio() { this.analyser.getByteTimeDomainData(this.timeByteArray); this.analyserL.getByteTimeDomainData(this.timeByteArrayL); this.analyserR.getByteTimeDomainData(this.timeByteArrayR); this.processAudio(); } }, { key: "updateAudio", value: function updateAudio(timeByteArray, timeByteArrayL, timeByteArrayR) { this.timeByteArray.set(timeByteArray); this.timeByteArrayL.set(timeByteArrayL); this.timeByteArrayR.set(timeByteArrayR); this.processAudio(); } /* eslint-disable no-bitwise */ }, { key: "processAudio", value: function processAudio() { for (var i = 0, j = 0, lastIdx = 0; i < this.fftSize; i++) { // Shift Unsigned to Signed about 0 this.timeArray[i] = this.timeByteArray[i] - 128; this.timeByteArraySignedL[i] = this.timeByteArrayL[i] - 128; this.timeByteArraySignedR[i] = this.timeByteArrayR[i] - 128; this.tempTimeArrayL[i] = 0.5 * (this.timeByteArraySignedL[i] + this.timeByteArraySignedL[lastIdx]); this.tempTimeArrayR[i] = 0.5 * (this.timeByteArraySignedR[i] + this.timeByteArraySignedR[lastIdx]); // Undersampled if (i % 2 === 0) { this.timeArrayL[j] = this.tempTimeArrayL[i]; this.timeArrayR[j] = this.tempTimeArrayR[i]; j += 1; } lastIdx = i; } // Use full width samples for the FFT this.freqArray = this.fft.timeToFrequencyDomain(this.timeArray); this.freqArrayL = this.fft.timeToFrequencyDomain(this.timeByteArraySignedL); this.freqArrayR = this.fft.timeToFrequencyDomain(this.timeByteArraySignedR); } }, { key: "connectAudio", value: function connectAudio(audionode) { audionode.connect(this.audible); } }, { key: "disconnectAudio", value: function disconnectAudio(audionode) { audionode.disconnect(this.audible); } /* eslint-enable no-bitwise */ }]); return AudioProcessor; }(); /***/ }), /***/ "./src/audio/fft.js": /*!**************************!*\ !*** ./src/audio/fft.js ***! \**************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return FFT; }); 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; } var FFT = /*#__PURE__*/ function () { function FFT(samplesIn, samplesOut) { var equalize = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; _classCallCheck(this, FFT); this.samplesIn = samplesIn; this.samplesOut = samplesOut; this.equalize = equalize; this.NFREQ = samplesOut * 2; if (this.equalize) { this.initEqualizeTable(); } this.initBitRevTable(); this.initCosSinTable(); } _createClass(FFT, [{ key: "initEqualizeTable", value: function initEqualizeTable() { this.equalizeArr = new Float32Array(this.samplesOut); var invHalfNFREQ = 1.0 / this.samplesOut; for (var i = 0; i < this.samplesOut; i++) { this.equalizeArr[i] = -0.02 * Math.log((this.samplesOut - i) * invHalfNFREQ); } } /* eslint-disable no-bitwise */ }, { key: "initBitRevTable", value: function initBitRevTable() { this.bitrevtable = new Uint16Array(this.NFREQ); for (var i = 0; i < this.NFREQ; i++) { this.bitrevtable[i] = i; } var j = 0; for (var _i = 0; _i < this.NFREQ; _i++) { if (j > _i) { var temp = this.bitrevtable[_i]; this.bitrevtable[_i] = this.bitrevtable[j]; this.bitrevtable[j] = temp; } var m = this.NFREQ >> 1; while (m >= 1 && j >= m) { j -= m; m >>= 1; } j += m; } } }, { key: "initCosSinTable", value: function initCosSinTable() { var dftsize = 2; var tabsize = 0; while (dftsize <= this.NFREQ) { tabsize += 1; dftsize <<= 1; } this.cossintable = [new Float32Array(tabsize), new Float32Array(tabsize)]; dftsize = 2; var i = 0; while (dftsize <= this.NFREQ) { var theta = -2.0 * Math.PI / dftsize; this.cossintable[0][i] = Math.cos(theta); this.cossintable[1][i] = Math.sin(theta); i += 1; dftsize <<= 1; } } }, { key: "timeToFrequencyDomain", value: function timeToFrequencyDomain(waveDataIn) { var real = new Float32Array(this.NFREQ); var imag = new Float32Array(this.NFREQ); for (var i = 0; i < this.NFREQ; i++) { var idx = this.bitrevtable[i]; if (idx < this.samplesIn) { real[i] = waveDataIn[idx]; } else { real[i] = 0; } imag[i] = 0; } var dftsize = 2; var t = 0; while (dftsize <= this.NFREQ) { var wpr = this.cossintable[0][t]; var wpi = this.cossintable[1][t]; var wr = 1.0; var wi = 0.0; var hdftsize = dftsize >> 1; for (var m = 0; m < hdftsize; m++) { for (var _i2 = m; _i2 < this.NFREQ; _i2 += dftsize) { var j = _i2 + hdftsize; var tempr = wr * real[j] - wi * imag[j]; var tempi = wr * imag[j] + wi * real[j]; real[j] = real[_i2] - tempr; imag[j] = imag[_i2] - tempi; real[_i2] += tempr; imag[_i2] += tempi; } var wtemp = wr; wr = wtemp * wpr - wi * wpi; wi = wi * wpr + wtemp * wpi; } dftsize <<= 1; t += 1; } var spectralDataOut = new Float32Array(this.samplesOut); if (this.equalize) { for (var _i3 = 0; _i3 < this.samplesOut; _i3++) { spectralDataOut[_i3] = this.equalizeArr[_i3] * Math.sqrt(real[_i3] * real[_i3] + imag[_i3] * imag[_i3]); } } else { for (var _i4 = 0; _i4 < this.samplesOut; _i4++) { spectralDataOut[_i4] = Math.sqrt(real[_i4] * real[_i4] + imag[_i4] * imag[_i4]); } } return spectralDataOut; } /* eslint-enable no-bitwise */ }]); return FFT; }(); /***/ }), /***/ "./src/blankPreset.js": /*!****************************!*\ !*** ./src/blankPreset.js ***! \****************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/* eslint-disable */ !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = (function () { 'use strict;'; var pmap = { baseVals: { gammaadj: 1.25, wave_g: 0.5, mv_x: 12.0, warpscale: 1.0, brighten: 0.0, mv_y: 9.0, wave_scale: 1.0, echo_alpha: 0.0, additivewave: 0.0, sx: 1.0, sy: 1.0, warp: 0.01, red_blue: 0.0, wave_mode: 0.0, wave_brighten: 0.0, wrap: 0.0, zoomexp: 1.0, fshader: 0.0, wave_r: 0.5, echo_zoom: 1.0, wave_smoothing: 0.75, warpanimspeed: 1.0, wave_dots: 0.0, wave_x: 0.5, wave_y: 0.5, zoom: 1.0, solarize: 0.0, modwavealphabyvolume: 0.0, dx: 0.0, cx: 0.5, dy: 0.0, darken_center: 0.0, cy: 0.5, invert: 0.0, bmotionvectorson: 0.0, rot: 0.0, modwavealphaend: 0.95, wave_mystery: -0.2, decay: 0.9, wave_a: 1.0, wave_b: 0.5, rating: 5.0, modwavealphastart: 0.75, darken: 0.0, echo_orient: 0.0, ib_r: 0.5, ib_g: 0.5, ib_b: 0.5, ib_a: 0.0, ib_size: 0.0, ob_r: 0.5, ob_g: 0.5, ob_b: 0.5, ob_a: 0.0, ob_size: 0.0, mv_dx: 0.0, mv_dy: 0.0, mv_a: 0.0, mv_r: 0.5, mv_g: 0.5, mv_b: 0.5, mv_l: 0.0 }, init_eqs: function init_eqs() { var m = {}; return m; }, frame_eqs: function frame_eqs(m) { m.rkeys = ['warp']; m.zoom = 1.01 + 0.02 * m.treb_att; m.warp = 0.15 + 0.25 * m.bass_att; return m; }, pixel_eqs: function pixel_eqs(m) { m.warp = m.warp + m.rad * 0.15; return m; }, waves: [{ baseVals: { a: 1.0, enabled: 0.0, b: 1.0, g: 1.0, scaling: 1.0, samples: 512.0, additive: 0.0, usedots: 0.0, spectrum: 0.0, r: 1.0, smoothing: 0.5, thick: 0.0, sep: 0.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; }, point_eqs: '' }, { baseVals: { a: 1.0, enabled: 0.0, b: 1.0, g: 1.0, scaling: 1.0, samples: 512.0, additive: 0.0, usedots: 0.0, spectrum: 0.0, r: 1.0, smoothing: 0.5, thick: 0.0, sep: 0.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; }, point_eqs: '' }, { baseVals: { a: 1.0, enabled: 0.0, b: 1.0, g: 1.0, scaling: 1.0, samples: 512.0, additive: 0.0, usedots: 0.0, spectrum: 0.0, r: 1.0, smoothing: 0.5, thick: 0.0, sep: 0.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; }, point_eqs: '' }, { baseVals: { a: 1.0, enabled: 0.0, b: 1.0, g: 1.0, scaling: 1.0, samples: 512.0, additive: 0.0, usedots: 0.0, spectrum: 0.0, r: 1.0, smoothing: 0.5, thick: 0.0, sep: 0.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; }, point_eqs: '' }], shapes: [{ baseVals: { r2: 0.0, a: 1.0, enabled: 0.0, b: 0.0, tex_ang: 0.0, thickoutline: 0.0, g: 0.0, textured: 0.0, g2: 1.0, tex_zoom: 1.0, additive: 0.0, border_a: 0.1, border_b: 1.0, b2: 0.0, a2: 0.0, r: 1.0, border_g: 1.0, rad: 0.1, x: 0.5, y: 0.5, ang: 0.0, sides: 4.0, border_r: 1.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; } }, { baseVals: { r2: 0.0, a: 1.0, enabled: 0.0, b: 0.0, tex_ang: 0.0, thickoutline: 0.0, g: 0.0, textured: 0.0, g2: 1.0, tex_zoom: 1.0, additive: 0.0, border_a: 0.1, border_b: 1.0, b2: 0.0, a2: 0.0, r: 1.0, border_g: 1.0, rad: 0.1, x: 0.5, y: 0.5, ang: 0.0, sides: 4.0, border_r: 1.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; } }, { baseVals: { r2: 0.0, a: 1.0, enabled: 0.0, b: 0.0, tex_ang: 0.0, thickoutline: 0.0, g: 0.0, textured: 0.0, g2: 1.0, tex_zoom: 1.0, additive: 0.0, border_a: 0.1, border_b: 1.0, b2: 0.0, a2: 0.0, r: 1.0, border_g: 1.0, rad: 0.1, x: 0.5, y: 0.5, ang: 0.0, sides: 4.0, border_r: 1.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; } }, { baseVals: { r2: 0.0, a: 1.0, enabled: 0.0, b: 0.0, tex_ang: 0.0, thickoutline: 0.0, g: 0.0, textured: 0.0, g2: 1.0, tex_zoom: 1.0, additive: 0.0, border_a: 0.1, border_b: 1.0, b2: 0.0, a2: 0.0, r: 1.0, border_g: 1.0, rad: 0.1, x: 0.5, y: 0.5, ang: 0.0, sides: 4.0, border_r: 1.0 }, init_eqs: function init_eqs(m) { m.rkeys = []; return m; }, frame_eqs: function frame_eqs(m) { return m; } }], warp: 'shader_body {\nret = texture2D(sampler_main, uv).rgb;\nret -= 0.004;\n}\n', comp: 'shader_body {\nret = texture2D(sampler_main, uv).rgb;\nret *= hue_shader;\n}\n' }; return pmap; }).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); /* eslint-enable */ /***/ }), /***/ "./src/equations/presetEquationRunner.js": /*!***********************************************!*\ !*** ./src/equations/presetEquationRunner.js ***! \***********************************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return PresetEquationRunner; }); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils */ "./src/utils.js"); 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; } var PresetEquationRunner = /*#__PURE__*/ function () { function PresetEquationRunner(preset, globalVars, opts) { _classCallCheck(this, PresetEquationRunner); this.preset = preset; this.texsizeX = opts.texsizeX; this.texsizeY = opts.texsizeY; this.mesh_width = opts.mesh_width; this.mesh_height = opts.mesh_height; this.aspectx = opts.aspectx; this.aspecty = opts.aspecty; this.invAspectx = 1.0 / this.aspectx; this.invAspecty = 1.0 / this.aspecty; this.qs = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].range(1, 33).map(function (x) { return "q".concat(x); }); this.ts = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].range(1, 9).map(function (x) { return "t".concat(x); }); this.regs = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].range(100).map(function (x) { if (x < 10) { return "reg0".concat(x); } return "reg".concat(x); }); this.initializeEquations(globalVars); } _createClass(PresetEquationRunner, [{ key: "initializeEquations", value: function initializeEquations(globalVars) { this.runVertEQs = this.preset.pixel_eqs !== ''; this.mdVSQInit = null; this.mdVSRegs = null; this.mdVSFrame = null; this.mdVSUserKeys = null; this.mdVSFrameMap = null; this.mdVSShapes = null; this.mdVSUserKeysShapes = null; this.mdVSFrameMapShapes = null; this.mdVSWaves = null; this.mdVSUserKeysWaves = null; this.mdVSFrameMapWaves = null; this.mdVSQAfterFrame = null; this.gmegabuf = new Array(1048576).fill(0); var mdVSBase = { frame: globalVars.frame, time: globalVars.time, fps: globalVars.fps, bass: globalVars.bass, bass_att: globalVars.bass_att, mid: globalVars.mid, mid_att: globalVars.mid_att, treb: globalVars.treb, treb_att: globalVars.treb_att, meshx: this.mesh_width, meshy: this.mesh_height, aspectx: this.invAspectx, aspecty: this.invAspecty, pixelsx: this.texsizeX, pixelsy: this.texsizeY, gmegabuf: this.gmegabuf }; this.mdVS = Object.assign({}, this.preset.baseVals, mdVSBase); this.mdVS.megabuf = new Array(1048576).fill(0); this.mdVS.rand_start = new Float32Array([Math.random(), Math.random(), Math.random(), Math.random()]); this.mdVS.rand_preset = new Float32Array([Math.random(), Math.random(), Math.random(), Math.random()]); var nonUserKeys = this.qs.concat(this.regs, Object.keys(this.mdVS)); var mdVSAfterInit = this.preset.init_eqs(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].cloneVars(this.mdVS)); // qs need to be initialized to there init values every frame this.mdVSQInit = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSAfterInit, this.qs); this.mdVSRegs = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSAfterInit, this.regs); var initUserVars = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSAfterInit, Object.keys(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].omit(mdVSAfterInit, nonUserKeys))); initUserVars.megabuf = mdVSAfterInit.megabuf; initUserVars.gmegabuf = mdVSAfterInit.gmegabuf; this.mdVSFrame = this.preset.frame_eqs(Object.assign({}, this.mdVS, this.mdVSQInit, this.mdVSRegs, initUserVars)); // user vars need to be copied between frames this.mdVSUserKeys = Object.keys(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].omit(this.mdVSFrame, nonUserKeys)); // Determine vars to carry over between frames this.mdVSFrameMap = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(this.mdVSFrame, this.mdVSUserKeys); // qs for shapes this.mdVSQAfterFrame = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(this.mdVSFrame, this.qs); this.mdVSRegs = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(this.mdVSFrame, this.regs); this.mdVSWaves = []; this.mdVSTWaveInits = []; this.mdVSUserKeysWaves = []; this.mdVSFrameMapWaves = []; if (this.preset.waves && this.preset.waves.length > 0) { for (var i = 0; i < this.preset.waves.length; i++) { var wave = this.preset.waves[i]; var baseVals = wave.baseVals; if (baseVals.enabled !== 0) { var mdVSWave = Object.assign({}, baseVals, mdVSBase); var nonUserWaveKeys = this.qs.concat(this.ts, this.regs, Object.keys(mdVSWave)); Object.assign(mdVSWave, this.mdVSQAfterFrame, this.mdVSRegs); mdVSWave.megabuf = new Array(1048576).fill(0); if (wave.init_eqs) { mdVSWave = wave.init_eqs(mdVSWave); this.mdVSRegs = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSWave, this.regs); // base vals need to be reset Object.assign(mdVSWave, baseVals); } this.mdVSWaves.push(mdVSWave); this.mdVSTWaveInits.push(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSWave, this.ts)); this.mdVSUserKeysWaves.push(Object.keys(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].omit(mdVSWave, nonUserWaveKeys))); this.mdVSFrameMapWaves.push(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSWave, this.mdVSUserKeysWaves[i])); } else { this.mdVSWaves.push({}); this.mdVSTWaveInits.push({}); this.mdVSUserKeysWaves.push([]); this.mdVSFrameMapWaves.push({}); } } } this.mdVSShapes = []; this.mdVSTShapeInits = []; this.mdVSUserKeysShapes = []; this.mdVSFrameMapShapes = []; if (this.preset.shapes && this.preset.shapes.length > 0) { for (var _i = 0; _i < this.preset.shapes.length; _i++) { var shape = this.preset.shapes[_i]; var _baseVals = shape.baseVals; if (_baseVals.enabled !== 0) { var mdVSShape = Object.assign({}, _baseVals, mdVSBase); var nonUserShapeKeys = this.qs.concat(this.ts, this.regs, Object.keys(mdVSShape)); Object.assign(mdVSShape, this.mdVSQAfterFrame, this.mdVSRegs); mdVSShape.megabuf = new Array(1048576).fill(0); if (shape.init_eqs) { mdVSShape = shape.init_eqs(mdVSShape); this.mdVSRegs = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSShape, this.regs); // base vals need to be reset Object.assign(mdVSShape, _baseVals); } this.mdVSShapes.push(mdVSShape); this.mdVSTShapeInits.push(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSShape, this.ts)); this.mdVSUserKeysShapes.push(Object.keys(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].omit(mdVSShape, nonUserShapeKeys))); this.mdVSFrameMapShapes.push(_utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(mdVSShape, this.mdVSUserKeysShapes[_i])); } else { this.mdVSShapes.push({}); this.mdVSTShapeInits.push({}); this.mdVSUserKeysShapes.push([]); this.mdVSFrameMapShapes.push({}); } } } } }, { key: "updatePreset", value: function updatePreset(preset, globalVars) { this.preset = preset; this.initializeEquations(globalVars); } }, { key: "updateGlobals", value: function updateGlobals(opts) { this.texsizeX = opts.texsizeX; this.texsizeY = opts.texsizeY; this.mesh_width = opts.mesh_width; this.mesh_height = opts.mesh_height; this.aspectx = opts.aspectx; this.aspecty = opts.aspecty; this.invAspectx = 1.0 / this.aspectx; this.invAspecty = 1.0 / this.aspecty; } }, { key: "runFrameEquations", value: function runFrameEquations(globalVars) { this.mdVSFrame = Object.assign({}, this.mdVS, this.mdVSQInit, this.mdVSFrameMap, globalVars); this.mdVSFrame = this.preset.frame_eqs(this.mdVSFrame); this.mdVSFrameMap = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(this.mdVSFrame, this.mdVSUserKeys); this.mdVSQAfterFrame = _utils__WEBPACK_IMPORTED_MODULE_0__["default"].pick(this.mdVSFrame, this.qs); } }]); return PresetEquationRunner; }(); /***/ }), /***/ "./src/image/imageTextures.js": /*!************************************!*\ !*** ./src/image/imageTextures.js ***! \************************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return ImageTextures; }); 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; } var ImageTextures = /*#__PURE__*/ function () { function ImageTextures(gl) { var _this = this; _classCallCheck(this, ImageTextures); this.gl = gl; this.anisoExt = this.gl.getExtension('EXT_texture_filter_anisotropic') || this.gl.getExtension('MOZ_EXT_texture_filter_anisotropic') || this.gl.getExtension('WEBKIT_EXT_texture_filter_anisotropic'); this.samplers = {}; /* eslint-disable max-len */ this.clouds2Image = new Image(); this.clouds2Image.onload = function () { _this.samplers.clouds2 = _this.gl.createTexture(); _this.bindTexture(_this.samplers.clouds2, _this.clouds2Image, 128, 128); }; this.clouds2Image.src = '