Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

2gl

Package Overview
Dependencies
Maintainers
5
Versions
51
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

2gl - npm Package Compare versions

Comparing version 0.4.1 to 0.5.0

.nyc_output/0252ee8257ec0bfd27f41afb2235f508.json

3

Buffer.js

@@ -119,2 +119,3 @@ /**

this._initData = null;
return this;
}

@@ -213,2 +214,2 @@

*/
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/Buffer.js"],"names":["Buffer","constructor","initData","options","_initData","byteLength","undefined","type","ArrayBuffer","drawType","StaticDraw","Object","assign","defaultOptions","_glBuffer","_glContext","bind","gl","location","prepare","bindBuffer","ARRAY_BUFFER","vertexAttribPointer","itemSize","_toGlParam","dataType","normalized","stride","offset","ElementArrayBuffer","ELEMENT_ARRAY_BUFFER","remove","_unprepare","subData","index","data","bufferSubData","createBuffer","bufferData","deleteBuffer","param","STATIC_DRAW","DynamicDraw","DYNAMIC_DRAW","Byte","BYTE","Short","SHORT","Int","INT","Float","FLOAT","UnsignedByte","UNSIGNED_BYTE","UnsignedShort","UNSIGNED_SHORT","UnsignedInt","UNSIGNED_INT"],"mappings":"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","file":"Buffer.js","sourcesContent":["/**\n * Используется для хранения и подготовки данных для передачи в атрибуты шейдера\n *\n * @param {TypedArray | ArrayBuffer | number} initData Данные для инита буфера:\n * содержимое буфера или его размер\n * @param {?BufferBindOptions} options Параметры передачи буфера в видеокарту,\n * могут быть переопределены из {@link BufferChannel}\n */\nclass Buffer {\n    constructor(initData, options) {\n        this._initData = initData;\n\n        /**\n         * Размер данных в буфере в байтах\n         * @type {Number}\n         */\n        this.byteLength = initData.byteLength !== undefined ? initData.byteLength : initData;\n\n        /**\n         * Тип буфера. Буфер может использоваться для передачи массива данных,\n         * так и для передачи индексов элементов из данных.\n         * @type {Buffer.ArrayBuffer | Buffer.ElementArrayBuffer}\n         */\n        this.type = Buffer.ArrayBuffer;\n\n        /**\n         * Указывает, как часто данные буфера будут изменяться.\n         * @type {Buffer.StaticDraw | Buffer.DynamicDraw}\n         */\n        this.drawType = Buffer.StaticDraw;\n\n        /**\n         * Параметры для связывания буфера\n         * @type {BufferBindOptions}\n         * @ignore\n         */\n        this.options = Object.assign({}, Buffer.defaultOptions, options);\n\n        /**\n         * Исходный WebGL буфер\n         * @type {?WebGLBuffer}\n         * @ignore\n         */\n        this._glBuffer = null;\n\n        /**\n         * Контекст WebGL, в котором был инициализирован буфер.\n         * Используется только для удаления буфера, подумать хорошо, прежде чем использовать для чего-то ещё.\n         * @type {?WebGLRenderingContext}\n         * @ignore\n         */\n        this._glContext = null;\n    }\n\n    /**\n     * Связывает данные с контекстом WebGL.\n     *\n     * В случае Buffer.ArrayBuffer связывает с атрибутами шейдера.\n     * А в случае Buffer.ElementArrayBuffer связывает массив индексов.\n     *\n     * Если используется первый раз, добавляет данные в контекст WebGL.\n     *\n     * @param {WebGLRenderingContext} gl\n     * @param {?Number} location Положение аттрибута для связывания данных с переменными в шейдере\n     * @param {?BufferBindOptions} options Параметры передаваемые в функцию vertexAttribPointer, если их нет,\n     * то используются параметры конкретного буфера. Параметры должны быть переданы все.\n     */\n    bind(gl, location, options) {\n        if (!this._glBuffer) {\n            this.prepare(gl);\n        }\n\n        if (this.type === Buffer.ArrayBuffer) {\n            gl.bindBuffer(gl.ARRAY_BUFFER, this._glBuffer);\n\n            options = options || this.options;\n\n            gl.vertexAttribPointer(location, options.itemSize, this._toGlParam(gl, options.dataType),\n                options.normalized, options.stride, options.offset);\n\n        } else if (this.type === Buffer.ElementArrayBuffer) {\n            gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, this._glBuffer);\n        }\n\n        return this;\n    }\n\n    /**\n     * Удаляет данные из контекста WebGL.\n     */\n    remove() {\n        this._unprepare();\n\n        return this;\n    }\n\n    /**\n     * Заменяет часть буфера новыми данными и отправляет их в видеокарту\n     * @param {WebGLRenderingContext} gl\n     * @param {Number} index Индекс, с которого начать замену\n     * @param {TypedArray} data Новые данные\n     */\n    subData(gl, index, data) {\n        gl.bindBuffer(this._toGlParam(gl, this.type), this._glBuffer);\n        gl.bufferSubData(this._toGlParam(gl, this.type), index, data);\n\n        return this;\n    }\n\n    /**\n     * Кладёт данные в видеокарту\n     * @param {WebGLRenderingContext} gl\n     * @ignore\n     */\n    prepare(gl) {\n        this._glContext = gl;\n        this._glBuffer = gl.createBuffer();\n        gl.bindBuffer(this._toGlParam(gl, this.type), this._glBuffer);\n        gl.bufferData(this._toGlParam(gl, this.type), this._initData, this._toGlParam(gl, this.drawType));\n        this._initData = null;\n    }\n\n    /**\n     * Удаляет данные из видеокарты\n     * @ignore\n     */\n    _unprepare() {\n        if (this._glBuffer) {\n            this._glContext.deleteBuffer(this._glBuffer);\n            this._glBuffer = null;\n            this._glContext = null;\n        }\n    }\n\n    /**\n     * Преобразовывает параметры буфера в параметры WebGL\n     * @param {WebGLRenderingContext} gl\n     * @param {Buffer.ArrayBuffer | Buffer.ElementArrayBuffer} param\n     * @ignore\n     */\n    _toGlParam(gl, param) {\n        if (param === Buffer.ArrayBuffer) { return gl.ARRAY_BUFFER; }\n        if (param === Buffer.ElementArrayBuffer) { return gl.ELEMENT_ARRAY_BUFFER; }\n        if (param === Buffer.StaticDraw) { return gl.STATIC_DRAW; }\n        if (param === Buffer.DynamicDraw) { return gl.DYNAMIC_DRAW; }\n        if (param === Buffer.Byte) { return gl.BYTE; }\n        if (param === Buffer.Short) { return gl.SHORT; }\n        if (param === Buffer.Int) { return gl.INT; }\n        if (param === Buffer.Float) { return gl.FLOAT; }\n        if (param === Buffer.UnsignedByte) { return gl.UNSIGNED_BYTE; }\n        if (param === Buffer.UnsignedShort) { return gl.UNSIGNED_SHORT; }\n        if (param === Buffer.UnsignedInt) { return gl.UNSIGNED_INT; }\n        return null;\n    }\n}\n\nBuffer.ArrayBuffer = 1;\nBuffer.ElementArrayBuffer = 2;\n\nBuffer.StaticDraw = 10;\nBuffer.DynamicDraw = 11;\n\nBuffer.Float = 20;\nBuffer.UnsignedByte = 21;\nBuffer.UnsignedShort = 22;\nBuffer.UnsignedInt = 23;\nBuffer.Byte = 24;\nBuffer.Short = 25;\nBuffer.Int = 26;\n\nBuffer.defaultOptions = {\n    itemSize: 3,\n    dataType: Buffer.Float,\n    stride: 0,\n    offset: 0,\n    normalized: false\n};\n\nexport default Buffer;\n\n/**\n * Параметры передаваемые в функцию vertexAttribPointer.\n *\n * @typedef {Object} BufferBindOptions\n * @property {Number} itemSize Размерность элементов в буфере\n * @property {Buffer.Float | Buffer.UnsignedByte} dataType Тип данных в буфере\n * @property {Boolean} normalized Используется для целочисленных типов. Если выставлен в true, то\n * значения имеющие тип BYTE от -128 до 128 будут переведены от -1.0 до 1.0.\n * @property {Number} stride\n * @property {Number} offset\n */\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/Buffer.js"],"names":["Buffer","constructor","initData","options","_initData","byteLength","undefined","type","ArrayBuffer","drawType","StaticDraw","Object","assign","defaultOptions","_glBuffer","_glContext","bind","gl","location","prepare","bindBuffer","ARRAY_BUFFER","vertexAttribPointer","itemSize","_toGlParam","dataType","normalized","stride","offset","ElementArrayBuffer","ELEMENT_ARRAY_BUFFER","remove","_unprepare","subData","index","data","bufferSubData","createBuffer","bufferData","deleteBuffer","param","STATIC_DRAW","DynamicDraw","DYNAMIC_DRAW","Byte","BYTE","Short","SHORT","Int","INT","Float","FLOAT","UnsignedByte","UNSIGNED_BYTE","UnsignedShort","UNSIGNED_SHORT","UnsignedInt","UNSIGNED_INT"],"mappings":"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","file":"Buffer.js","sourcesContent":["/**\n * Используется для хранения и подготовки данных для передачи в атрибуты шейдера\n *\n * @param {TypedArray | ArrayBuffer | number} initData Данные для инита буфера:\n * содержимое буфера или его размер\n * @param {?BufferBindOptions} options Параметры передачи буфера в видеокарту,\n * могут быть переопределены из {@link BufferChannel}\n */\nclass Buffer {\n    constructor(initData, options) {\n        this._initData = initData;\n\n        /**\n         * Размер данных в буфере в байтах\n         * @type {Number}\n         */\n        this.byteLength = initData.byteLength !== undefined ? initData.byteLength : initData;\n\n        /**\n         * Тип буфера. Буфер может использоваться для передачи массива данных,\n         * так и для передачи индексов элементов из данных.\n         * @type {Buffer.ArrayBuffer | Buffer.ElementArrayBuffer}\n         */\n        this.type = Buffer.ArrayBuffer;\n\n        /**\n         * Указывает, как часто данные буфера будут изменяться.\n         * @type {Buffer.StaticDraw | Buffer.DynamicDraw}\n         */\n        this.drawType = Buffer.StaticDraw;\n\n        /**\n         * Параметры для связывания буфера\n         * @type {BufferBindOptions}\n         * @ignore\n         */\n        this.options = Object.assign({}, Buffer.defaultOptions, options);\n\n        /**\n         * Исходный WebGL буфер\n         * @type {?WebGLBuffer}\n         * @ignore\n         */\n        this._glBuffer = null;\n\n        /**\n         * Контекст WebGL, в котором был инициализирован буфер.\n         * Используется только для удаления буфера, подумать хорошо, прежде чем использовать для чего-то ещё.\n         * @type {?WebGLRenderingContext}\n         * @ignore\n         */\n        this._glContext = null;\n    }\n\n    /**\n     * Связывает данные с контекстом WebGL.\n     *\n     * В случае Buffer.ArrayBuffer связывает с атрибутами шейдера.\n     * А в случае Buffer.ElementArrayBuffer связывает массив индексов.\n     *\n     * Если используется первый раз, добавляет данные в контекст WebGL.\n     *\n     * @param {WebGLRenderingContext} gl\n     * @param {?Number} location Положение аттрибута для связывания данных с переменными в шейдере\n     * @param {?BufferBindOptions} options Параметры передаваемые в функцию vertexAttribPointer, если их нет,\n     * то используются параметры конкретного буфера. Параметры должны быть переданы все.\n     */\n    bind(gl, location, options) {\n        if (!this._glBuffer) {\n            this.prepare(gl);\n        }\n\n        if (this.type === Buffer.ArrayBuffer) {\n            gl.bindBuffer(gl.ARRAY_BUFFER, this._glBuffer);\n\n            options = options || this.options;\n\n            gl.vertexAttribPointer(location, options.itemSize, this._toGlParam(gl, options.dataType),\n                options.normalized, options.stride, options.offset);\n\n        } else if (this.type === Buffer.ElementArrayBuffer) {\n            gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, this._glBuffer);\n        }\n\n        return this;\n    }\n\n    /**\n     * Удаляет данные из контекста WebGL.\n     */\n    remove() {\n        this._unprepare();\n\n        return this;\n    }\n\n    /**\n     * Заменяет часть буфера новыми данными и отправляет их в видеокарту\n     * @param {WebGLRenderingContext} gl\n     * @param {Number} index Индекс, с которого начать замену\n     * @param {TypedArray} data Новые данные\n     */\n    subData(gl, index, data) {\n        gl.bindBuffer(this._toGlParam(gl, this.type), this._glBuffer);\n        gl.bufferSubData(this._toGlParam(gl, this.type), index, data);\n\n        return this;\n    }\n\n    /**\n     * Кладёт данные в видеокарту\n     * @param {WebGLRenderingContext} gl\n     * @ignore\n     */\n    prepare(gl) {\n        this._glContext = gl;\n        this._glBuffer = gl.createBuffer();\n        gl.bindBuffer(this._toGlParam(gl, this.type), this._glBuffer);\n        gl.bufferData(this._toGlParam(gl, this.type), this._initData, this._toGlParam(gl, this.drawType));\n        this._initData = null;\n        return this;\n    }\n\n    /**\n     * Удаляет данные из видеокарты\n     * @ignore\n     */\n    _unprepare() {\n        if (this._glBuffer) {\n            this._glContext.deleteBuffer(this._glBuffer);\n            this._glBuffer = null;\n            this._glContext = null;\n        }\n    }\n\n    /**\n     * Преобразовывает параметры буфера в параметры WebGL\n     * @param {WebGLRenderingContext} gl\n     * @param {Buffer.ArrayBuffer | Buffer.ElementArrayBuffer} param\n     * @ignore\n     */\n    _toGlParam(gl, param) {\n        if (param === Buffer.ArrayBuffer) { return gl.ARRAY_BUFFER; }\n        if (param === Buffer.ElementArrayBuffer) { return gl.ELEMENT_ARRAY_BUFFER; }\n        if (param === Buffer.StaticDraw) { return gl.STATIC_DRAW; }\n        if (param === Buffer.DynamicDraw) { return gl.DYNAMIC_DRAW; }\n        if (param === Buffer.Byte) { return gl.BYTE; }\n        if (param === Buffer.Short) { return gl.SHORT; }\n        if (param === Buffer.Int) { return gl.INT; }\n        if (param === Buffer.Float) { return gl.FLOAT; }\n        if (param === Buffer.UnsignedByte) { return gl.UNSIGNED_BYTE; }\n        if (param === Buffer.UnsignedShort) { return gl.UNSIGNED_SHORT; }\n        if (param === Buffer.UnsignedInt) { return gl.UNSIGNED_INT; }\n        return null;\n    }\n}\n\nBuffer.ArrayBuffer = 1;\nBuffer.ElementArrayBuffer = 2;\n\nBuffer.StaticDraw = 10;\nBuffer.DynamicDraw = 11;\n\nBuffer.Float = 20;\nBuffer.UnsignedByte = 21;\nBuffer.UnsignedShort = 22;\nBuffer.UnsignedInt = 23;\nBuffer.Byte = 24;\nBuffer.Short = 25;\nBuffer.Int = 26;\n\nBuffer.defaultOptions = {\n    itemSize: 3,\n    dataType: Buffer.Float,\n    stride: 0,\n    offset: 0,\n    normalized: false\n};\n\nexport default Buffer;\n\n/**\n * Параметры передаваемые в функцию vertexAttribPointer.\n *\n * @typedef {Object} BufferBindOptions\n * @property {Number} itemSize Размерность элементов в буфере\n * @property {Buffer.Float | Buffer.UnsignedByte} dataType Тип данных в буфере\n * @property {Boolean} normalized Используется для целочисленных типов. Если выставлен в true, то\n * значения имеющие тип BYTE от -128 до 128 будут переведены от -1.0 до 1.0.\n * @property {Number} stride\n * @property {Number} offset\n */\n"]}
{
"name": "2gl",
"version": "0.4.1",
"version": "0.5.0",
"description": "WebGL library for 2GIS projects",
"repository": {
"type": "git",
"url": "git@github.com:2gis/2gl.git"
"url": "git+https://github.com/2gis/2gl.git"
},
"main": "index.js",
"typings": "index.d.ts",
"module": "src/index.js",

@@ -11,0 +12,0 @@ "jsnext:main": "src/index.js",

@@ -14,4 +14,4 @@ import Object3DPlugin from './rendererPlugins/Object3DPlugin';

* @param {Boolean} [options.autoClear=true] Стирать ли прошлый кадр перед новый рендерингом
* @param {Array} [options.clearColor=true] Цвет заливки в формате RGBA
* @param {Object} [options.sortObjects=true] Нужно ли сортировать прозрачные объекты по удаленности
* @param {Number[]} [options.clearColor=[1,1,1,1]] Цвет заливки в формате RGBA
* @param {Boolean} [options.sortObjects=true] Нужно ли сортировать прозрачные объекты по удаленности
* или по renderOrder

@@ -32,3 +32,3 @@ * */

this._gl = this._canvasElement.getContext('webgl', attributes) || this._canvasElement.getContext('experimental-webgl', attributes);
this._gl = options.version === 2 ? this._canvasElement.getContext('webgl2', attributes) : this._canvasElement.getContext('webgl', attributes) || this._canvasElement.getContext('experimental-webgl', attributes);
} else {

@@ -281,2 +281,2 @@ this._gl = options.gl;

*/
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/Renderer.js"],"names":["Object3DPlugin","Renderer","constructor","options","canvas","_canvasElement","document","getElementById","attributes","antialias","undefined","stencil","failIfMajorPerformanceCaveat","_gl","getContext","gl","_pixelRatio","pixelRatio","autoClear","clearColor","sortObjects","_plugins","_pluginsByType","_maxPluginOrder","addPlugin","webGlExtensions","plugin","order","push","sort","a","b","type","Math","max","apply","map","p","removePlugin","Plugin","some","el","i","splice","setPixelRatio","value","getPixelRatio","setSize","width","height","_size","style","setViewport","viewport","getSize","setRenderTarget","renderTarget","_renderTarget","readPixels","x","y","array","bind","RGBA","UNSIGNED_BYTE","unbind","clear","COLOR_BUFFER_BIT","DEPTH_BUFFER_BIT","render","scene","camera","userData","typifyForRender","clearDepth","clearStencil","updateLocalMatrix","updateWorldMatrix","state","renderer","extensions","pluginsToRender","item","filter","hasObjects","length","addExtension","name","getExtension"],"mappings":"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","file":"Renderer.js","sourcesContent":["import Object3DPlugin from './rendererPlugins/Object3DPlugin';\n\n/**\n * Используется для инициализация WebGL контекста и отрисовки объектов.\n * Для некоторых объектов может использовать специфичные рендеры.\n *\n * @param {Object} options\n * @param {HTMLElement} [options.canvas] Элемент canvas\n * @param {WebGLRenderingContext} [options.gl] Если элемент canvas не указан, то можно напрямую передать WebGL контекст\n * @param {Number} [options.pixelRatio=1] Pixel ratio экрана\n * @param {Boolean} [options.antialias=true] Использовать ли антиалиасинг\n * @param {Boolean} [options.stencil=false] Использовать ли stencil buffer\n * @param {Boolean} [options.autoClear=true] Стирать ли прошлый кадр перед новый рендерингом\n * @param {Array} [options.clearColor=true] Цвет заливки в формате RGBA\n * @param {Object} [options.sortObjects=true] Нужно ли сортировать прозрачные объекты по удаленности\n * или по renderOrder\n * */\nclass Renderer {\n    constructor(options) {\n        options = options || {};\n\n        if (options.canvas) {\n            this._canvasElement = typeof options.canvas === 'string' ?\n                document.getElementById(options.canvas) : options.canvas;\n\n            const attributes = {\n                antialias: options.antialias !== undefined ? options.antialias : true,\n                stencil: options.stencil !== undefined ? options.stencil : false,\n                failIfMajorPerformanceCaveat: options.failIfMajorPerformanceCaveat !== undefined ?\n                    options.failIfMajorPerformanceCaveat : false\n            };\n\n            this._gl = this._canvasElement.getContext('webgl', attributes) ||\n                this._canvasElement.getContext('experimental-webgl', attributes);\n        } else {\n            this._gl = options.gl;\n        }\n\n        this._pixelRatio = options.pixelRatio || 1;\n\n        /**\n         * Определяет стирать ли прошлый кадр перед новым рендерингом\n         * @type {Boolean}\n         */\n        this.autoClear = options.autoClear !== undefined ? options.autoClear : true;\n\n        /**\n         * Цвет заливки в формате RGBA\n         * @type {Array}\n         */\n        this.clearColor = options.clearColor || [1, 1, 1, 1];\n        this.sortObjects = true;\n\n        this._plugins = [];\n        this._pluginsByType = {};\n        this._maxPluginOrder = 0;\n\n        this.addPlugin(new Object3DPlugin(), 0);\n\n        /**\n         * Список включенных WebGL расширений\n         * @type {Object}\n         */\n        this.webGlExtensions = {};\n    }\n\n    /**\n     * Добавляет {@link RendererPlugin} к рендеру. К рендеру может быть добавлен только один плагин каждого типа.\n     * @param {Plugin} plugin Плагин\n     * @param {?Number} order Каждый плагин выполняется при рендеринге по возрастанию order,\n     * если его нет, то выбирается максимальный order + 1.\n     */\n    addPlugin(plugin, order) {\n        if (order === undefined) {\n            order = this._maxPluginOrder + 1;\n        }\n\n        this._plugins.push({\n            plugin,\n            order\n        });\n        this._plugins.sort((a, b) => a.order - b.order);\n        this._pluginsByType[plugin.type] = plugin;\n\n        this._maxPluginOrder = Math.max.apply(Math, this._plugins.map(p => p.order));\n\n        return this;\n    }\n\n    /**\n     * Удаляет {@link RendererPlugin} из рендера.\n     * @param {Plugin} Plugin Класс плагина\n     */\n    removePlugin(Plugin) {\n        this._plugins.some((el, i) => {\n            if (el.plugin instanceof Plugin) {\n                delete this._pluginsByType[this._plugins[i].plugin.type];\n                this._plugins.splice(i, 1);\n                return true;\n            }\n            return false;\n        });\n\n        return this;\n    }\n\n    /**\n     * Устанавливает параметр pixel ratio\n     * @param {Number} value\n     */\n    setPixelRatio(value) {\n        this._pixelRatio = value;\n\n        return this;\n    }\n\n    /**\n     * Возвращает текущий pixel ratio\n     * @returns {Number}\n     */\n    getPixelRatio() {\n        return this._pixelRatio;\n    }\n\n    /**\n     * Устанавливает размеры элементу canvas и viewport для WebGL\n     * @param {Number} width Ширина в пикселях\n     * @param {Number} height Высота в пикселях\n     */\n    setSize(width, height) {\n        this._size = [\n            width * this._pixelRatio,\n            height * this._pixelRatio\n        ];\n\n        if (this._canvasElement) {\n            this._canvasElement.width = this._size[0];\n            this._canvasElement.height = this._size[1];\n            this._canvasElement.style.width = width + 'px';\n            this._canvasElement.style.height = height + 'px';\n        }\n\n        this.setViewport();\n\n        return this;\n    }\n\n    /**\n     * Устанавливает viewport для WebGL\n     * Если размеры не указаны, то выставляет размеры указанные в функции {@link Renderer#setSize}\n     * @param {Number} [width] Ширина в пикселях\n     * @param {Number} [height] Высота в пикселях\n     */\n    setViewport(width, height) {\n        if (width !== undefined && height !== undefined) {\n            this._gl.viewport(0, 0, width, height);\n        } else {\n            this._gl.viewport(0, 0, this._size[0], this._size[1]);\n        }\n\n        return this;\n    }\n\n    /**\n     * Возвращает текущий viewport WebGL\n     * @returns {Array}\n     */\n    getSize() {\n        return this._size;\n    }\n\n    /**\n     * Устанавливает RenderTarget\n     * @param {?RenderTarget} renderTarget\n     */\n    setRenderTarget(renderTarget) {\n        this._renderTarget = renderTarget;\n        return this;\n    }\n\n    /**\n     * Считывает указанную область пикселей в массив\n     * @param {Number} x Координаты начала области\n     * @param {Number} y Координаты начала области\n     * @param {Number} width Ширина области\n     * @param {Number} height Высота области\n     * @param {TypedArray} array Массив для записи данных\n     */\n    readPixels(x, y, width, height, array) {\n        const gl = this._gl;\n\n        if (this._renderTarget) {\n            this._renderTarget.bind(gl);\n            gl.readPixels(x, y, width, height, gl.RGBA, gl.UNSIGNED_BYTE, array);\n            this._renderTarget.unbind(gl);\n        } else {\n            gl.readPixels(x, y, width, height, gl.RGBA, gl.UNSIGNED_BYTE, array);\n        }\n\n        return this;\n    }\n\n    /**\n     * Очищает текущий кадр и заливает цветом указанным в clearColor\n     */\n    clear() {\n        const gl = this._gl;\n\n        gl.clearColor.apply(gl, this.clearColor);\n        gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n\n        return this;\n    }\n\n    /**\n     * Рисует сцену\n     * @param {Scene} scene Сцена\n     * @param {Camera} camera Камера\n     * @param {*} userData Дополнительная информация, которая будет передана всем плагинам и объектам\n     */\n    render(scene, camera, userData) {\n        const gl = this._gl;\n\n        scene.typifyForRender(this._pluginsByType);\n\n        if (this._renderTarget) {\n            this._renderTarget.bind(gl);\n        }\n\n        gl.clearDepth(1);\n        gl.clearStencil(0);\n\n        if (this.autoClear) {\n            this.clear();\n        }\n\n        camera.updateLocalMatrix();\n        camera.updateWorldMatrix();\n\n        const state = {\n            renderer: this,\n            extensions: this.webGlExtensions,\n            scene,\n            camera,\n            gl,\n            userData\n        };\n        // TODO: make state immutable?\n\n        const pluginsToRender = this._plugins\n            .map(item => item.plugin)\n            .filter(plugin => plugin.hasObjects());\n\n        for (let i = 0; i < pluginsToRender.length; i++) {\n            pluginsToRender[i].render(\n                state,\n                pluginsToRender[i - 1],\n                pluginsToRender[i + 1]\n            );\n        }\n\n        if (this._renderTarget) {\n            this._renderTarget.unbind(gl);\n        }\n\n        return this;\n    }\n\n    /**\n     * Включает расширение WebGL\n     *\n     * @param {String} name Название расширения\n     */\n    addExtension(name) {\n        this.webGlExtensions[name] = this._gl.getExtension(name);\n        return this;\n    }\n}\n\nexport default Renderer;\n\n/**\n * Состояние рендера. Передается объектам для отрисовки.\n *\n * @typedef {Object} State\n * @property {WebGLRenderingContext} gl\n * @property {Scene} scene\n * @property {Camera} camera\n * @property {Renderer} renderer\n */\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/Renderer.js"],"names":["Object3DPlugin","Renderer","constructor","options","canvas","_canvasElement","document","getElementById","attributes","antialias","undefined","stencil","failIfMajorPerformanceCaveat","_gl","version","getContext","gl","_pixelRatio","pixelRatio","autoClear","clearColor","sortObjects","_plugins","_pluginsByType","_maxPluginOrder","addPlugin","webGlExtensions","plugin","order","push","sort","a","b","type","Math","max","apply","map","p","removePlugin","Plugin","some","el","i","splice","setPixelRatio","value","getPixelRatio","setSize","width","height","_size","style","setViewport","viewport","getSize","setRenderTarget","renderTarget","_renderTarget","readPixels","x","y","array","bind","RGBA","UNSIGNED_BYTE","unbind","clear","COLOR_BUFFER_BIT","DEPTH_BUFFER_BIT","render","scene","camera","userData","typifyForRender","clearDepth","clearStencil","updateLocalMatrix","updateWorldMatrix","state","renderer","extensions","pluginsToRender","item","filter","hasObjects","length","addExtension","name","getExtension"],"mappings":"AAAA,OAAOA,cAAP,MAA2B,kCAA3B;;AAEA;;;;;;;;;;;;;;;AAeA,MAAMC,QAAN,CAAe;AACXC,gBAAYC,OAAZ,EAAqB;AACjBA,kBAAUA,WAAW,EAArB;;AAEA,YAAIA,QAAQC,MAAZ,EAAoB;AAChB,iBAAKC,cAAL,GAAsB,OAAOF,QAAQC,MAAf,KAA0B,QAA1B,GAClBE,SAASC,cAAT,CAAwBJ,QAAQC,MAAhC,CADkB,GACwBD,QAAQC,MADtD;;AAGA,kBAAMI,aAAa;AACfC,2BAAWN,QAAQM,SAAR,KAAsBC,SAAtB,GAAkCP,QAAQM,SAA1C,GAAsD,IADlD;AAEfE,yBAASR,QAAQQ,OAAR,KAAoBD,SAApB,GAAgCP,QAAQQ,OAAxC,GAAkD,KAF5C;AAGfC,8CAA8BT,QAAQS,4BAAR,KAAyCF,SAAzC,GAC1BP,QAAQS,4BADkB,GACa;AAJ5B,aAAnB;;AAOA,iBAAKC,GAAL,GAAWV,QAAQW,OAAR,KAAoB,CAApB,GACP,KAAKT,cAAL,CAAoBU,UAApB,CAA+B,QAA/B,EAAyCP,UAAzC,CADO,GAEN,KAAKH,cAAL,CAAoBU,UAApB,CAA+B,OAA/B,EAAwCP,UAAxC,KACG,KAAKH,cAAL,CAAoBU,UAApB,CAA+B,oBAA/B,EAAqDP,UAArD,CAHR;AAIH,SAfD,MAeO;AACH,iBAAKK,GAAL,GAAWV,QAAQa,EAAnB;AACH;;AAED,aAAKC,WAAL,GAAmBd,QAAQe,UAAR,IAAsB,CAAzC;;AAEA;;;;AAIA,aAAKC,SAAL,GAAiBhB,QAAQgB,SAAR,KAAsBT,SAAtB,GAAkCP,QAAQgB,SAA1C,GAAsD,IAAvE;;AAEA;;;;AAIA,aAAKC,UAAL,GAAkBjB,QAAQiB,UAAR,IAAsB,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,CAAxC;AACA,aAAKC,WAAL,GAAmB,IAAnB;;AAEA,aAAKC,QAAL,GAAgB,EAAhB;AACA,aAAKC,cAAL,GAAsB,EAAtB;AACA,aAAKC,eAAL,GAAuB,CAAvB;;AAEA,aAAKC,SAAL,CAAe,IAAIzB,cAAJ,EAAf,EAAqC,CAArC;;AAEA;;;;AAIA,aAAK0B,eAAL,GAAuB,EAAvB;AACH;;AAED;;;;;;AAMAD,cAAUE,MAAV,EAAkBC,KAAlB,EAAyB;AACrB,YAAIA,UAAUlB,SAAd,EAAyB;AACrBkB,oBAAQ,KAAKJ,eAAL,GAAuB,CAA/B;AACH;;AAED,aAAKF,QAAL,CAAcO,IAAd,CAAmB;AACfF,kBADe;AAEfC;AAFe,SAAnB;AAIA,aAAKN,QAAL,CAAcQ,IAAd,CAAmB,CAACC,CAAD,EAAIC,CAAJ,KAAUD,EAAEH,KAAF,GAAUI,EAAEJ,KAAzC;AACA,aAAKL,cAAL,CAAoBI,OAAOM,IAA3B,IAAmCN,MAAnC;;AAEA,aAAKH,eAAL,GAAuBU,KAAKC,GAAL,CAASC,KAAT,CAAeF,IAAf,EAAqB,KAAKZ,QAAL,CAAce,GAAd,CAAkBC,KAAKA,EAAEV,KAAzB,CAArB,CAAvB;;AAEA,eAAO,IAAP;AACH;;AAED;;;;AAIAW,iBAAaC,MAAb,EAAqB;AACjB,aAAKlB,QAAL,CAAcmB,IAAd,CAAmB,CAACC,EAAD,EAAKC,CAAL,KAAW;AAC1B,gBAAID,GAAGf,MAAH,YAAqBa,MAAzB,EAAiC;AAC7B,uBAAO,KAAKjB,cAAL,CAAoB,KAAKD,QAAL,CAAcqB,CAAd,EAAiBhB,MAAjB,CAAwBM,IAA5C,CAAP;AACA,qBAAKX,QAAL,CAAcsB,MAAd,CAAqBD,CAArB,EAAwB,CAAxB;AACA,uBAAO,IAAP;AACH;AACD,mBAAO,KAAP;AACH,SAPD;;AASA,eAAO,IAAP;AACH;;AAED;;;;AAIAE,kBAAcC,KAAd,EAAqB;AACjB,aAAK7B,WAAL,GAAmB6B,KAAnB;;AAEA,eAAO,IAAP;AACH;;AAED;;;;AAIAC,oBAAgB;AACZ,eAAO,KAAK9B,WAAZ;AACH;;AAED;;;;;AAKA+B,YAAQC,KAAR,EAAeC,MAAf,EAAuB;AACnB,aAAKC,KAAL,GAAa,CACTF,QAAQ,KAAKhC,WADJ,EAETiC,SAAS,KAAKjC,WAFL,CAAb;;AAKA,YAAI,KAAKZ,cAAT,EAAyB;AACrB,iBAAKA,cAAL,CAAoB4C,KAApB,GAA4B,KAAKE,KAAL,CAAW,CAAX,CAA5B;AACA,iBAAK9C,cAAL,CAAoB6C,MAApB,GAA6B,KAAKC,KAAL,CAAW,CAAX,CAA7B;AACA,iBAAK9C,cAAL,CAAoB+C,KAApB,CAA0BH,KAA1B,GAAkCA,QAAQ,IAA1C;AACA,iBAAK5C,cAAL,CAAoB+C,KAApB,CAA0BF,MAA1B,GAAmCA,SAAS,IAA5C;AACH;;AAED,aAAKG,WAAL;;AAEA,eAAO,IAAP;AACH;;AAED;;;;;;AAMAA,gBAAYJ,KAAZ,EAAmBC,MAAnB,EAA2B;AACvB,YAAID,UAAUvC,SAAV,IAAuBwC,WAAWxC,SAAtC,EAAiD;AAC7C,iBAAKG,GAAL,CAASyC,QAAT,CAAkB,CAAlB,EAAqB,CAArB,EAAwBL,KAAxB,EAA+BC,MAA/B;AACH,SAFD,MAEO;AACH,iBAAKrC,GAAL,CAASyC,QAAT,CAAkB,CAAlB,EAAqB,CAArB,EAAwB,KAAKH,KAAL,CAAW,CAAX,CAAxB,EAAuC,KAAKA,KAAL,CAAW,CAAX,CAAvC;AACH;;AAED,eAAO,IAAP;AACH;;AAED;;;;AAIAI,cAAU;AACN,eAAO,KAAKJ,KAAZ;AACH;;AAED;;;;AAIAK,oBAAgBC,YAAhB,EAA8B;AAC1B,aAAKC,aAAL,GAAqBD,YAArB;AACA,eAAO,IAAP;AACH;;AAED;;;;;;;;AAQAE,eAAWC,CAAX,EAAcC,CAAd,EAAiBZ,KAAjB,EAAwBC,MAAxB,EAAgCY,KAAhC,EAAuC;AACnC,cAAM9C,KAAK,KAAKH,GAAhB;;AAEA,YAAI,KAAK6C,aAAT,EAAwB;AACpB,iBAAKA,aAAL,CAAmBK,IAAnB,CAAwB/C,EAAxB;AACAA,eAAG2C,UAAH,CAAcC,CAAd,EAAiBC,CAAjB,EAAoBZ,KAApB,EAA2BC,MAA3B,EAAmClC,GAAGgD,IAAtC,EAA4ChD,GAAGiD,aAA/C,EAA8DH,KAA9D;AACA,iBAAKJ,aAAL,CAAmBQ,MAAnB,CAA0BlD,EAA1B;AACH,SAJD,MAIO;AACHA,eAAG2C,UAAH,CAAcC,CAAd,EAAiBC,CAAjB,EAAoBZ,KAApB,EAA2BC,MAA3B,EAAmClC,GAAGgD,IAAtC,EAA4ChD,GAAGiD,aAA/C,EAA8DH,KAA9D;AACH;;AAED,eAAO,IAAP;AACH;;AAED;;;AAGAK,YAAQ;AACJ,cAAMnD,KAAK,KAAKH,GAAhB;;AAEAG,WAAGI,UAAH,CAAcgB,KAAd,CAAoBpB,EAApB,EAAwB,KAAKI,UAA7B;AACAJ,WAAGmD,KAAH,CAASnD,GAAGoD,gBAAH,GAAsBpD,GAAGqD,gBAAlC;;AAEA,eAAO,IAAP;AACH;;AAED;;;;;;AAMAC,WAAOC,KAAP,EAAcC,MAAd,EAAsBC,QAAtB,EAAgC;AAC5B,cAAMzD,KAAK,KAAKH,GAAhB;;AAEA0D,cAAMG,eAAN,CAAsB,KAAKnD,cAA3B;;AAEA,YAAI,KAAKmC,aAAT,EAAwB;AACpB,iBAAKA,aAAL,CAAmBK,IAAnB,CAAwB/C,EAAxB;AACH;;AAEDA,WAAG2D,UAAH,CAAc,CAAd;AACA3D,WAAG4D,YAAH,CAAgB,CAAhB;;AAEA,YAAI,KAAKzD,SAAT,EAAoB;AAChB,iBAAKgD,KAAL;AACH;;AAEDK,eAAOK,iBAAP;AACAL,eAAOM,iBAAP;;AAEA,cAAMC,QAAQ;AACVC,sBAAU,IADA;AAEVC,wBAAY,KAAKvD,eAFP;AAGV6C,iBAHU;AAIVC,kBAJU;AAKVxD,cALU;AAMVyD;AANU,SAAd;AAQA;;AAEA,cAAMS,kBAAkB,KAAK5D,QAAL,CACnBe,GADmB,CACf8C,QAAQA,KAAKxD,MADE,EAEnByD,MAFmB,CAEZzD,UAAUA,OAAO0D,UAAP,EAFE,CAAxB;;AAIA,aAAK,IAAI1C,IAAI,CAAb,EAAgBA,IAAIuC,gBAAgBI,MAApC,EAA4C3C,GAA5C,EAAiD;AAC7CuC,4BAAgBvC,CAAhB,EAAmB2B,MAAnB,CACIS,KADJ,EAEIG,gBAAgBvC,IAAI,CAApB,CAFJ,EAGIuC,gBAAgBvC,IAAI,CAApB,CAHJ;AAKH;;AAED,YAAI,KAAKe,aAAT,EAAwB;AACpB,iBAAKA,aAAL,CAAmBQ,MAAnB,CAA0BlD,EAA1B;AACH;;AAED,eAAO,IAAP;AACH;;AAED;;;;;AAKAuE,iBAAaC,IAAb,EAAmB;AACf,aAAK9D,eAAL,CAAqB8D,IAArB,IAA6B,KAAK3E,GAAL,CAAS4E,YAAT,CAAsBD,IAAtB,CAA7B;AACA,eAAO,IAAP;AACH;AArQU;;AAwQf,eAAevF,QAAf;;AAEA","file":"Renderer.js","sourcesContent":["import Object3DPlugin from './rendererPlugins/Object3DPlugin';\n\n/**\n * Используется для инициализация WebGL контекста и отрисовки объектов.\n * Для некоторых объектов может использовать специфичные рендеры.\n *\n * @param {Object} options\n * @param {HTMLElement} [options.canvas] Элемент canvas\n * @param {WebGLRenderingContext} [options.gl] Если элемент canvas не указан, то можно напрямую передать WebGL контекст\n * @param {Number} [options.pixelRatio=1] Pixel ratio экрана\n * @param {Boolean} [options.antialias=true] Использовать ли антиалиасинг\n * @param {Boolean} [options.stencil=false] Использовать ли stencil buffer\n * @param {Boolean} [options.autoClear=true] Стирать ли прошлый кадр перед новый рендерингом\n * @param {Number[]} [options.clearColor=[1,1,1,1]] Цвет заливки в формате RGBA\n * @param {Boolean} [options.sortObjects=true] Нужно ли сортировать прозрачные объекты по удаленности\n * или по renderOrder\n * */\nclass Renderer {\n    constructor(options) {\n        options = options || {};\n\n        if (options.canvas) {\n            this._canvasElement = typeof options.canvas === 'string' ?\n                document.getElementById(options.canvas) : options.canvas;\n\n            const attributes = {\n                antialias: options.antialias !== undefined ? options.antialias : true,\n                stencil: options.stencil !== undefined ? options.stencil : false,\n                failIfMajorPerformanceCaveat: options.failIfMajorPerformanceCaveat !== undefined ?\n                    options.failIfMajorPerformanceCaveat : false\n            };\n\n            this._gl = options.version === 2 ?\n                this._canvasElement.getContext('webgl2', attributes) :\n                (this._canvasElement.getContext('webgl', attributes) ||\n                    this._canvasElement.getContext('experimental-webgl', attributes));\n        } else {\n            this._gl = options.gl;\n        }\n\n        this._pixelRatio = options.pixelRatio || 1;\n\n        /**\n         * Определяет стирать ли прошлый кадр перед новым рендерингом\n         * @type {Boolean}\n         */\n        this.autoClear = options.autoClear !== undefined ? options.autoClear : true;\n\n        /**\n         * Цвет заливки в формате RGBA\n         * @type {Array}\n         */\n        this.clearColor = options.clearColor || [1, 1, 1, 1];\n        this.sortObjects = true;\n\n        this._plugins = [];\n        this._pluginsByType = {};\n        this._maxPluginOrder = 0;\n\n        this.addPlugin(new Object3DPlugin(), 0);\n\n        /**\n         * Список включенных WebGL расширений\n         * @type {Object}\n         */\n        this.webGlExtensions = {};\n    }\n\n    /**\n     * Добавляет {@link RendererPlugin} к рендеру. К рендеру может быть добавлен только один плагин каждого типа.\n     * @param {Plugin} plugin Плагин\n     * @param {?Number} order Каждый плагин выполняется при рендеринге по возрастанию order,\n     * если его нет, то выбирается максимальный order + 1.\n     */\n    addPlugin(plugin, order) {\n        if (order === undefined) {\n            order = this._maxPluginOrder + 1;\n        }\n\n        this._plugins.push({\n            plugin,\n            order\n        });\n        this._plugins.sort((a, b) => a.order - b.order);\n        this._pluginsByType[plugin.type] = plugin;\n\n        this._maxPluginOrder = Math.max.apply(Math, this._plugins.map(p => p.order));\n\n        return this;\n    }\n\n    /**\n     * Удаляет {@link RendererPlugin} из рендера.\n     * @param {Plugin} Plugin Класс плагина\n     */\n    removePlugin(Plugin) {\n        this._plugins.some((el, i) => {\n            if (el.plugin instanceof Plugin) {\n                delete this._pluginsByType[this._plugins[i].plugin.type];\n                this._plugins.splice(i, 1);\n                return true;\n            }\n            return false;\n        });\n\n        return this;\n    }\n\n    /**\n     * Устанавливает параметр pixel ratio\n     * @param {Number} value\n     */\n    setPixelRatio(value) {\n        this._pixelRatio = value;\n\n        return this;\n    }\n\n    /**\n     * Возвращает текущий pixel ratio\n     * @returns {Number}\n     */\n    getPixelRatio() {\n        return this._pixelRatio;\n    }\n\n    /**\n     * Устанавливает размеры элементу canvas и viewport для WebGL\n     * @param {Number} width Ширина в пикселях\n     * @param {Number} height Высота в пикселях\n     */\n    setSize(width, height) {\n        this._size = [\n            width * this._pixelRatio,\n            height * this._pixelRatio\n        ];\n\n        if (this._canvasElement) {\n            this._canvasElement.width = this._size[0];\n            this._canvasElement.height = this._size[1];\n            this._canvasElement.style.width = width + 'px';\n            this._canvasElement.style.height = height + 'px';\n        }\n\n        this.setViewport();\n\n        return this;\n    }\n\n    /**\n     * Устанавливает viewport для WebGL\n     * Если размеры не указаны, то выставляет размеры указанные в функции {@link Renderer#setSize}\n     * @param {Number} [width] Ширина в пикселях\n     * @param {Number} [height] Высота в пикселях\n     */\n    setViewport(width, height) {\n        if (width !== undefined && height !== undefined) {\n            this._gl.viewport(0, 0, width, height);\n        } else {\n            this._gl.viewport(0, 0, this._size[0], this._size[1]);\n        }\n\n        return this;\n    }\n\n    /**\n     * Возвращает текущий viewport WebGL\n     * @returns {Array}\n     */\n    getSize() {\n        return this._size;\n    }\n\n    /**\n     * Устанавливает RenderTarget\n     * @param {?RenderTarget} renderTarget\n     */\n    setRenderTarget(renderTarget) {\n        this._renderTarget = renderTarget;\n        return this;\n    }\n\n    /**\n     * Считывает указанную область пикселей в массив\n     * @param {Number} x Координаты начала области\n     * @param {Number} y Координаты начала области\n     * @param {Number} width Ширина области\n     * @param {Number} height Высота области\n     * @param {TypedArray} array Массив для записи данных\n     */\n    readPixels(x, y, width, height, array) {\n        const gl = this._gl;\n\n        if (this._renderTarget) {\n            this._renderTarget.bind(gl);\n            gl.readPixels(x, y, width, height, gl.RGBA, gl.UNSIGNED_BYTE, array);\n            this._renderTarget.unbind(gl);\n        } else {\n            gl.readPixels(x, y, width, height, gl.RGBA, gl.UNSIGNED_BYTE, array);\n        }\n\n        return this;\n    }\n\n    /**\n     * Очищает текущий кадр и заливает цветом указанным в clearColor\n     */\n    clear() {\n        const gl = this._gl;\n\n        gl.clearColor.apply(gl, this.clearColor);\n        gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n\n        return this;\n    }\n\n    /**\n     * Рисует сцену\n     * @param {Scene} scene Сцена\n     * @param {Camera} camera Камера\n     * @param {*} userData Дополнительная информация, которая будет передана всем плагинам и объектам\n     */\n    render(scene, camera, userData) {\n        const gl = this._gl;\n\n        scene.typifyForRender(this._pluginsByType);\n\n        if (this._renderTarget) {\n            this._renderTarget.bind(gl);\n        }\n\n        gl.clearDepth(1);\n        gl.clearStencil(0);\n\n        if (this.autoClear) {\n            this.clear();\n        }\n\n        camera.updateLocalMatrix();\n        camera.updateWorldMatrix();\n\n        const state = {\n            renderer: this,\n            extensions: this.webGlExtensions,\n            scene,\n            camera,\n            gl,\n            userData\n        };\n        // TODO: make state immutable?\n\n        const pluginsToRender = this._plugins\n            .map(item => item.plugin)\n            .filter(plugin => plugin.hasObjects());\n\n        for (let i = 0; i < pluginsToRender.length; i++) {\n            pluginsToRender[i].render(\n                state,\n                pluginsToRender[i - 1],\n                pluginsToRender[i + 1]\n            );\n        }\n\n        if (this._renderTarget) {\n            this._renderTarget.unbind(gl);\n        }\n\n        return this;\n    }\n\n    /**\n     * Включает расширение WebGL\n     *\n     * @param {String} name Название расширения\n     */\n    addExtension(name) {\n        this.webGlExtensions[name] = this._gl.getExtension(name);\n        return this;\n    }\n}\n\nexport default Renderer;\n\n/**\n * Состояние рендера. Передается объектам для отрисовки.\n *\n * @typedef {Object} State\n * @property {WebGLRenderingContext} gl\n * @property {Scene} scene\n * @property {Camera} camera\n * @property {Renderer} renderer\n */\n"]}

@@ -6,8 +6,20 @@ import Texture from './Texture';

*
* @param {Object} options
* @param {vec2} [options.size] Размер фреймбуфера
* @param {RenderTargetOptions & TextureOptions} options
*/
class RenderTarget {
constructor(options = {}) {
this._size = options.size;
/**
* Параметры для связывания фреймбуфера
* @type {RenderTargetOptions & TextureOptions}
* @readonly
*/
this.options = Object.assign({}, RenderTarget.defaultOptions, options);
/**
* Контекст WebGL, в котором был инициализирован фреймбуфер.
* Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.
* @type {?WebGLRenderingContext}
* @ignore
*/
this._glContext = null;
}

@@ -20,7 +32,2 @@

bind(gl) {
if (this._sizeChanged) {
this._unprepare(gl);
this._sizeChanged = false;
}
if (!this._frameBuffer) {

@@ -46,6 +53,5 @@ this._prepare(gl);

* Удаляет фреймбуфер из видеокарты
* @param {WebGLRenderingContext} gl
*/
remove(gl) {
this._unprepare(gl);
remove() {
this._unprepare();
return this;

@@ -59,4 +65,4 @@ }

setSize(size) {
this._size = size;
this._sizeChanged = true;
this.options.size = size;
this._unprepare();
return this;

@@ -66,2 +72,10 @@ }

/**
* Возвращает текущую текстуру фреймбуфера
* @return {Texture | null}
*/
getTexture() {
return this._texture;
}
/**
* Инициализирует фреймбуфер, текстуры и рендербуфер

@@ -72,6 +86,4 @@ * @param {WebGLRenderingContext} gl

_prepare(gl) {
this._texture = new Texture();
this._texture.generateMipmaps = false;
this._texture.size = this._size;
this._glContext = gl;
this._texture = new Texture(null, this.options);
this._texture._prepare(gl);

@@ -84,5 +96,5 @@

gl.bindRenderbuffer(gl.RENDERBUFFER, this._renderBuffer);
gl.renderbufferStorage(gl.RENDERBUFFER, gl.DEPTH_COMPONENT16, this._size[0], this._size[1]);
gl.renderbufferStorage(gl.RENDERBUFFER, gl.DEPTH_COMPONENT16, this.options.size[0], this.options.size[1]);
gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._texture._texture, 0);
gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._texture.getTexture(), 0);
gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.DEPTH_ATTACHMENT, gl.RENDERBUFFER, this._renderBuffer);

@@ -98,7 +110,7 @@

* Удаляет данные из видеокарты
* @param {WebGLRenderingContext} gl
* @ignore
*/
_unprepare(gl) {
_unprepare() {
if (this._frameBuffer) {
const gl = this._glContext;
this._texture.remove(gl);

@@ -108,2 +120,4 @@ gl.deleteFramebuffer(this._frameBuffer);

this._frameBuffer = null;
this._renderBuffer = null;
this._texture = null;
}

@@ -136,3 +150,15 @@ }

RenderTarget.defaultOptions = Object.assign({}, Texture.defaultOptions, {
size: [0, 0],
generateMipmaps: false
});
export default RenderTarget;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/RenderTarget.js"],"names":["Texture","RenderTarget","constructor","options","_size","size","bind","gl","_sizeChanged","_unprepare","_frameBuffer","_prepare","bindFramebuffer","FRAMEBUFFER","unbind","remove","setSize","_texture","generateMipmaps","createFramebuffer","_renderBuffer","createRenderbuffer","bindRenderbuffer","RENDERBUFFER","renderbufferStorage","DEPTH_COMPONENT16","framebufferTexture2D","COLOR_ATTACHMENT0","TEXTURE_2D","framebufferRenderbuffer","DEPTH_ATTACHMENT","_checkComplete","deleteFramebuffer","deleteRenderbuffer","status","checkFramebufferStatus","FRAMEBUFFER_COMPLETE","FRAMEBUFFER_UNSUPPORTED","console","log","FRAMEBUFFER_INCOMPLETE_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_DIMENSIONS","FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT"],"mappings":"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","file":"RenderTarget.js","sourcesContent":["import Texture from './Texture';\n\n/**\n * Используется для создания фреймбуфера, куда можно отрендерить кадр.\n *\n * @param {Object} options\n * @param {vec2} [options.size] Размер фреймбуфера\n */\nclass RenderTarget {\n    constructor(options = {}) {\n        this._size = options.size;\n    }\n\n    /**\n     * Связывает компоненты с контекстом WebGL\n     * @param {WebGLRenderingContext} gl\n     */\n    bind(gl) {\n        if (this._sizeChanged) {\n            this._unprepare(gl);\n            this._sizeChanged = false;\n        }\n\n        if (!this._frameBuffer) {\n            this._prepare(gl);\n        }\n\n        gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);\n\n        return this;\n    }\n\n    /**\n     * Устанавливает пустой фреймбуфер у контекста WebGL\n     * @param {WebGLRenderingContext} gl\n     */\n    unbind(gl) {\n        gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n        return this;\n    }\n\n    /**\n     * Удаляет фреймбуфер из видеокарты\n     * @param {WebGLRenderingContext} gl\n     */\n    remove(gl) {\n        this._unprepare(gl);\n        return this;\n    }\n\n    /**\n     * Устанавливает размер фреймбуферу\n     * @param {vec2} size\n     */\n    setSize(size) {\n        this._size = size;\n        this._sizeChanged = true;\n        return this;\n    }\n\n    /**\n     * Инициализирует фреймбуфер, текстуры и рендербуфер\n     * @param {WebGLRenderingContext} gl\n     * @ignore\n     */\n    _prepare(gl) {\n        this._texture = new Texture();\n        this._texture.generateMipmaps = false;\n        this._texture.size = this._size;\n\n        this._texture._prepare(gl);\n\n        this._frameBuffer = gl.createFramebuffer();\n        gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);\n\n        this._renderBuffer = gl.createRenderbuffer();\n        gl.bindRenderbuffer(gl.RENDERBUFFER, this._renderBuffer);\n        gl.renderbufferStorage(gl.RENDERBUFFER, gl.DEPTH_COMPONENT16, this._size[0], this._size[1]);\n\n        gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._texture._texture, 0);\n        gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.DEPTH_ATTACHMENT, gl.RENDERBUFFER, this._renderBuffer);\n\n        this._checkComplete(gl);\n\n        gl.bindRenderbuffer(gl.RENDERBUFFER, null);\n        gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n    }\n\n    /**\n     * Удаляет данные из видеокарты\n     * @param {WebGLRenderingContext} gl\n     * @ignore\n     */\n    _unprepare(gl) {\n        if (this._frameBuffer) {\n            this._texture.remove(gl);\n            gl.deleteFramebuffer(this._frameBuffer);\n            gl.deleteRenderbuffer(this._renderBuffer);\n            this._frameBuffer = null;\n        }\n    }\n\n    /**\n     * Проверяет инициализацию фреймбуфера\n     * @param {WebGLRenderingContext} gl\n     * @ignore\n     */\n    _checkComplete(gl) {\n        const status = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\n\n        if (status === gl.FRAMEBUFFER_COMPLETE) {\n            return;\n        } else if (status === gl.FRAMEBUFFER_UNSUPPORTED) {\n            console.log('Framebuffer is unsupported');\n        } else if (status === gl.FRAMEBUFFER_INCOMPLETE_ATTACHMENT) {\n            console.log('Framebuffer incomplete attachment');\n        } else if (status === gl.FRAMEBUFFER_INCOMPLETE_DIMENSIONS) {\n            console.log('Framebuffer incomplete dimensions');\n        } else if (status === gl.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT) {\n            console.log('Framebuffer incomplete missing attachment');\n        } else {\n            console.log('Unexpected framebuffer status: ' + status);\n        }\n    }\n}\n\nexport default RenderTarget;\n"]}
/**
* Параметры связывания текстуры
*
* @typedef {Object} RenderTargetOptions
* @property {Number[]} size
*/
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/RenderTarget.js"],"names":["Texture","RenderTarget","constructor","options","Object","assign","defaultOptions","_glContext","bind","gl","_frameBuffer","_prepare","bindFramebuffer","FRAMEBUFFER","unbind","remove","_unprepare","setSize","size","getTexture","_texture","createFramebuffer","_renderBuffer","createRenderbuffer","bindRenderbuffer","RENDERBUFFER","renderbufferStorage","DEPTH_COMPONENT16","framebufferTexture2D","COLOR_ATTACHMENT0","TEXTURE_2D","framebufferRenderbuffer","DEPTH_ATTACHMENT","_checkComplete","deleteFramebuffer","deleteRenderbuffer","status","checkFramebufferStatus","FRAMEBUFFER_COMPLETE","FRAMEBUFFER_UNSUPPORTED","console","log","FRAMEBUFFER_INCOMPLETE_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_DIMENSIONS","FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT","generateMipmaps"],"mappings":"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","file":"RenderTarget.js","sourcesContent":["import Texture from './Texture';\n\n/**\n * Используется для создания фреймбуфера, куда можно отрендерить кадр.\n *\n * @param {RenderTargetOptions & TextureOptions} options\n */\nclass RenderTarget {\n    constructor(options = {}) {\n        /**\n         * Параметры для связывания фреймбуфера\n         * @type {RenderTargetOptions & TextureOptions}\n         * @readonly\n         */\n        this.options = Object.assign({}, RenderTarget.defaultOptions, options);\n\n        /**\n         * Контекст WebGL, в котором был инициализирован фреймбуфер.\n         * Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.\n         * @type {?WebGLRenderingContext}\n         * @ignore\n         */\n        this._glContext = null;\n    }\n\n    /**\n     * Связывает компоненты с контекстом WebGL\n     * @param {WebGLRenderingContext} gl\n     */\n    bind(gl) {\n        if (!this._frameBuffer) {\n            this._prepare(gl);\n        }\n\n        gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);\n\n        return this;\n    }\n\n    /**\n     * Устанавливает пустой фреймбуфер у контекста WebGL\n     * @param {WebGLRenderingContext} gl\n     */\n    unbind(gl) {\n        gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n        return this;\n    }\n\n    /**\n     * Удаляет фреймбуфер из видеокарты\n     */\n    remove() {\n        this._unprepare();\n        return this;\n    }\n\n    /**\n     * Устанавливает размер фреймбуферу\n     * @param {vec2} size\n     */\n    setSize(size) {\n        this.options.size = size;\n        this._unprepare();\n        return this;\n    }\n\n    /**\n     * Возвращает текущую текстуру фреймбуфера\n     * @return {Texture | null}\n     */\n    getTexture() {\n        return this._texture;\n    }\n\n    /**\n     * Инициализирует фреймбуфер, текстуры и рендербуфер\n     * @param {WebGLRenderingContext} gl\n     * @ignore\n     */\n    _prepare(gl) {\n        this._glContext = gl;\n        this._texture = new Texture(null, this.options);\n        this._texture._prepare(gl);\n\n        this._frameBuffer = gl.createFramebuffer();\n        gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);\n\n        this._renderBuffer = gl.createRenderbuffer();\n        gl.bindRenderbuffer(gl.RENDERBUFFER, this._renderBuffer);\n        gl.renderbufferStorage(gl.RENDERBUFFER, gl.DEPTH_COMPONENT16, this.options.size[0], this.options.size[1]);\n\n        gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._texture.getTexture(), 0);\n        gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.DEPTH_ATTACHMENT, gl.RENDERBUFFER, this._renderBuffer);\n\n        this._checkComplete(gl);\n\n        gl.bindRenderbuffer(gl.RENDERBUFFER, null);\n        gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n    }\n\n    /**\n     * Удаляет данные из видеокарты\n     * @ignore\n     */\n    _unprepare() {\n        if (this._frameBuffer) {\n            const gl = this._glContext;\n            this._texture.remove(gl);\n            gl.deleteFramebuffer(this._frameBuffer);\n            gl.deleteRenderbuffer(this._renderBuffer);\n            this._frameBuffer = null;\n            this._renderBuffer = null;\n            this._texture = null;\n        }\n    }\n\n    /**\n     * Проверяет инициализацию фреймбуфера\n     * @param {WebGLRenderingContext} gl\n     * @ignore\n     */\n    _checkComplete(gl) {\n        const status = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\n\n        if (status === gl.FRAMEBUFFER_COMPLETE) {\n            return;\n        } else if (status === gl.FRAMEBUFFER_UNSUPPORTED) {\n            console.log('Framebuffer is unsupported');\n        } else if (status === gl.FRAMEBUFFER_INCOMPLETE_ATTACHMENT) {\n            console.log('Framebuffer incomplete attachment');\n        } else if (status === gl.FRAMEBUFFER_INCOMPLETE_DIMENSIONS) {\n            console.log('Framebuffer incomplete dimensions');\n        } else if (status === gl.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT) {\n            console.log('Framebuffer incomplete missing attachment');\n        } else {\n            console.log('Unexpected framebuffer status: ' + status);\n        }\n    }\n}\n\nRenderTarget.defaultOptions = Object.assign({}, Texture.defaultOptions, {\n    size: [0, 0],\n    generateMipmaps: false,\n});\n\nexport default RenderTarget;\n\n/**\n * Параметры связывания текстуры\n *\n * @typedef {Object} RenderTargetOptions\n * @property {Number[]} size\n */\n"]}

@@ -121,2 +121,3 @@ /**

this._initData = null;
return this;
}

@@ -123,0 +124,0 @@

@@ -14,4 +14,4 @@ import Object3DPlugin from './rendererPlugins/Object3DPlugin';

* @param {Boolean} [options.autoClear=true] Стирать ли прошлый кадр перед новый рендерингом
* @param {Array} [options.clearColor=true] Цвет заливки в формате RGBA
* @param {Object} [options.sortObjects=true] Нужно ли сортировать прозрачные объекты по удаленности
* @param {Number[]} [options.clearColor=[1,1,1,1]] Цвет заливки в формате RGBA
* @param {Boolean} [options.sortObjects=true] Нужно ли сортировать прозрачные объекты по удаленности
* или по renderOrder

@@ -34,4 +34,6 @@ * */

this._gl = this._canvasElement.getContext('webgl', attributes) ||
this._canvasElement.getContext('experimental-webgl', attributes);
this._gl = options.version === 2 ?
this._canvasElement.getContext('webgl2', attributes) :
(this._canvasElement.getContext('webgl', attributes) ||
this._canvasElement.getContext('experimental-webgl', attributes));
} else {

@@ -38,0 +40,0 @@ this._gl = options.gl;

@@ -6,8 +6,20 @@ import Texture from './Texture';

*
* @param {Object} options
* @param {vec2} [options.size] Размер фреймбуфера
* @param {RenderTargetOptions & TextureOptions} options
*/
class RenderTarget {
constructor(options = {}) {
this._size = options.size;
/**
* Параметры для связывания фреймбуфера
* @type {RenderTargetOptions & TextureOptions}
* @readonly
*/
this.options = Object.assign({}, RenderTarget.defaultOptions, options);
/**
* Контекст WebGL, в котором был инициализирован фреймбуфер.
* Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.
* @type {?WebGLRenderingContext}
* @ignore
*/
this._glContext = null;
}

@@ -20,7 +32,2 @@

bind(gl) {
if (this._sizeChanged) {
this._unprepare(gl);
this._sizeChanged = false;
}
if (!this._frameBuffer) {

@@ -46,6 +53,5 @@ this._prepare(gl);

* Удаляет фреймбуфер из видеокарты
* @param {WebGLRenderingContext} gl
*/
remove(gl) {
this._unprepare(gl);
remove() {
this._unprepare();
return this;

@@ -59,4 +65,4 @@ }

setSize(size) {
this._size = size;
this._sizeChanged = true;
this.options.size = size;
this._unprepare();
return this;

@@ -66,2 +72,10 @@ }

/**
* Возвращает текущую текстуру фреймбуфера
* @return {Texture | null}
*/
getTexture() {
return this._texture;
}
/**
* Инициализирует фреймбуфер, текстуры и рендербуфер

@@ -72,6 +86,4 @@ * @param {WebGLRenderingContext} gl

_prepare(gl) {
this._texture = new Texture();
this._texture.generateMipmaps = false;
this._texture.size = this._size;
this._glContext = gl;
this._texture = new Texture(null, this.options);
this._texture._prepare(gl);

@@ -84,5 +96,5 @@

gl.bindRenderbuffer(gl.RENDERBUFFER, this._renderBuffer);
gl.renderbufferStorage(gl.RENDERBUFFER, gl.DEPTH_COMPONENT16, this._size[0], this._size[1]);
gl.renderbufferStorage(gl.RENDERBUFFER, gl.DEPTH_COMPONENT16, this.options.size[0], this.options.size[1]);
gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._texture._texture, 0);
gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._texture.getTexture(), 0);
gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.DEPTH_ATTACHMENT, gl.RENDERBUFFER, this._renderBuffer);

@@ -98,7 +110,7 @@

* Удаляет данные из видеокарты
* @param {WebGLRenderingContext} gl
* @ignore
*/
_unprepare(gl) {
_unprepare() {
if (this._frameBuffer) {
const gl = this._glContext;
this._texture.remove(gl);

@@ -108,2 +120,4 @@ gl.deleteFramebuffer(this._frameBuffer);

this._frameBuffer = null;
this._renderBuffer = null;
this._texture = null;
}

@@ -136,2 +150,14 @@ }

RenderTarget.defaultOptions = Object.assign({}, Texture.defaultOptions, {
size: [0, 0],
generateMipmaps: false,
});
export default RenderTarget;
/**
* Параметры связывания текстуры
*
* @typedef {Object} RenderTargetOptions
* @property {Number[]} size
*/
/**
* Текстуры используются для отрисовки изображений в WebGL
*/
class Texture {
/**
* @param {HTMLImageElement | HTMLCanvasElement} [src=null] В качестве изображения может быть
* либо элемент img, либо canvas
* @param {HTMLImageElement | HTMLCanvasElement | ImageBitmap | ImageData | TypedArray} [src=null] В качестве
* изображения может быть либо элемент img, либо canvas
* @param {?TextureOptions} options
*/
constructor(src) {
constructor(src, options = {}) {
this._src = src || null;
/**
* Тип фильтра при отображении текстуры, размеры которой больше, чем размеры исходной картинки
* @type {TextureFilter}
* Параметры для связывания текстуры
* @type {TextureOptions}
* @readonly
*/
this.magFilter = Texture.LinearFilter;
this.options = Object.assign({}, Texture.defaultOptions, options);
/**
* Тип фильтра при отображении текстуры, размеры которой меньше, чем размеры исходной картинки
* @type {TextureFilter}
*/
this.minFilter = Texture.LinearMipMapLinearFilter;
/**
* Что делать, если ширина исходной картинки не равна степени 2.
* @type {TextureClamp}
*/
this.wrapS = Texture.ClampToEdgeWrapping;
/**
* Что делать, если высота исходной картинки не равна степени 2.
* @type {TextureClamp}
*/
this.wrapT = Texture.ClampToEdgeWrapping;
/**
* Формат текстуры (RGBA или Alpha)
* @type {TextureFormat}
*/
this.format = Texture.RgbaFormat;
/**
* Генерировать ли mipmaps.
* Они значительно повышают качество и производительность отображения.
* Mipmaps могут использоваться только, если размеры текстуры равны степени 2.
*
* @type {Boolean}
*/
this.generateMipmaps = true;
/**
* Нужно ли отражать текстуру относительно оси Y.
* @type {Boolean}
*/
this.flipY = true;
/**
* Сохранен ли цвет текстуры с premultiply аlpha.
* @type {Boolean}
*/
this.premultiplyAlpha = true;
/**
* Контекст WebGL, в котором была инициализирована текстура.

@@ -81,4 +39,6 @@ * Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.

enable(gl, index) {
if (index !== undefined) {
gl.activeTexture(gl.TEXTURE0 + index);
const unit = index !== undefined ? index : this.options.unit;
if (unit !== undefined) {
gl.activeTexture(gl.TEXTURE0 + unit);
}

@@ -108,2 +68,10 @@

/**
* Возвращает WebGL текстуру
* @return {WebGLTexture}
*/
getTexture() {
return this._texture;
}
_prepare(gl) {

@@ -114,14 +82,14 @@ this._glContext = gl;

gl.bindTexture(gl.TEXTURE_2D, this._texture);
gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, this.flipY);
gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.premultiplyAlpha);
gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, this.options.flipY);
gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.options.premultiplyAlpha);
if (this.size) {
if (this.options.size) {
gl.texImage2D(
gl.TEXTURE_2D,
0,
this._toGlParam(gl, this.format),
this.size[0],
this.size[1],
this._toGlParam(gl, this.options.format),
this.options.size[0],
this.options.size[1],
0,
this._toGlParam(gl, this.format),
this._toGlParam(gl, this.options.format),
gl.UNSIGNED_BYTE,

@@ -131,12 +99,19 @@ this._src

} else {
gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, this._src);
gl.texImage2D(
gl.TEXTURE_2D,
0,
this._toGlParam(gl, this.options.format),
this._toGlParam(gl, this.options.format),
gl.UNSIGNED_BYTE,
this._src
);
}
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, this._toGlParam(gl, this.wrapS));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, this._toGlParam(gl, this.wrapT));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, this._toGlParam(gl, this.options.wrapS));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, this._toGlParam(gl, this.options.wrapT));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, this._toGlParam(gl, this.magFilter));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, this._toGlParam(gl, this.minFilter));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, this._toGlParam(gl, this.options.magFilter));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, this._toGlParam(gl, this.options.minFilter));
if (this.generateMipmaps &&
if (this.options.generateMipmaps &&
this.minFilter !== Texture.NearestFilter &&

@@ -165,2 +140,3 @@ this.minFilter !== Texture.LinearFilter

if (param === Texture.AlphaFormat) { return gl.ALPHA; }
if (param === Texture.RgbFormat) { return gl.RGB; }
return null;

@@ -183,3 +159,15 @@ }

Texture.AlphaFormat = 12;
Texture.RgbFormat = 13;
Texture.defaultOptions = {
magFilter: Texture.LinearFilter,
minFilter: Texture.LinearMipMapLinearFilter,
wrapS: Texture.ClampToEdgeWrapping,
wrapT: Texture.ClampToEdgeWrapping,
format: Texture.RgbaFormat,
generateMipmaps: true,
flipY: true,
premultiplyAlpha: true,
};
export default Texture;

@@ -200,1 +188,17 @@

*/
/**
* Параметры связывания текстуры
*
* @typedef {Object} TextureOptions
* @property {TextureFilter} magFilter
* @property {TextureFilter} minFilter
* @property {TextureClamp} wrapS
* @property {TextureClamp} wrapT
* @property {TextureFormat} format
* @property {Boolean} generateMipmaps
* @property {Boolean} flipY
* @property {Boolean} premultiplyAlpha
* @property {?Number[]} size
* @property {?Number} unit
*/

@@ -45,10 +45,6 @@ /**

* стандартный подход для связывания атрибутов через {@link ShaderProgram#bind}.
*
* @param {State} state Стейт рендерера
*/
unbind(state) {
const ext = state.extensions.OES_vertex_array_object;
if (ext) {
ext.bindVertexArrayOES(null);
unbind() {
if (this._ext) {
this._ext.bindVertexArrayOES(null);
}

@@ -55,0 +51,0 @@

/**
* Текстуры используются для отрисовки изображений в WebGL
*/
class Texture {
/**
* @param {HTMLImageElement | HTMLCanvasElement} [src=null] В качестве изображения может быть
* либо элемент img, либо canvas
*/
constructor(src) {
this._src = src || null;
/**
* Тип фильтра при отображении текстуры, размеры которой больше, чем размеры исходной картинки
* @type {TextureFilter}
* @param {HTMLImageElement | HTMLCanvasElement | ImageBitmap | ImageData | TypedArray} [src=null] В качестве
* изображения может быть либо элемент img, либо canvas
* @param {?TextureOptions} options
*/
this.magFilter = Texture.LinearFilter;
constructor(src, options = {}) {
this._src = src || null;
/**
* Тип фильтра при отображении текстуры, размеры которой меньше, чем размеры исходной картинки
* @type {TextureFilter}
*/
this.minFilter = Texture.LinearMipMapLinearFilter;
/**
* Параметры для связывания текстуры
* @type {TextureOptions}
* @readonly
*/
this.options = Object.assign({}, Texture.defaultOptions, options);
/**
* Что делать, если ширина исходной картинки не равна степени 2.
* @type {TextureClamp}
*/
this.wrapS = Texture.ClampToEdgeWrapping;
/**
* Контекст WebGL, в котором была инициализирована текстура.
* Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.
* @type {?WebGLRenderingContext}
* @ignore
*/
this._glContext = null;
}
/**
* Что делать, если высота исходной картинки не равна степени 2.
* @type {TextureClamp}
* Связывает WebGL и данные текстуры.
* При первом вызов происходит инициализация.
*
* @param {WebGLRenderingContext} gl
* @param {?Number} index Номер текстуры в контексте WebGL.
* Если его нет, используется уже активированный юнит текстуры.
*/
this.wrapT = Texture.ClampToEdgeWrapping;
enable(gl, index) {
const unit = index !== undefined ? index : this.options.unit;
/**
* Формат текстуры (RGBA или Alpha)
* @type {TextureFormat}
*/
this.format = Texture.RgbaFormat;
if (unit !== undefined) {
gl.activeTexture(gl.TEXTURE0 + unit);
}
/**
* Генерировать ли mipmaps.
* Они значительно повышают качество и производительность отображения.
* Mipmaps могут использоваться только, если размеры текстуры равны степени 2.
*
* @type {Boolean}
*/
this.generateMipmaps = true;
if (!this._texture) {
this._prepare(gl);
}
/**
* Нужно ли отражать текстуру относительно оси Y.
* @type {Boolean}
*/
this.flipY = true;
gl.bindTexture(gl.TEXTURE_2D, this._texture);
/**
* Сохранен ли цвет текстуры с premultiply аlpha.
* @type {Boolean}
*/
this.premultiplyAlpha = true;
return this;
}
/**
* Контекст WebGL, в котором была инициализирована текстура.
* Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.
* @type {?WebGLRenderingContext}
* @ignore
* Удаляет текстуру из видеокарты
*/
this._glContext = null;
}
remove() {
if (this._texture) {
this._glContext.deleteTexture(this._texture);
this._glContext = null;
this._texture = null;
}
/**
* Связывает WebGL и данные текстуры.
* При первом вызов происходит инициализация.
*
* @param {WebGLRenderingContext} gl
* @param {?Number} index Номер текстуры в контексте WebGL.
* Если его нет, используется уже активированный юнит текстуры.
*/
enable(gl, index) {
if (index !== undefined) {
gl.activeTexture(gl.TEXTURE0 + index);
return this;
}
if (!this._texture) {
this._prepare(gl);
/**
* Возвращает WebGL текстуру
* @return {WebGLTexture}
*/
getTexture() {
return this._texture;
}
gl.bindTexture(gl.TEXTURE_2D, this._texture);
_prepare(gl) {
this._glContext = gl;
this._texture = gl.createTexture();
return this;
}
gl.bindTexture(gl.TEXTURE_2D, this._texture);
gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, this.options.flipY);
gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.options.premultiplyAlpha);
/**
* Удаляет текстуру из видеокарты
*/
remove() {
if (this._texture) {
this._glContext.deleteTexture(this._texture);
this._glContext = null;
this._texture = null;
}
if (this.options.size) {
gl.texImage2D(gl.TEXTURE_2D, 0, this._toGlParam(gl, this.options.format), this.options.size[0], this.options.size[1], 0, this._toGlParam(gl, this.options.format), gl.UNSIGNED_BYTE, this._src);
} else {
gl.texImage2D(gl.TEXTURE_2D, 0, this._toGlParam(gl, this.options.format), this._toGlParam(gl, this.options.format), gl.UNSIGNED_BYTE, this._src);
}
return this;
}
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, this._toGlParam(gl, this.options.wrapS));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, this._toGlParam(gl, this.options.wrapT));
_prepare(gl) {
this._glContext = gl;
this._texture = gl.createTexture();
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, this._toGlParam(gl, this.options.magFilter));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, this._toGlParam(gl, this.options.minFilter));
gl.bindTexture(gl.TEXTURE_2D, this._texture);
gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, this.flipY);
gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.premultiplyAlpha);
if (this.options.generateMipmaps && this.minFilter !== Texture.NearestFilter && this.minFilter !== Texture.LinearFilter) {
gl.generateMipmap(gl.TEXTURE_2D);
}
if (this.size) {
gl.texImage2D(gl.TEXTURE_2D, 0, this._toGlParam(gl, this.format), this.size[0], this.size[1], 0, this._toGlParam(gl, this.format), gl.UNSIGNED_BYTE, this._src);
} else {
gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, this._src);
gl.bindTexture(gl.TEXTURE_2D, null);
}
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, this._toGlParam(gl, this.wrapS));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, this._toGlParam(gl, this.wrapT));
_toGlParam(gl, param) {
if (param === Texture.ClampToEdgeWrapping) {
return gl.CLAMP_TO_EDGE;
}
if (param === Texture.Repeat) {
return gl.REPEAT;
}
if (param === Texture.MirroredRepeat) {
return gl.MIRRORED_REPEAT;
}
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, this._toGlParam(gl, this.magFilter));
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, this._toGlParam(gl, this.minFilter));
if (param === Texture.NearestFilter) {
return gl.NEAREST;
}
if (param === Texture.NearestMipMapNearestFilter) {
return gl.NEAREST_MIPMAP_NEAREST;
}
if (param === Texture.NearestMipMapLinearFilter) {
return gl.NEAREST_MIPMAP_LINEAR;
}
if (this.generateMipmaps && this.minFilter !== Texture.NearestFilter && this.minFilter !== Texture.LinearFilter) {
gl.generateMipmap(gl.TEXTURE_2D);
if (param === Texture.LinearFilter) {
return gl.LINEAR;
}
if (param === Texture.LinearMipMapNearestFilter) {
return gl.LINEAR_MIPMAP_NEAREST;
}
if (param === Texture.LinearMipMapLinearFilter) {
return gl.LINEAR_MIPMAP_LINEAR;
}
if (param === Texture.RgbaFormat) {
return gl.RGBA;
}
if (param === Texture.AlphaFormat) {
return gl.ALPHA;
}
if (param === Texture.RgbFormat) {
return gl.RGB;
}
return null;
}
gl.bindTexture(gl.TEXTURE_2D, null);
}
_toGlParam(gl, param) {
if (param === Texture.ClampToEdgeWrapping) {
return gl.CLAMP_TO_EDGE;
}
if (param === Texture.Repeat) {
return gl.REPEAT;
}
if (param === Texture.MirroredRepeat) {
return gl.MIRRORED_REPEAT;
}
if (param === Texture.NearestFilter) {
return gl.NEAREST;
}
if (param === Texture.NearestMipMapNearestFilter) {
return gl.NEAREST_MIPMAP_NEAREST;
}
if (param === Texture.NearestMipMapLinearFilter) {
return gl.NEAREST_MIPMAP_LINEAR;
}
if (param === Texture.LinearFilter) {
return gl.LINEAR;
}
if (param === Texture.LinearMipMapNearestFilter) {
return gl.LINEAR_MIPMAP_NEAREST;
}
if (param === Texture.LinearMipMapLinearFilter) {
return gl.LINEAR_MIPMAP_LINEAR;
}
if (param === Texture.RgbaFormat) {
return gl.RGBA;
}
if (param === Texture.AlphaFormat) {
return gl.ALPHA;
}
return null;
}
}

@@ -187,3 +158,15 @@

Texture.AlphaFormat = 12;
Texture.RgbFormat = 13;
Texture.defaultOptions = {
magFilter: Texture.LinearFilter,
minFilter: Texture.LinearMipMapLinearFilter,
wrapS: Texture.ClampToEdgeWrapping,
wrapT: Texture.ClampToEdgeWrapping,
format: Texture.RgbaFormat,
generateMipmaps: true,
flipY: true,
premultiplyAlpha: true
};
export default Texture;

@@ -204,2 +187,18 @@

*/
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/Texture.js"],"names":["Texture","constructor","src","_src","magFilter","LinearFilter","minFilter","LinearMipMapLinearFilter","wrapS","ClampToEdgeWrapping","wrapT","format","RgbaFormat","generateMipmaps","flipY","premultiplyAlpha","_glContext","enable","gl","index","undefined","activeTexture","TEXTURE0","_texture","_prepare","bindTexture","TEXTURE_2D","remove","deleteTexture","createTexture","pixelStorei","UNPACK_FLIP_Y_WEBGL","UNPACK_PREMULTIPLY_ALPHA_WEBGL","size","texImage2D","_toGlParam","UNSIGNED_BYTE","RGBA","texParameteri","TEXTURE_WRAP_S","TEXTURE_WRAP_T","TEXTURE_MAG_FILTER","TEXTURE_MIN_FILTER","NearestFilter","generateMipmap","param","CLAMP_TO_EDGE","Repeat","REPEAT","MirroredRepeat","MIRRORED_REPEAT","NEAREST","NearestMipMapNearestFilter","NEAREST_MIPMAP_NEAREST","NearestMipMapLinearFilter","NEAREST_MIPMAP_LINEAR","LINEAR","LinearMipMapNearestFilter","LINEAR_MIPMAP_NEAREST","LINEAR_MIPMAP_LINEAR","AlphaFormat","ALPHA"],"mappings":"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","file":"Texture.js","sourcesContent":["/**\n * Текстуры используются для отрисовки изображений в WebGL\n */\nclass Texture {\n    /**\n     * @param {HTMLImageElement | HTMLCanvasElement} [src=null] В качестве изображения может быть\n     * либо элемент img, либо canvas\n     */\n    constructor(src) {\n        this._src = src || null;\n\n        /**\n         * Тип фильтра при отображении текстуры, размеры которой больше, чем размеры исходной картинки\n         * @type {TextureFilter}\n         */\n        this.magFilter = Texture.LinearFilter;\n\n        /**\n         * Тип фильтра при отображении текстуры, размеры которой меньше, чем размеры исходной картинки\n         * @type {TextureFilter}\n         */\n        this.minFilter = Texture.LinearMipMapLinearFilter;\n\n        /**\n         * Что делать, если ширина исходной картинки не равна степени 2.\n         * @type {TextureClamp}\n         */\n        this.wrapS = Texture.ClampToEdgeWrapping;\n\n        /**\n         * Что делать, если высота исходной картинки не равна степени 2.\n         * @type {TextureClamp}\n         */\n        this.wrapT = Texture.ClampToEdgeWrapping;\n\n        /**\n         * Формат текстуры (RGBA или Alpha)\n         * @type {TextureFormat}\n         */\n        this.format = Texture.RgbaFormat;\n\n        /**\n         * Генерировать ли mipmaps.\n         * Они значительно повышают качество и производительность отображения.\n         * Mipmaps могут использоваться только, если размеры текстуры равны степени 2.\n         *\n         * @type {Boolean}\n         */\n        this.generateMipmaps = true;\n\n        /**\n         * Нужно ли отражать текстуру относительно оси Y.\n         * @type {Boolean}\n         */\n        this.flipY = true;\n\n        /**\n         * Сохранен ли цвет текстуры с premultiply аlpha.\n         * @type {Boolean}\n         */\n        this.premultiplyAlpha = true;\n\n        /**\n         * Контекст WebGL, в котором была инициализирована текстура.\n         * Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.\n         * @type {?WebGLRenderingContext}\n         * @ignore\n         */\n        this._glContext = null;\n    }\n\n    /**\n     * Связывает WebGL и данные текстуры.\n     * При первом вызов происходит инициализация.\n     *\n     * @param {WebGLRenderingContext} gl\n     * @param {?Number} index Номер текстуры в контексте WebGL.\n     * Если его нет, используется уже активированный юнит текстуры.\n     */\n    enable(gl, index) {\n        if (index !== undefined) {\n            gl.activeTexture(gl.TEXTURE0 + index);\n        }\n\n        if (!this._texture) {\n            this._prepare(gl);\n        }\n\n        gl.bindTexture(gl.TEXTURE_2D, this._texture);\n\n        return this;\n    }\n\n    /**\n     * Удаляет текстуру из видеокарты\n     */\n    remove() {\n        if (this._texture) {\n            this._glContext.deleteTexture(this._texture);\n            this._glContext = null;\n            this._texture = null;\n        }\n\n        return this;\n    }\n\n    _prepare(gl) {\n        this._glContext = gl;\n        this._texture = gl.createTexture();\n\n        gl.bindTexture(gl.TEXTURE_2D, this._texture);\n        gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, this.flipY);\n        gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.premultiplyAlpha);\n\n        if (this.size) {\n            gl.texImage2D(\n                gl.TEXTURE_2D,\n                0,\n                this._toGlParam(gl, this.format),\n                this.size[0],\n                this.size[1],\n                0,\n                this._toGlParam(gl, this.format),\n                gl.UNSIGNED_BYTE,\n                this._src\n            );\n        } else {\n            gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, this._src);\n        }\n\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, this._toGlParam(gl, this.wrapS));\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, this._toGlParam(gl, this.wrapT));\n\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, this._toGlParam(gl, this.magFilter));\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, this._toGlParam(gl, this.minFilter));\n\n        if (this.generateMipmaps &&\n            this.minFilter !== Texture.NearestFilter &&\n            this.minFilter !== Texture.LinearFilter\n        ) {\n            gl.generateMipmap(gl.TEXTURE_2D);\n        }\n\n        gl.bindTexture(gl.TEXTURE_2D, null);\n    }\n\n    _toGlParam(gl, param) {\n        if (param === Texture.ClampToEdgeWrapping) { return gl.CLAMP_TO_EDGE; }\n        if (param === Texture.Repeat) { return gl.REPEAT; }\n        if (param === Texture.MirroredRepeat) { return gl.MIRRORED_REPEAT; }\n\n        if (param === Texture.NearestFilter) { return gl.NEAREST; }\n        if (param === Texture.NearestMipMapNearestFilter) { return gl.NEAREST_MIPMAP_NEAREST; }\n        if (param === Texture.NearestMipMapLinearFilter) { return gl.NEAREST_MIPMAP_LINEAR; }\n\n        if (param === Texture.LinearFilter) { return gl.LINEAR; }\n        if (param === Texture.LinearMipMapNearestFilter) { return gl.LINEAR_MIPMAP_NEAREST; }\n        if (param === Texture.LinearMipMapLinearFilter) { return gl.LINEAR_MIPMAP_LINEAR; }\n        if (param === Texture.RgbaFormat) { return gl.RGBA; }\n        if (param === Texture.AlphaFormat) { return gl.ALPHA; }\n        return null;\n    }\n}\n\nTexture.ClampToEdgeWrapping = 8;\nTexture.Repeat = 9;\nTexture.MirroredRepeat = 10;\n\nTexture.NearestFilter = 1;\nTexture.NearestMipMapNearestFilter = 2;\nTexture.NearestMipMapLinearFilter = 3;\nTexture.LinearFilter = 4;\nTexture.LinearMipMapNearestFilter = 5;\nTexture.LinearMipMapLinearFilter = 6;\n\nTexture.RgbaFormat = 11;\nTexture.AlphaFormat = 12;\n\nexport default Texture;\n\n/**\n * @typedef {Texture.NearestFilter | Texture.NearestMipMapNearestFilter |\n * Texture.NearestMipMapLinearFilter | Texture.LinearFilter |\n * Texture.LinearMipMapNearestFilter | Texture.LinearMipMapLinearFilter} TextureFilter\n */\n\n/**\n * @typedef {Texture.ClampToEdgeWrapping} TextureClamp\n */\n\n/**\n * @typedef {Texture.RgbaFormat | Texture.AlphaFormat} TextureFormat\n */\n"]}
/**
* Параметры связывания текстуры
*
* @typedef {Object} TextureOptions
* @property {TextureFilter} magFilter
* @property {TextureFilter} minFilter
* @property {TextureClamp} wrapS
* @property {TextureClamp} wrapT
* @property {TextureFormat} format
* @property {Boolean} generateMipmaps
* @property {Boolean} flipY
* @property {Boolean} premultiplyAlpha
* @property {?Number[]} size
* @property {?Number} unit
*/
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/Texture.js"],"names":["Texture","constructor","src","options","_src","Object","assign","defaultOptions","_glContext","enable","gl","index","unit","undefined","activeTexture","TEXTURE0","_texture","_prepare","bindTexture","TEXTURE_2D","remove","deleteTexture","getTexture","createTexture","pixelStorei","UNPACK_FLIP_Y_WEBGL","flipY","UNPACK_PREMULTIPLY_ALPHA_WEBGL","premultiplyAlpha","size","texImage2D","_toGlParam","format","UNSIGNED_BYTE","texParameteri","TEXTURE_WRAP_S","wrapS","TEXTURE_WRAP_T","wrapT","TEXTURE_MAG_FILTER","magFilter","TEXTURE_MIN_FILTER","minFilter","generateMipmaps","NearestFilter","LinearFilter","generateMipmap","param","ClampToEdgeWrapping","CLAMP_TO_EDGE","Repeat","REPEAT","MirroredRepeat","MIRRORED_REPEAT","NEAREST","NearestMipMapNearestFilter","NEAREST_MIPMAP_NEAREST","NearestMipMapLinearFilter","NEAREST_MIPMAP_LINEAR","LINEAR","LinearMipMapNearestFilter","LINEAR_MIPMAP_NEAREST","LinearMipMapLinearFilter","LINEAR_MIPMAP_LINEAR","RgbaFormat","RGBA","AlphaFormat","ALPHA","RgbFormat","RGB"],"mappings":"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","file":"Texture.js","sourcesContent":["/**\n * Текстуры используются для отрисовки изображений в WebGL\n */\n\nclass Texture {\n    /**\n     * @param {HTMLImageElement | HTMLCanvasElement | ImageBitmap | ImageData | TypedArray} [src=null] В качестве\n     * изображения может быть либо элемент img, либо canvas\n     * @param {?TextureOptions} options\n     */\n    constructor(src, options = {}) {\n        this._src = src || null;\n\n        /**\n         * Параметры для связывания текстуры\n         * @type {TextureOptions}\n         * @readonly\n         */\n        this.options = Object.assign({}, Texture.defaultOptions, options);\n\n        /**\n         * Контекст WebGL, в котором была инициализирована текстура.\n         * Используется только для удаления, подумать хорошо, прежде чем использовать для чего-то ещё.\n         * @type {?WebGLRenderingContext}\n         * @ignore\n         */\n        this._glContext = null;\n    }\n\n    /**\n     * Связывает WebGL и данные текстуры.\n     * При первом вызов происходит инициализация.\n     *\n     * @param {WebGLRenderingContext} gl\n     * @param {?Number} index Номер текстуры в контексте WebGL.\n     * Если его нет, используется уже активированный юнит текстуры.\n     */\n    enable(gl, index) {\n        const unit = index !== undefined ? index : this.options.unit;\n\n        if (unit !== undefined) {\n            gl.activeTexture(gl.TEXTURE0 + unit);\n        }\n\n        if (!this._texture) {\n            this._prepare(gl);\n        }\n\n        gl.bindTexture(gl.TEXTURE_2D, this._texture);\n\n        return this;\n    }\n\n    /**\n     * Удаляет текстуру из видеокарты\n     */\n    remove() {\n        if (this._texture) {\n            this._glContext.deleteTexture(this._texture);\n            this._glContext = null;\n            this._texture = null;\n        }\n\n        return this;\n    }\n\n    /**\n     * Возвращает WebGL текстуру\n     * @return {WebGLTexture}\n     */\n    getTexture() {\n        return this._texture;\n    }\n\n    _prepare(gl) {\n        this._glContext = gl;\n        this._texture = gl.createTexture();\n\n        gl.bindTexture(gl.TEXTURE_2D, this._texture);\n        gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, this.options.flipY);\n        gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.options.premultiplyAlpha);\n\n        if (this.options.size) {\n            gl.texImage2D(\n                gl.TEXTURE_2D,\n                0,\n                this._toGlParam(gl, this.options.format),\n                this.options.size[0],\n                this.options.size[1],\n                0,\n                this._toGlParam(gl, this.options.format),\n                gl.UNSIGNED_BYTE,\n                this._src\n            );\n        } else {\n            gl.texImage2D(\n                gl.TEXTURE_2D,\n                0,\n                this._toGlParam(gl, this.options.format),\n                this._toGlParam(gl, this.options.format),\n                gl.UNSIGNED_BYTE,\n                this._src\n            );\n        }\n\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, this._toGlParam(gl, this.options.wrapS));\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, this._toGlParam(gl, this.options.wrapT));\n\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, this._toGlParam(gl, this.options.magFilter));\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, this._toGlParam(gl, this.options.minFilter));\n\n        if (this.options.generateMipmaps &&\n            this.minFilter !== Texture.NearestFilter &&\n            this.minFilter !== Texture.LinearFilter\n        ) {\n            gl.generateMipmap(gl.TEXTURE_2D);\n        }\n\n        gl.bindTexture(gl.TEXTURE_2D, null);\n    }\n\n    _toGlParam(gl, param) {\n        if (param === Texture.ClampToEdgeWrapping) { return gl.CLAMP_TO_EDGE; }\n        if (param === Texture.Repeat) { return gl.REPEAT; }\n        if (param === Texture.MirroredRepeat) { return gl.MIRRORED_REPEAT; }\n\n        if (param === Texture.NearestFilter) { return gl.NEAREST; }\n        if (param === Texture.NearestMipMapNearestFilter) { return gl.NEAREST_MIPMAP_NEAREST; }\n        if (param === Texture.NearestMipMapLinearFilter) { return gl.NEAREST_MIPMAP_LINEAR; }\n\n        if (param === Texture.LinearFilter) { return gl.LINEAR; }\n        if (param === Texture.LinearMipMapNearestFilter) { return gl.LINEAR_MIPMAP_NEAREST; }\n        if (param === Texture.LinearMipMapLinearFilter) { return gl.LINEAR_MIPMAP_LINEAR; }\n        if (param === Texture.RgbaFormat) { return gl.RGBA; }\n        if (param === Texture.AlphaFormat) { return gl.ALPHA; }\n        if (param === Texture.RgbFormat) { return gl.RGB; }\n        return null;\n    }\n}\n\nTexture.ClampToEdgeWrapping = 8;\nTexture.Repeat = 9;\nTexture.MirroredRepeat = 10;\n\nTexture.NearestFilter = 1;\nTexture.NearestMipMapNearestFilter = 2;\nTexture.NearestMipMapLinearFilter = 3;\nTexture.LinearFilter = 4;\nTexture.LinearMipMapNearestFilter = 5;\nTexture.LinearMipMapLinearFilter = 6;\n\nTexture.RgbaFormat = 11;\nTexture.AlphaFormat = 12;\nTexture.RgbFormat = 13;\n\nTexture.defaultOptions = {\n    magFilter: Texture.LinearFilter,\n    minFilter: Texture.LinearMipMapLinearFilter,\n    wrapS: Texture.ClampToEdgeWrapping,\n    wrapT: Texture.ClampToEdgeWrapping,\n    format: Texture.RgbaFormat,\n    generateMipmaps: true,\n    flipY: true,\n    premultiplyAlpha: true,\n};\n\nexport default Texture;\n\n/**\n * @typedef {Texture.NearestFilter | Texture.NearestMipMapNearestFilter |\n * Texture.NearestMipMapLinearFilter | Texture.LinearFilter |\n * Texture.LinearMipMapNearestFilter | Texture.LinearMipMapLinearFilter} TextureFilter\n */\n\n/**\n * @typedef {Texture.ClampToEdgeWrapping} TextureClamp\n */\n\n/**\n * @typedef {Texture.RgbaFormat | Texture.AlphaFormat} TextureFormat\n */\n\n/**\n * Параметры связывания текстуры\n *\n * @typedef {Object} TextureOptions\n * @property {TextureFilter} magFilter\n * @property {TextureFilter} minFilter\n * @property {TextureClamp} wrapS\n * @property {TextureClamp} wrapT\n * @property {TextureFormat} format\n * @property {Boolean} generateMipmaps\n * @property {Boolean} flipY\n * @property {Boolean} premultiplyAlpha\n * @property {?Number[]} size\n * @property {?Number} unit\n */\n"]}

@@ -45,10 +45,6 @@ /**

* стандартный подход для связывания атрибутов через {@link ShaderProgram#bind}.
*
* @param {State} state Стейт рендерера
*/
unbind(state) {
const ext = state.extensions.OES_vertex_array_object;
if (ext) {
ext.bindVertexArrayOES(null);
unbind() {
if (this._ext) {
this._ext.bindVertexArrayOES(null);
}

@@ -99,2 +95,2 @@

export default Vao;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9WYW8uanMiXSwibmFtZXMiOlsiVmFvIiwiY29uc3RydWN0b3IiLCJzaGFkZXJQcm9ncmFtIiwiYXR0cmlidXRlcyIsIl92YW8iLCJfYXR0cmlidXRlcyIsIl9zaGFkZXJQcm9ncmFtIiwiX2V4dCIsImJpbmQiLCJzdGF0ZSIsImV4dCIsImV4dGVuc2lvbnMiLCJPRVNfdmVydGV4X2FycmF5X29iamVjdCIsIl9iaW5kIiwiZ2wiLCJ1bmJpbmQiLCJiaW5kVmVydGV4QXJyYXlPRVMiLCJyZW1vdmUiLCJkZWxldGVWZXJ0ZXhBcnJheU9FUyIsIl9wcmVwYXJlIiwiY3JlYXRlVmVydGV4QXJyYXlPRVMiLCJzaGFkZXJBdHRyaWJ1dGVzIiwibmFtZSIsInNoYWRlckF0dHJpYnV0ZSIsImluZGV4IiwiZW5hYmxlVmVydGV4QXR0cmliQXJyYXkiLCJsb2NhdGlvbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7OztBQVNBLE1BQU1BLEdBQU4sQ0FBVTtBQUNOQyxnQkFBWUMsYUFBWixFQUEyQkMsYUFBYSxFQUF4QyxFQUE0QztBQUN4QyxhQUFLQyxJQUFMLEdBQVksSUFBWjtBQUNBLGFBQUtDLFdBQUwsR0FBbUJGLFVBQW5CO0FBQ0EsYUFBS0csY0FBTCxHQUFzQkosYUFBdEI7O0FBRUE7Ozs7QUFJQSxhQUFLSyxJQUFMLEdBQVksSUFBWjtBQUNIOztBQUVEOzs7OztBQUtBQyxTQUFLQyxLQUFMLEVBQVk7QUFDUixjQUFNQyxNQUFNRCxNQUFNRSxVQUFOLENBQWlCQyx1QkFBN0I7O0FBRUEsWUFBSUYsR0FBSixFQUFTO0FBQ0wsaUJBQUtHLEtBQUwsQ0FBV0osTUFBTUssRUFBakIsRUFBcUJKLEdBQXJCO0FBQ0gsU0FGRCxNQUVPO0FBQ0g7QUFDQSxpQkFBS0osY0FBTCxDQUFvQkUsSUFBcEIsQ0FBeUJDLE1BQU1LLEVBQS9CLEVBQW1DLElBQW5DLEVBQXlDLEtBQUtULFdBQTlDO0FBQ0g7O0FBRUQsZUFBTyxJQUFQO0FBQ0g7O0FBRUQ7Ozs7Ozs7QUFPQVUsV0FBT04sS0FBUCxFQUFjO0FBQ1YsY0FBTUMsTUFBTUQsTUFBTUUsVUFBTixDQUFpQkMsdUJBQTdCOztBQUVBLFlBQUlGLEdBQUosRUFBUztBQUNMQSxnQkFBSU0sa0JBQUosQ0FBdUIsSUFBdkI7QUFDSDs7QUFFRCxlQUFPLElBQVA7QUFDSDs7QUFFRDs7O0FBR0FDLGFBQVM7QUFDTCxZQUFJLEtBQUtiLElBQVQsRUFBZTtBQUNYLGlCQUFLRyxJQUFMLENBQVVXLG9CQUFWLENBQStCLEtBQUtkLElBQXBDO0FBQ0g7O0FBRUQsZUFBTyxJQUFQO0FBQ0g7O0FBRURTLFVBQU1DLEVBQU4sRUFBVUosR0FBVixFQUFlO0FBQ1gsWUFBSSxDQUFDLEtBQUtOLElBQVYsRUFBZ0I7QUFDWixpQkFBS2UsUUFBTCxDQUFjTCxFQUFkLEVBQWtCSixHQUFsQjtBQUNILFNBRkQsTUFFTztBQUNIQSxnQkFBSU0sa0JBQUosQ0FBdUIsS0FBS1osSUFBNUI7QUFDSDtBQUNKOztBQUVEZSxhQUFTTCxFQUFULEVBQWFKLEdBQWIsRUFBa0I7QUFDZCxhQUFLSCxJQUFMLEdBQVlHLEdBQVo7QUFDQSxhQUFLTixJQUFMLEdBQVlNLElBQUlVLG9CQUFKLEVBQVo7O0FBRUFWLFlBQUlNLGtCQUFKLENBQXVCLEtBQUtaLElBQTVCOztBQUVBLGNBQU1pQixtQkFBbUIsS0FBS2YsY0FBTCxDQUFvQkgsVUFBN0M7QUFDQSxjQUFNQSxhQUFhLEtBQUtFLFdBQXhCOztBQUVBO0FBQ0EsYUFBSyxNQUFNaUIsSUFBWCxJQUFtQm5CLFVBQW5CLEVBQStCO0FBQzNCLGtCQUFNb0Isa0JBQWtCRixpQkFBaUJDLElBQWpCLENBQXhCO0FBQ0EsZ0JBQUlDLGdCQUFnQkMsS0FBaEIsS0FBMEIsSUFBOUIsRUFBb0M7QUFDaENWLG1CQUFHVyx1QkFBSCxDQUEyQkYsZ0JBQWdCRyxRQUEzQztBQUNIO0FBQ0R2Qix1QkFBV21CLElBQVgsRUFBaUJkLElBQWpCLENBQXNCTSxFQUF0QixFQUEwQlMsZ0JBQWdCRyxRQUExQztBQUNIO0FBQ0o7QUFwRks7O0FBdUZWLGVBQWUxQixHQUFmIiwiZmlsZSI6IlZhby5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICog0J7QsdC10YDRgtC60LAg0L3QsNC0IHZlcnRleCBhcnJheSBvYmplY3QuXG4gKiBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9ydS9kb2NzL1dlYi9BUEkvT0VTX3ZlcnRleF9hcnJheV9vYmplY3RcbiAqXG4gKiDQlNC70Y8g0LjRgdC/0L7Qu9GM0LfQvtCy0LDQvdC40Y8g0L3QtdC+0LHRhdC+0LTQuNC80L4g0LLQutC70Y7Rh9C40YLRjCDRgNCw0YHRiNC40YDQtdC90LjQtSByZW5kZXJlci5hZGRFeHRlbnNpb24oJ09FU192ZXJ0ZXhfYXJyYXlfb2JqZWN0JylcbiAqXG4gKiBAcGFyYW0ge1NoYWRlclByb2dyYW19INCo0LXQudC00LXRgNC90LDRjyDQv9GA0L7Qs9GA0LDQvNC80LAsINC60LDQttC00YvQuSBWYW8g0L/RgNC40LLRj9C30LDQvSDQuiDQvtC00L3QvtC5INGI0LXQudC00LXRgNC90L7QuSDQv9GA0L7Qs9GA0LDQvNC80LUuXG4gKiBAcGFyYW0ge09iamVjdH0gS2V5LXZhbHVlINC+0LHRitC10LrRgiDRgdC+0LTQtdGA0LbQsNGJ0LjQuSDQtNCw0L3QvdGL0LUg0LDRgtGA0LjQsdGD0YLQvtCyLlxuICovXG5jbGFzcyBWYW8ge1xuICAgIGNvbnN0cnVjdG9yKHNoYWRlclByb2dyYW0sIGF0dHJpYnV0ZXMgPSB7fSkge1xuICAgICAgICB0aGlzLl92YW8gPSBudWxsO1xuICAgICAgICB0aGlzLl9hdHRyaWJ1dGVzID0gYXR0cmlidXRlcztcbiAgICAgICAgdGhpcy5fc2hhZGVyUHJvZ3JhbSA9IHNoYWRlclByb2dyYW07XG5cbiAgICAgICAgLyoqXG4gICAgICAgICAqIFdlYkdMINGN0LrRgdGC0LXQvdGI0LXQvSwg0LIg0LrQvtGC0L7RgNC+0Lwg0LHRi9C7INC40L3QuNGG0LjQsNC70LjQt9C40YDQvtCy0LDQvSDQsdGD0YTQtdGALlxuICAgICAgICAgKiDQmNGB0L/QvtC70YzQt9GD0LXRgtGB0Y8g0YLQvtC70YzQutC+INC00LvRjyDRg9C00LDQu9C10L3QuNGPIHZhbywg0L/QvtC00YPQvNCw0YLRjCDRhdC+0YDQvtGI0L4sINC/0YDQtdC20LTQtSDRh9C10Lwg0LjRgdC/0L7Qu9GM0LfQvtCy0LDRgtGMINC00LvRjyDRh9C10LPQvi3RgtC+INC10YnRkS5cbiAgICAgICAgICovXG4gICAgICAgIHRoaXMuX2V4dCA9IG51bGw7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICog0KHQstGP0LfRi9Cy0LDQtdGCIHZhbyDRgSDQutC+0L3RgtC10LrRgdGC0L7QvCBXZWJHTC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSB7U3RhdGV9INCh0YLQtdC50YIg0YDQtdC90LTQtdGA0LBcbiAgICAgKi9cbiAgICBiaW5kKHN0YXRlKSB7XG4gICAgICAgIGNvbnN0IGV4dCA9IHN0YXRlLmV4dGVuc2lvbnMuT0VTX3ZlcnRleF9hcnJheV9vYmplY3Q7XG5cbiAgICAgICAgaWYgKGV4dCkge1xuICAgICAgICAgICAgdGhpcy5fYmluZChzdGF0ZS5nbCwgZXh0KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIC8vINCSINGB0LvRg9GH0LDQtSDRhNC+0LvQu9Cx0LXQutCwIC0g0LHQuNC90LTQuNC8INCw0YLRgNC40LHRg9GC0Ysg0L/RgNGP0LzQviDQuNC3INGI0LXQudC00LXRgNC90L7QuSDQv9GA0L7Qs9GA0LDQvNC80YtcbiAgICAgICAgICAgIHRoaXMuX3NoYWRlclByb2dyYW0uYmluZChzdGF0ZS5nbCwgbnVsbCwgdGhpcy5fYXR0cmlidXRlcyk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiDQntGC0LLRj9C30YvQstCw0LXRgiB2YW8g0L7RgiDQutC+0L3RgtC10LrRgdGC0LAgV2ViR0wuXG4gICAgICog0JLQndCY0JzQkNCd0JjQlTog0K3RgtC+0YIg0LzQtdGC0L7QtCDQvdGD0LbQvdC+INCy0YvQt9GL0LLQsNGC0Ywg0LLRgdC10LPQtNCwLCDQv9C10YDQtdC0INGC0LXQvCDQutCw0Log0LHRg9C00LXRgiDQuNGB0L/QvtC70YzQt9C+0LLQsNGC0YzRgdGPXG4gICAgICog0YHRgtCw0L3QtNCw0YDRgtC90YvQuSDQv9C+0LTRhdC+0LQg0LTQu9GPINGB0LLRj9C30YvQstCw0L3QuNGPINCw0YLRgNC40LHRg9GC0L7QsiDRh9C10YDQtdC3IHtAbGluayBTaGFkZXJQcm9ncmFtI2JpbmR9LlxuICAgICAqXG4gICAgICogQHBhcmFtIHtTdGF0ZX0gc3RhdGUg0KHRgtC10LnRgiDRgNC10L3QtNC10YDQtdGA0LBcbiAgICAgKi9cbiAgICB1bmJpbmQoc3RhdGUpIHtcbiAgICAgICAgY29uc3QgZXh0ID0gc3RhdGUuZXh0ZW5zaW9ucy5PRVNfdmVydGV4X2FycmF5X29iamVjdDtcblxuICAgICAgICBpZiAoZXh0KSB7XG4gICAgICAgICAgICBleHQuYmluZFZlcnRleEFycmF5T0VTKG51bGwpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICog0KPQtNCw0LvRj9C10YIgdmFvLlxuICAgICAqL1xuICAgIHJlbW92ZSgpIHtcbiAgICAgICAgaWYgKHRoaXMuX3Zhbykge1xuICAgICAgICAgICAgdGhpcy5fZXh0LmRlbGV0ZVZlcnRleEFycmF5T0VTKHRoaXMuX3Zhbyk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBfYmluZChnbCwgZXh0KSB7XG4gICAgICAgIGlmICghdGhpcy5fdmFvKSB7XG4gICAgICAgICAgICB0aGlzLl9wcmVwYXJlKGdsLCBleHQpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZXh0LmJpbmRWZXJ0ZXhBcnJheU9FUyh0aGlzLl92YW8pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgX3ByZXBhcmUoZ2wsIGV4dCkge1xuICAgICAgICB0aGlzLl9leHQgPSBleHQ7XG4gICAgICAgIHRoaXMuX3ZhbyA9IGV4dC5jcmVhdGVWZXJ0ZXhBcnJheU9FUygpO1xuXG4gICAgICAgIGV4dC5iaW5kVmVydGV4QXJyYXlPRVModGhpcy5fdmFvKTtcblxuICAgICAgICBjb25zdCBzaGFkZXJBdHRyaWJ1dGVzID0gdGhpcy5fc2hhZGVyUHJvZ3JhbS5hdHRyaWJ1dGVzO1xuICAgICAgICBjb25zdCBhdHRyaWJ1dGVzID0gdGhpcy5fYXR0cmlidXRlcztcblxuICAgICAgICAvLyDQkdC40L3QtNC40Lwg0LDRgtGA0LjQsdGD0YLRiyDQv9C10YDQtdC00LDQvdC90YvQtSDQsiDQutC+0L3RgdGC0YDRg9C60YLQvtGALCDQuNGFINC/0LDRgNCw0LzQtdGC0YDRiyDQsdC10YDRkdC8INC40Lcg0YjQtdC50LTQtdGA0L3QvtC5INC/0YDQvtCz0YDQsNC80LzRi1xuICAgICAgICBmb3IgKGNvbnN0IG5hbWUgaW4gYXR0cmlidXRlcykge1xuICAgICAgICAgICAgY29uc3Qgc2hhZGVyQXR0cmlidXRlID0gc2hhZGVyQXR0cmlidXRlc1tuYW1lXTtcbiAgICAgICAgICAgIGlmIChzaGFkZXJBdHRyaWJ1dGUuaW5kZXggIT09IHRydWUpIHtcbiAgICAgICAgICAgICAgICBnbC5lbmFibGVWZXJ0ZXhBdHRyaWJBcnJheShzaGFkZXJBdHRyaWJ1dGUubG9jYXRpb24pO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgYXR0cmlidXRlc1tuYW1lXS5iaW5kKGdsLCBzaGFkZXJBdHRyaWJ1dGUubG9jYXRpb24pO1xuICAgICAgICB9XG4gICAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBWYW87XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9WYW8uanMiXSwibmFtZXMiOlsiVmFvIiwiY29uc3RydWN0b3IiLCJzaGFkZXJQcm9ncmFtIiwiYXR0cmlidXRlcyIsIl92YW8iLCJfYXR0cmlidXRlcyIsIl9zaGFkZXJQcm9ncmFtIiwiX2V4dCIsImJpbmQiLCJzdGF0ZSIsImV4dCIsImV4dGVuc2lvbnMiLCJPRVNfdmVydGV4X2FycmF5X29iamVjdCIsIl9iaW5kIiwiZ2wiLCJ1bmJpbmQiLCJiaW5kVmVydGV4QXJyYXlPRVMiLCJyZW1vdmUiLCJkZWxldGVWZXJ0ZXhBcnJheU9FUyIsIl9wcmVwYXJlIiwiY3JlYXRlVmVydGV4QXJyYXlPRVMiLCJzaGFkZXJBdHRyaWJ1dGVzIiwibmFtZSIsInNoYWRlckF0dHJpYnV0ZSIsImluZGV4IiwiZW5hYmxlVmVydGV4QXR0cmliQXJyYXkiLCJsb2NhdGlvbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7OztBQVNBLE1BQU1BLEdBQU4sQ0FBVTtBQUNOQyxnQkFBWUMsYUFBWixFQUEyQkMsYUFBYSxFQUF4QyxFQUE0QztBQUN4QyxhQUFLQyxJQUFMLEdBQVksSUFBWjtBQUNBLGFBQUtDLFdBQUwsR0FBbUJGLFVBQW5CO0FBQ0EsYUFBS0csY0FBTCxHQUFzQkosYUFBdEI7O0FBRUE7Ozs7QUFJQSxhQUFLSyxJQUFMLEdBQVksSUFBWjtBQUNIOztBQUVEOzs7OztBQUtBQyxTQUFLQyxLQUFMLEVBQVk7QUFDUixjQUFNQyxNQUFNRCxNQUFNRSxVQUFOLENBQWlCQyx1QkFBN0I7O0FBRUEsWUFBSUYsR0FBSixFQUFTO0FBQ0wsaUJBQUtHLEtBQUwsQ0FBV0osTUFBTUssRUFBakIsRUFBcUJKLEdBQXJCO0FBQ0gsU0FGRCxNQUVPO0FBQ0g7QUFDQSxpQkFBS0osY0FBTCxDQUFvQkUsSUFBcEIsQ0FBeUJDLE1BQU1LLEVBQS9CLEVBQW1DLElBQW5DLEVBQXlDLEtBQUtULFdBQTlDO0FBQ0g7O0FBRUQsZUFBTyxJQUFQO0FBQ0g7O0FBRUQ7Ozs7O0FBS0FVLGFBQVM7QUFDTCxZQUFJLEtBQUtSLElBQVQsRUFBZTtBQUNYLGlCQUFLQSxJQUFMLENBQVVTLGtCQUFWLENBQTZCLElBQTdCO0FBQ0g7O0FBRUQsZUFBTyxJQUFQO0FBQ0g7O0FBRUQ7OztBQUdBQyxhQUFTO0FBQ0wsWUFBSSxLQUFLYixJQUFULEVBQWU7QUFDWCxpQkFBS0csSUFBTCxDQUFVVyxvQkFBVixDQUErQixLQUFLZCxJQUFwQztBQUNIOztBQUVELGVBQU8sSUFBUDtBQUNIOztBQUVEUyxVQUFNQyxFQUFOLEVBQVVKLEdBQVYsRUFBZTtBQUNYLFlBQUksQ0FBQyxLQUFLTixJQUFWLEVBQWdCO0FBQ1osaUJBQUtlLFFBQUwsQ0FBY0wsRUFBZCxFQUFrQkosR0FBbEI7QUFDSCxTQUZELE1BRU87QUFDSEEsZ0JBQUlNLGtCQUFKLENBQXVCLEtBQUtaLElBQTVCO0FBQ0g7QUFDSjs7QUFFRGUsYUFBU0wsRUFBVCxFQUFhSixHQUFiLEVBQWtCO0FBQ2QsYUFBS0gsSUFBTCxHQUFZRyxHQUFaO0FBQ0EsYUFBS04sSUFBTCxHQUFZTSxJQUFJVSxvQkFBSixFQUFaOztBQUVBVixZQUFJTSxrQkFBSixDQUF1QixLQUFLWixJQUE1Qjs7QUFFQSxjQUFNaUIsbUJBQW1CLEtBQUtmLGNBQUwsQ0FBb0JILFVBQTdDO0FBQ0EsY0FBTUEsYUFBYSxLQUFLRSxXQUF4Qjs7QUFFQTtBQUNBLGFBQUssTUFBTWlCLElBQVgsSUFBbUJuQixVQUFuQixFQUErQjtBQUMzQixrQkFBTW9CLGtCQUFrQkYsaUJBQWlCQyxJQUFqQixDQUF4QjtBQUNBLGdCQUFJQyxnQkFBZ0JDLEtBQWhCLEtBQTBCLElBQTlCLEVBQW9DO0FBQ2hDVixtQkFBR1csdUJBQUgsQ0FBMkJGLGdCQUFnQkcsUUFBM0M7QUFDSDtBQUNEdkIsdUJBQVdtQixJQUFYLEVBQWlCZCxJQUFqQixDQUFzQk0sRUFBdEIsRUFBMEJTLGdCQUFnQkcsUUFBMUM7QUFDSDtBQUNKO0FBaEZLOztBQW1GVixlQUFlMUIsR0FBZiIsImZpbGUiOiJWYW8uanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqINCe0LHQtdGA0YLQutCwINC90LDQtCB2ZXJ0ZXggYXJyYXkgb2JqZWN0LlxuICogaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvcnUvZG9jcy9XZWIvQVBJL09FU192ZXJ0ZXhfYXJyYXlfb2JqZWN0XG4gKlxuICog0JTQu9GPINC40YHQv9C+0LvRjNC30L7QstCw0L3QuNGPINC90LXQvtCx0YXQvtC00LjQvNC+INCy0LrQu9GO0YfQuNGC0Ywg0YDQsNGB0YjQuNGA0LXQvdC40LUgcmVuZGVyZXIuYWRkRXh0ZW5zaW9uKCdPRVNfdmVydGV4X2FycmF5X29iamVjdCcpXG4gKlxuICogQHBhcmFtIHtTaGFkZXJQcm9ncmFtfSDQqNC10LnQtNC10YDQvdCw0Y8g0L/RgNC+0LPRgNCw0LzQvNCwLCDQutCw0LbQtNGL0LkgVmFvINC/0YDQuNCy0Y/Qt9Cw0L0g0Log0L7QtNC90L7QuSDRiNC10LnQtNC10YDQvdC+0Lkg0L/RgNC+0LPRgNCw0LzQvNC1LlxuICogQHBhcmFtIHtPYmplY3R9IEtleS12YWx1ZSDQvtCx0YrQtdC60YIg0YHQvtC00LXRgNC20LDRidC40Lkg0LTQsNC90L3Ri9C1INCw0YLRgNC40LHRg9GC0L7Qsi5cbiAqL1xuY2xhc3MgVmFvIHtcbiAgICBjb25zdHJ1Y3RvcihzaGFkZXJQcm9ncmFtLCBhdHRyaWJ1dGVzID0ge30pIHtcbiAgICAgICAgdGhpcy5fdmFvID0gbnVsbDtcbiAgICAgICAgdGhpcy5fYXR0cmlidXRlcyA9IGF0dHJpYnV0ZXM7XG4gICAgICAgIHRoaXMuX3NoYWRlclByb2dyYW0gPSBzaGFkZXJQcm9ncmFtO1xuXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBXZWJHTCDRjdC60YHRgtC10L3RiNC10L0sINCyINC60L7RgtC+0YDQvtC8INCx0YvQuyDQuNC90LjRhtC40LDQu9C40LfQuNGA0L7QstCw0L0g0LHRg9GE0LXRgC5cbiAgICAgICAgICog0JjRgdC/0L7Qu9GM0LfRg9C10YLRgdGPINGC0L7Qu9GM0LrQviDQtNC70Y8g0YPQtNCw0LvQtdC90LjRjyB2YW8sINC/0L7QtNGD0LzQsNGC0Ywg0YXQvtGA0L7RiNC+LCDQv9GA0LXQttC00LUg0YfQtdC8INC40YHQv9C+0LvRjNC30L7QstCw0YLRjCDQtNC70Y8g0YfQtdCz0L4t0YLQviDQtdGJ0ZEuXG4gICAgICAgICAqL1xuICAgICAgICB0aGlzLl9leHQgPSBudWxsO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqINCh0LLRj9C30YvQstCw0LXRgiB2YW8g0YEg0LrQvtC90YLQtdC60YHRgtC+0LwgV2ViR0wuXG4gICAgICpcbiAgICAgKiBAcGFyYW0ge1N0YXRlfSDQodGC0LXQudGCINGA0LXQvdC00LXRgNCwXG4gICAgICovXG4gICAgYmluZChzdGF0ZSkge1xuICAgICAgICBjb25zdCBleHQgPSBzdGF0ZS5leHRlbnNpb25zLk9FU192ZXJ0ZXhfYXJyYXlfb2JqZWN0O1xuXG4gICAgICAgIGlmIChleHQpIHtcbiAgICAgICAgICAgIHRoaXMuX2JpbmQoc3RhdGUuZ2wsIGV4dCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAvLyDQkiDRgdC70YPRh9Cw0LUg0YTQvtC70LvQsdC10LrQsCAtINCx0LjQvdC00LjQvCDQsNGC0YDQuNCx0YPRgtGLINC/0YDRj9C80L4g0LjQtyDRiNC10LnQtNC10YDQvdC+0Lkg0L/RgNC+0LPRgNCw0LzQvNGLXG4gICAgICAgICAgICB0aGlzLl9zaGFkZXJQcm9ncmFtLmJpbmQoc3RhdGUuZ2wsIG51bGwsIHRoaXMuX2F0dHJpYnV0ZXMpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICog0J7RgtCy0Y/Qt9GL0LLQsNC10YIgdmFvINC+0YIg0LrQvtC90YLQtdC60YHRgtCwIFdlYkdMLlxuICAgICAqINCS0J3QmNCc0JDQndCY0JU6INCt0YLQvtGCINC80LXRgtC+0LQg0L3Rg9C20L3QviDQstGL0LfRi9Cy0LDRgtGMINCy0YHQtdCz0LTQsCwg0L/QtdGA0LXQtCDRgtC10Lwg0LrQsNC6INCx0YPQtNC10YIg0LjRgdC/0L7Qu9GM0LfQvtCy0LDRgtGM0YHRj1xuICAgICAqINGB0YLQsNC90LTQsNGA0YLQvdGL0Lkg0L/QvtC00YXQvtC0INC00LvRjyDRgdCy0Y/Qt9GL0LLQsNC90LjRjyDQsNGC0YDQuNCx0YPRgtC+0LIg0YfQtdGA0LXQtyB7QGxpbmsgU2hhZGVyUHJvZ3JhbSNiaW5kfS5cbiAgICAgKi9cbiAgICB1bmJpbmQoKSB7XG4gICAgICAgIGlmICh0aGlzLl9leHQpIHtcbiAgICAgICAgICAgIHRoaXMuX2V4dC5iaW5kVmVydGV4QXJyYXlPRVMobnVsbCk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiDQo9C00LDQu9GP0LXRgiB2YW8uXG4gICAgICovXG4gICAgcmVtb3ZlKCkge1xuICAgICAgICBpZiAodGhpcy5fdmFvKSB7XG4gICAgICAgICAgICB0aGlzLl9leHQuZGVsZXRlVmVydGV4QXJyYXlPRVModGhpcy5fdmFvKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIF9iaW5kKGdsLCBleHQpIHtcbiAgICAgICAgaWYgKCF0aGlzLl92YW8pIHtcbiAgICAgICAgICAgIHRoaXMuX3ByZXBhcmUoZ2wsIGV4dCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBleHQuYmluZFZlcnRleEFycmF5T0VTKHRoaXMuX3Zhbyk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBfcHJlcGFyZShnbCwgZXh0KSB7XG4gICAgICAgIHRoaXMuX2V4dCA9IGV4dDtcbiAgICAgICAgdGhpcy5fdmFvID0gZXh0LmNyZWF0ZVZlcnRleEFycmF5T0VTKCk7XG5cbiAgICAgICAgZXh0LmJpbmRWZXJ0ZXhBcnJheU9FUyh0aGlzLl92YW8pO1xuXG4gICAgICAgIGNvbnN0IHNoYWRlckF0dHJpYnV0ZXMgPSB0aGlzLl9zaGFkZXJQcm9ncmFtLmF0dHJpYnV0ZXM7XG4gICAgICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSB0aGlzLl9hdHRyaWJ1dGVzO1xuXG4gICAgICAgIC8vINCR0LjQvdC00LjQvCDQsNGC0YDQuNCx0YPRgtGLINC/0LXRgNC10LTQsNC90L3Ri9C1INCyINC60L7QvdGB0YLRgNGD0LrRgtC+0YAsINC40YUg0L/QsNGA0LDQvNC10YLRgNGLINCx0LXRgNGR0Lwg0LjQtyDRiNC10LnQtNC10YDQvdC+0Lkg0L/RgNC+0LPRgNCw0LzQvNGLXG4gICAgICAgIGZvciAoY29uc3QgbmFtZSBpbiBhdHRyaWJ1dGVzKSB7XG4gICAgICAgICAgICBjb25zdCBzaGFkZXJBdHRyaWJ1dGUgPSBzaGFkZXJBdHRyaWJ1dGVzW25hbWVdO1xuICAgICAgICAgICAgaWYgKHNoYWRlckF0dHJpYnV0ZS5pbmRleCAhPT0gdHJ1ZSkge1xuICAgICAgICAgICAgICAgIGdsLmVuYWJsZVZlcnRleEF0dHJpYkFycmF5KHNoYWRlckF0dHJpYnV0ZS5sb2NhdGlvbik7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBhdHRyaWJ1dGVzW25hbWVdLmJpbmQoZ2wsIHNoYWRlckF0dHJpYnV0ZS5sb2NhdGlvbik7XG4gICAgICAgIH1cbiAgICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IFZhbztcbiJdfQ==

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc