From 00446473ee2281b0b65d922b837c145b5631095d Mon Sep 17 00:00:00 2001 From: Tom Peffer Date: Sat, 7 Mar 2020 18:04:17 +0100 Subject: [PATCH] Fixed missing "border" parameter in TexImage2D & TexImage2DAsync (WebGLContext) --- src/Blazor.Extensions.Canvas/WebGL/WebGLContext.cs | 8 ++++---- .../wwwroot/blazor.extensions.canvas.js | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/Blazor.Extensions.Canvas/WebGL/WebGLContext.cs b/src/Blazor.Extensions.Canvas/WebGL/WebGLContext.cs index af290b2..0f90cd5 100644 --- a/src/Blazor.Extensions.Canvas/WebGL/WebGLContext.cs +++ b/src/Blazor.Extensions.Canvas/WebGL/WebGLContext.cs @@ -405,12 +405,12 @@ protected override async Task ExtendedInitializeAsync() public async Task IsTextureAsync(WebGLTexture texture) => await this.CallMethodAsync(IS_TEXTURE, texture); [Obsolete("Use the async version instead, which is already called internally.")] - public void TexImage2D(Texture2DType target, int level, PixelFormat internalFormat, int width, int height, PixelFormat format, PixelType type, T[] pixels) + public void TexImage2D(Texture2DType target, int level, PixelFormat internalFormat, int width, int height, int border, PixelFormat format, PixelType type, T[] pixels) where T : struct - => this.CallMethod(TEX_IMAGE_2D, target, level, internalFormat, width, height, format, type, pixels); - public async Task TexImage2DAsync(Texture2DType target, int level, PixelFormat internalFormat, int width, int height, PixelFormat format, PixelType type, T[] pixels) + => this.CallMethod(TEX_IMAGE_2D, target, level, internalFormat, width, height, border, format, type, pixels); + public async Task TexImage2DAsync(Texture2DType target, int level, PixelFormat internalFormat, int width, int height, int border, PixelFormat format, PixelType type, T[] pixels) where T : struct - => await this.BatchCallAsync(TEX_IMAGE_2D, isMethodCall: true, target, level, internalFormat, width, height, format, type, pixels); + => await this.BatchCallAsync(TEX_IMAGE_2D, isMethodCall: true, target, level, internalFormat, width, height, border, format, type, pixels); [Obsolete("Use the async version instead, which is already called internally.")] public void TexSubImage2D(Texture2DType target, int level, int xoffset, int yoffset, int width, int height, PixelFormat format, PixelType type, T[] pixels) diff --git a/src/Blazor.Extensions.Canvas/wwwroot/blazor.extensions.canvas.js b/src/Blazor.Extensions.Canvas/wwwroot/blazor.extensions.canvas.js index 7a02dc8..3114927 100644 --- a/src/Blazor.Extensions.Canvas/wwwroot/blazor.extensions.canvas.js +++ b/src/Blazor.Extensions.Canvas/wwwroot/blazor.extensions.canvas.js @@ -1,2 +1,2 @@ !function(t){var e={};function n(r){if(e[r])return e[r].exports;var i=e[r]={i:r,l:!1,exports:{}};return t[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var i in t)n.d(r,i,function(e){return t[e]}.bind(null,i));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=0)}([function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});const r=n(1);var i;!function(t){const e="BlazorExtensions",n={Canvas2d:new r.ContextManager("2d"),WebGL:new r.ContextManager("webgl")};t.initialize=function(){"undefined"==typeof window||window[e]?window[e]=Object.assign({},window[e],n):window[e]=Object.assign({},n)}}(i||(i={})),i.initialize()},function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});e.ContextManager=class{constructor(t){if(this.contexts=new Map,this.webGLObject=new Array,this.webGLContext=!1,this.webGLTypes=[WebGLBuffer,WebGLShader,WebGLProgram,WebGLFramebuffer,WebGLRenderbuffer,WebGLTexture,WebGLUniformLocation],this.add=((t,e)=>{if(!t)throw new Error("Invalid canvas.");if(!this.contexts.get(t.id)){var n;if(!(n=e?t.getContext(this.contextName,e):t.getContext(this.contextName)))throw new Error("Invalid context.");this.contexts.set(t.id,n)}}),this.remove=(t=>{this.contexts.delete(t.id)}),this.setProperty=((t,e,n)=>{const r=this.getContext(t);this.setPropertyWithContext(r,e,n)}),this.getProperty=((t,e)=>{const n=this.getContext(t);return this.serialize(n[e])}),this.call=((t,e,n)=>{const r=this.getContext(t);return this.callWithContext(r,e,n)}),this.callBatch=((t,e)=>{const n=this.getContext(t);for(let t=0;t0?r[0]:null)}}),this.callWithContext=((t,e,n)=>this.serialize(this.prototypes[e].apply(t,void 0!=n?n.map(t=>this.deserialize(e,t)):[]))),this.setPropertyWithContext=((t,e,n)=>{t[e]=this.deserialize(e,n)}),this.getContext=(t=>{if(!t)throw new Error("Invalid canvas.");const e=this.contexts.get(t.id);if(!e)throw new Error("Invalid context.");return e}),this.deserialize=((t,e)=>{if(!this.webGLContext||void 0==e)return e;if(e.hasOwnProperty("webGLType")&&e.hasOwnProperty("id"))return this.webGLObject[e.id];if(Array.isArray(e)&&!t.endsWith("v"))return Int8Array.of(...e);if("string"!=typeof e||"bufferData"!==t&&"bufferSubData"!==t)return e;{let t=window.atob(e),r=t.length,i=new Uint8Array(r);for(var n=0;n{if(t instanceof TextMetrics)return{width:t.width};if(!this.webGLContext||void 0==t)return t;const e=this.webGLTypes.find(e=>t instanceof e);if(void 0!=e){const n=this.webGLObject.length;return this.webGLObject.push(t),{webGLType:e.name,id:n}}return t}),this.contextName=t,"2d"===t)this.prototypes=CanvasRenderingContext2D.prototype;else{if("webgl"!==t&&"experimental-webgl"!==t)throw new Error(`Invalid context name: ${t}`);this.prototypes=WebGLRenderingContext.prototype,this.webGLContext=!0}}}}]); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./src/InitializeCanvas.ts","webpack:///./src/CanvasContextManager.ts"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","CanvasContextManager_1","Canvas","blazorExtensions","extensionObject","Canvas2d","ContextManager","WebGL","initialize","window","assign","[object Object]","contextName","this","contexts","Map","webGLObject","Array","webGLContext","webGLTypes","WebGLBuffer","WebGLShader","WebGLProgram","WebGLFramebuffer","WebGLRenderbuffer","WebGLTexture","WebGLUniformLocation","add","canvas","parameters","Error","id","context","getContext","set","remove","delete","setProperty","setPropertyWithContext","getProperty","serialize","method","args","callWithContext","callBatch","batchedCalls","length","params","slice","isArray","prototypes","apply","undefined","map","deserialize","endsWith","Int8Array","of","binStr","atob","bytes","Uint8Array","charCodeAt","TextMetrics","width","type","find","push","webGLType","CanvasRenderingContext2D","WebGLRenderingContext"],"mappings":"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","file":"blazor.extensions.canvas.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","import { ContextManager } from './CanvasContextManager';\n\nnamespace Canvas {\n  const blazorExtensions: string = 'BlazorExtensions';\n  // define what this extension adds to the window object inside BlazorExtensions\n  const extensionObject = {\n    Canvas2d: new ContextManager(\"2d\"),\n    WebGL: new ContextManager(\"webgl\")\n  };\n\n  export function initialize(): void {\n    if (typeof window !== 'undefined' && !window[blazorExtensions]) {\n      // when the library is loaded in a browser via a <script> element, make the\n      // following APIs available in global scope for invocation from JS\n      window[blazorExtensions] = {\n        ...extensionObject\n      };\n    } else {\n      window[blazorExtensions] = {\n        ...window[blazorExtensions],\n        ...extensionObject\n      };\n    }\n  }\n}\n\nCanvas.initialize();\n","export class ContextManager {\n  private readonly contexts = new Map<string, any>();\n  private readonly webGLObject = new Array<any>();\n  private readonly contextName: string;\n  private webGLContext = false;\n  private readonly prototypes: any;\n  private readonly webGLTypes = [\n    WebGLBuffer, WebGLShader, WebGLProgram, WebGLFramebuffer, WebGLRenderbuffer, WebGLTexture, WebGLUniformLocation\n  ];\n\n  public constructor(contextName: string) {\n    this.contextName = contextName;\n    if (contextName === \"2d\")\n      this.prototypes = CanvasRenderingContext2D.prototype;\n    else if (contextName === \"webgl\" || contextName === \"experimental-webgl\") {\n      this.prototypes = WebGLRenderingContext.prototype;\n      this.webGLContext = true;\n    } else\n      throw new Error(`Invalid context name: ${contextName}`);\n  }\n\n  public add = (canvas: HTMLCanvasElement, parameters: any) => {\n    if (!canvas) throw new Error('Invalid canvas.');\n    if (this.contexts.get(canvas.id)) return;\n\n    var context;\n    if (parameters)\n      context = canvas.getContext(this.contextName, parameters);\n    else\n      context = canvas.getContext(this.contextName);\n\n    if (!context) throw new Error('Invalid context.');\n\n    this.contexts.set(canvas.id, context);\n  }\n\n  public remove = (canvas: HTMLCanvasElement) => {\n    this.contexts.delete(canvas.id);\n  }\n\n  public setProperty = (canvas: HTMLCanvasElement, property: string, value: any) => {\n    const context = this.getContext(canvas);\n    this.setPropertyWithContext(context, property, value);\n  }\n\n  public getProperty = (canvas: HTMLCanvasElement, property: string) => {\n    const context = this.getContext(canvas);\n    return this.serialize(context[property]);\n  }\n\n  public call = (canvas: HTMLCanvasElement, method: string, args: any) => {\n    const context = this.getContext(canvas);\n    return this.callWithContext(context, method, args);\n  }\n\n  public callBatch = (canvas: HTMLCanvasElement, batchedCalls: any[][]) => {\n    const context = this.getContext(canvas);\n    for (let i = 0; i < batchedCalls.length; i++) {\n      let params = batchedCalls[i].slice(2);\n      if (batchedCalls[i][1]) {\n        this.callWithContext(context, batchedCalls[i][0], params);\n      } else {\n        this.setPropertyWithContext(\n          context,\n          batchedCalls[i][0],\n          Array.isArray(params) && params.length > 0 ? params[0] : null);\n      }\n    }\n  }\n\n  private callWithContext = (context: any, method: string, args: any) => {\n    return this.serialize(this.prototypes[method].apply(context, args != undefined ? args.map((value) => this.deserialize(method, value)) : []));\n  }\n\n  private setPropertyWithContext = (context: any, property: string, value: any) => {\n    context[property] = this.deserialize(property, value);\n  }\n\n  private getContext = (canvas: HTMLCanvasElement) => {\n    if (!canvas) throw new Error('Invalid canvas.');\n\n    const context = this.contexts.get(canvas.id);\n    if (!context) throw new Error('Invalid context.');\n\n    return context;\n  }\n\n  private deserialize = (method: string, object: any) => {\n    if (!this.webGLContext || object == undefined) return object; //deserialization only needs to happen for webGL\n\n    if (object.hasOwnProperty(\"webGLType\") && object.hasOwnProperty(\"id\")) {\n      return (this.webGLObject[object[\"id\"]]);\n    } else if (Array.isArray(object) && !method.endsWith(\"v\")) {\n      return Int8Array.of(...(object as number[]));\n    } else if (typeof(object) === \"string\" && (method === \"bufferData\" || method === \"bufferSubData\")) {\n      let binStr = window.atob(object);\n      let length = binStr.length;\n      let bytes = new Uint8Array(length);\n      for (var i = 0; i < length; i++) {\n          bytes[i] = binStr.charCodeAt(i);\n      }\n      return bytes;\n    } else\n      return object;\n  }\n\n  private serialize = (object: any) => {\n    if (object instanceof TextMetrics) {\n        return { width: object.width };\n    }\n\n    if (!this.webGLContext || object == undefined) return object; //serialization only needs to happen for webGL\n\n    const type = this.webGLTypes.find((type) => object instanceof type);\n    if (type != undefined) {\n      const id = this.webGLObject.length;\n      this.webGLObject.push(object);\n\n      return {\n        webGLType: type.name,\n        id: id\n        };\n    } else\n      return object;\n  }\n}\n"],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./src/InitializeCanvas.ts","webpack:///./src/CanvasContextManager.ts"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","CanvasContextManager_1","Canvas","blazorExtensions","extensionObject","Canvas2d","ContextManager","WebGL","initialize","window","assign","[object Object]","contextName","this","contexts","Map","webGLObject","Array","webGLContext","webGLTypes","WebGLBuffer","WebGLShader","WebGLProgram","WebGLFramebuffer","WebGLRenderbuffer","WebGLTexture","WebGLUniformLocation","add","canvas","parameters","Error","id","context","getContext","set","remove","delete","setProperty","setPropertyWithContext","getProperty","serialize","method","args","callWithContext","callBatch","batchedCalls","length","params","slice","isArray","prototypes","apply","undefined","map","deserialize","endsWith","Int8Array","of","binStr","atob","bytes","Uint8Array","charCodeAt","TextMetrics","width","type","find","push","webGLType","CanvasRenderingContext2D","WebGLRenderingContext"],"mappings":"aACA,IAAAA,KAGA,SAAAC,EAAAC,GAGA,GAAAF,EAAAE,GACA,OAAAF,EAAAE,GAAAC,QAGA,IAAAC,EAAAJ,EAAAE,IACAG,EAAAH,EACAI,GAAA,EACAH,YAUA,OANAI,EAAAL,GAAAM,KAAAJ,EAAAD,QAAAC,IAAAD,QAAAF,GAGAG,EAAAE,GAAA,EAGAF,EAAAD,QAKAF,EAAAQ,EAAAF,EAGAN,EAAAS,EAAAV,EAGAC,EAAAU,EAAA,SAAAR,EAAAS,EAAAC,GACAZ,EAAAa,EAAAX,EAAAS,IACAG,OAAAC,eAAAb,EAAAS,GAA0CK,YAAA,EAAAC,IAAAL,KAK1CZ,EAAAkB,EAAA,SAAAhB,GACA,oBAAAiB,eAAAC,aACAN,OAAAC,eAAAb,EAAAiB,OAAAC,aAAwDC,MAAA,WAExDP,OAAAC,eAAAb,EAAA,cAAiDmB,OAAA,KAQjDrB,EAAAsB,EAAA,SAAAD,EAAAE,GAEA,GADA,EAAAA,IAAAF,EAAArB,EAAAqB,IACA,EAAAE,EAAA,OAAAF,EACA,KAAAE,GAAA,iBAAAF,QAAAG,WAAA,OAAAH,EACA,IAAAI,EAAAX,OAAAY,OAAA,MAGA,GAFA1B,EAAAkB,EAAAO,GACAX,OAAAC,eAAAU,EAAA,WAAyCT,YAAA,EAAAK,UACzC,EAAAE,GAAA,iBAAAF,EAAA,QAAAM,KAAAN,EAAArB,EAAAU,EAAAe,EAAAE,EAAA,SAAAA,GAAgH,OAAAN,EAAAM,IAAqBC,KAAA,KAAAD,IACrI,OAAAF,GAIAzB,EAAA6B,EAAA,SAAA1B,GACA,IAAAS,EAAAT,KAAAqB,WACA,WAA2B,OAAArB,EAAA,SAC3B,WAAiC,OAAAA,GAEjC,OADAH,EAAAU,EAAAE,EAAA,IAAAA,GACAA,GAIAZ,EAAAa,EAAA,SAAAiB,EAAAC,GAAsD,OAAAjB,OAAAkB,UAAAC,eAAA1B,KAAAuB,EAAAC,IAGtD/B,EAAAkC,EAAA,GAIAlC,IAAAmC,EAAA,mFClFA,MAAAC,EAAApC,EAAA,GAEA,IAAUqC,GAAV,SAAUA,GACR,MAAMC,EAA2B,mBAE3BC,GACJC,SAAU,IAAIJ,EAAAK,eAAe,MAC7BC,MAAO,IAAIN,EAAAK,eAAe,UAGZJ,EAAAM,WAAhB,WACwB,oBAAXC,QAA2BA,OAAON,GAO3CM,OAAON,GAAiBxB,OAAA+B,UACnBD,OAAON,GACPC,GANLK,OAAON,GAAiBxB,OAAA+B,UACnBN,IAbX,CAAUF,WAwBVA,EAAOM,4FC1BPzC,EAAAuC,qBAUEK,YAAmBC,GAEjB,GAXeC,KAAAC,SAAW,IAAIC,IACfF,KAAAG,YAAc,IAAIC,MAE3BJ,KAAAK,cAAe,EAENL,KAAAM,YACfC,YAAaC,YAAaC,aAAcC,iBAAkBC,kBAAmBC,aAAcC,sBActFb,KAAAc,IAAM,EAACC,EAA2BC,KACvC,IAAKD,EAAQ,MAAM,IAAIE,MAAM,mBAC7B,IAAIjB,KAAKC,SAAShC,IAAI8C,EAAOG,IAA7B,CAEA,IAAIC,EAMJ,KAJEA,EADEH,EACQD,EAAOK,WAAWpB,KAAKD,YAAaiB,GAEpCD,EAAOK,WAAWpB,KAAKD,cAErB,MAAM,IAAIkB,MAAM,oBAE9BjB,KAAKC,SAASoB,IAAIN,EAAOG,GAAIC,MAGxBnB,KAAAsB,OAAS,CAACP,IACff,KAAKC,SAASsB,OAAOR,EAAOG,MAGvBlB,KAAAwB,YAAc,EAACT,EAA2BhC,EAAkBV,KACjE,MAAM8C,EAAUnB,KAAKoB,WAAWL,GAChCf,KAAKyB,uBAAuBN,EAASpC,EAAUV,KAG1C2B,KAAA0B,YAAc,EAACX,EAA2BhC,KAC/C,MAAMoC,EAAUnB,KAAKoB,WAAWL,GAChC,OAAOf,KAAK2B,UAAUR,EAAQpC,MAGzBiB,KAAAzC,KAAO,EAACwD,EAA2Ba,EAAgBC,KACxD,MAAMV,EAAUnB,KAAKoB,WAAWL,GAChC,OAAOf,KAAK8B,gBAAgBX,EAASS,EAAQC,KAGxC7B,KAAA+B,UAAY,EAAChB,EAA2BiB,KAC7C,MAAMb,EAAUnB,KAAKoB,WAAWL,GAChC,IAAK,IAAI3D,EAAI,EAAGA,EAAI4E,EAAaC,OAAQ7E,IAAK,CAC5C,IAAI8E,EAASF,EAAa5E,GAAG+E,MAAM,GAC/BH,EAAa5E,GAAG,GAClB4C,KAAK8B,gBAAgBX,EAASa,EAAa5E,GAAG,GAAI8E,GAElDlC,KAAKyB,uBACHN,EACAa,EAAa5E,GAAG,GAChBgD,MAAMgC,QAAQF,IAAWA,EAAOD,OAAS,EAAIC,EAAO,GAAK,SAKzDlC,KAAA8B,gBAAkB,EAACX,EAAcS,EAAgBC,IAChD7B,KAAK2B,UAAU3B,KAAKqC,WAAWT,GAAQU,MAAMnB,OAAiBoB,GAARV,EAAoBA,EAAKW,IAAKnE,GAAU2B,KAAKyC,YAAYb,EAAQvD,UAGxH2B,KAAAyB,uBAAyB,EAACN,EAAcpC,EAAkBV,KAChE8C,EAAQpC,GAAYiB,KAAKyC,YAAY1D,EAAUV,KAGzC2B,KAAAoB,WAAa,CAACL,IACpB,IAAKA,EAAQ,MAAM,IAAIE,MAAM,mBAE7B,MAAME,EAAUnB,KAAKC,SAAShC,IAAI8C,EAAOG,IACzC,IAAKC,EAAS,MAAM,IAAIF,MAAM,oBAE9B,OAAOE,IAGDnB,KAAAyC,YAAc,EAACb,EAAgB9C,KACrC,IAAKkB,KAAKK,mBAA0BkC,GAAVzD,EAAqB,OAAOA,EAEtD,GAAIA,EAAOG,eAAe,cAAgBH,EAAOG,eAAe,MAC9D,OAAQe,KAAKG,YAAYrB,EAAW,IAC/B,GAAIsB,MAAMgC,QAAQtD,KAAY8C,EAAOc,SAAS,KACnD,OAAOC,UAAUC,MAAO9D,GACnB,GAAuB,iBAAb,GAAqC,eAAX8C,GAAsC,kBAAXA,EASpE,OAAO9C,EAT0F,CACjG,IAAI+D,EAASjD,OAAOkD,KAAKhE,GACrBmD,EAASY,EAAOZ,OAChBc,EAAQ,IAAIC,WAAWf,GAC3B,IAAK,IAAI7E,EAAI,EAAGA,EAAI6E,EAAQ7E,IACxB2F,EAAM3F,GAAKyF,EAAOI,WAAW7F,GAEjC,OAAO2F,KAKH/C,KAAA2B,UAAY,CAAC7C,IACnB,GAAIA,aAAkBoE,YAClB,OAASC,MAAOrE,EAAOqE,OAG3B,IAAKnD,KAAKK,mBAA0BkC,GAAVzD,EAAqB,OAAOA,EAEtD,MAAMsE,EAAOpD,KAAKM,WAAW+C,KAAMD,GAAStE,aAAkBsE,GAC9D,QAAYb,GAARa,EAAmB,CACrB,MAAMlC,EAAKlB,KAAKG,YAAY8B,OAG5B,OAFAjC,KAAKG,YAAYmD,KAAKxE,IAGpByE,UAAWH,EAAKzF,KAChBuD,GAAIA,GAGN,OAAOpC,IAhHTkB,KAAKD,YAAcA,EACC,OAAhBA,EACFC,KAAKqC,WAAamB,yBAAyBxE,cACxC,IAAoB,UAAhBe,GAA2C,uBAAhBA,EAIlC,MAAM,IAAIkB,+BAA+BlB,KAHzCC,KAAKqC,WAAaoB,sBAAsBzE,UACxCgB,KAAKK,cAAe","file":"blazor.extensions.canvas.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","import { ContextManager } from './CanvasContextManager';\r\n\r\nnamespace Canvas {\r\n  const blazorExtensions: string = 'BlazorExtensions';\r\n  // define what this extension adds to the window object inside BlazorExtensions\r\n  const extensionObject = {\r\n    Canvas2d: new ContextManager(\"2d\"),\r\n    WebGL: new ContextManager(\"webgl\")\r\n  };\r\n\r\n  export function initialize(): void {\r\n    if (typeof window !== 'undefined' && !window[blazorExtensions]) {\r\n      // when the library is loaded in a browser via a <script> element, make the\r\n      // following APIs available in global scope for invocation from JS\r\n      window[blazorExtensions] = {\r\n        ...extensionObject\r\n      };\r\n    } else {\r\n      window[blazorExtensions] = {\r\n        ...window[blazorExtensions],\r\n        ...extensionObject\r\n      };\r\n    }\r\n  }\r\n}\r\n\r\nCanvas.initialize();\r\n","export class ContextManager {\r\n  private readonly contexts = new Map<string, any>();\r\n  private readonly webGLObject = new Array<any>();\r\n  private readonly contextName: string;\r\n  private webGLContext = false;\r\n  private readonly prototypes: any;\r\n  private readonly webGLTypes = [\r\n    WebGLBuffer, WebGLShader, WebGLProgram, WebGLFramebuffer, WebGLRenderbuffer, WebGLTexture, WebGLUniformLocation\r\n  ];\r\n\r\n  public constructor(contextName: string) {\r\n    this.contextName = contextName;\r\n    if (contextName === \"2d\")\r\n      this.prototypes = CanvasRenderingContext2D.prototype;\r\n    else if (contextName === \"webgl\" || contextName === \"experimental-webgl\") {\r\n      this.prototypes = WebGLRenderingContext.prototype;\r\n      this.webGLContext = true;\r\n    } else\r\n      throw new Error(`Invalid context name: ${contextName}`);\r\n  }\r\n\r\n  public add = (canvas: HTMLCanvasElement, parameters: any) => {\r\n    if (!canvas) throw new Error('Invalid canvas.');\r\n    if (this.contexts.get(canvas.id)) return;\r\n\r\n    var context;\r\n    if (parameters)\r\n      context = canvas.getContext(this.contextName, parameters);\r\n    else\r\n      context = canvas.getContext(this.contextName);\r\n\r\n    if (!context) throw new Error('Invalid context.');\r\n\r\n    this.contexts.set(canvas.id, context);\r\n  }\r\n\r\n  public remove = (canvas: HTMLCanvasElement) => {\r\n    this.contexts.delete(canvas.id);\r\n  }\r\n\r\n  public setProperty = (canvas: HTMLCanvasElement, property: string, value: any) => {\r\n    const context = this.getContext(canvas);\r\n    this.setPropertyWithContext(context, property, value);\r\n  }\r\n\r\n  public getProperty = (canvas: HTMLCanvasElement, property: string) => {\r\n    const context = this.getContext(canvas);\r\n    return this.serialize(context[property]);\r\n  }\r\n\r\n  public call = (canvas: HTMLCanvasElement, method: string, args: any) => {\r\n    const context = this.getContext(canvas);\r\n    return this.callWithContext(context, method, args);\r\n  }\r\n\r\n  public callBatch = (canvas: HTMLCanvasElement, batchedCalls: any[][]) => {\r\n    const context = this.getContext(canvas);\r\n    for (let i = 0; i < batchedCalls.length; i++) {\r\n      let params = batchedCalls[i].slice(2);\r\n      if (batchedCalls[i][1]) {\r\n        this.callWithContext(context, batchedCalls[i][0], params);\r\n      } else {\r\n        this.setPropertyWithContext(\r\n          context,\r\n          batchedCalls[i][0],\r\n          Array.isArray(params) && params.length > 0 ? params[0] : null);\r\n      }\r\n    }\r\n  }\r\n\r\n  private callWithContext = (context: any, method: string, args: any) => {\r\n    return this.serialize(this.prototypes[method].apply(context, args != undefined ? args.map((value) => this.deserialize(method, value)) : []));\r\n  }\r\n\r\n  private setPropertyWithContext = (context: any, property: string, value: any) => {\r\n    context[property] = this.deserialize(property, value);\r\n  }\r\n\r\n  private getContext = (canvas: HTMLCanvasElement) => {\r\n    if (!canvas) throw new Error('Invalid canvas.');\r\n\r\n    const context = this.contexts.get(canvas.id);\r\n    if (!context) throw new Error('Invalid context.');\r\n\r\n    return context;\r\n  }\r\n\r\n  private deserialize = (method: string, object: any) => {\r\n    if (!this.webGLContext || object == undefined) return object; //deserialization only needs to happen for webGL\r\n\r\n    if (object.hasOwnProperty(\"webGLType\") && object.hasOwnProperty(\"id\")) {\r\n      return (this.webGLObject[object[\"id\"]]);\r\n    } else if (Array.isArray(object) && !method.endsWith(\"v\")) {\r\n      return Int8Array.of(...(object as number[]));\r\n    } else if (typeof(object) === \"string\" && (method === \"bufferData\" || method === \"bufferSubData\")) {\r\n      let binStr = window.atob(object);\r\n      let length = binStr.length;\r\n      let bytes = new Uint8Array(length);\r\n      for (var i = 0; i < length; i++) {\r\n          bytes[i] = binStr.charCodeAt(i);\r\n      }\r\n      return bytes;\r\n    } else\r\n      return object;\r\n  }\r\n\r\n  private serialize = (object: any) => {\r\n    if (object instanceof TextMetrics) {\r\n        return { width: object.width };\r\n    }\r\n\r\n    if (!this.webGLContext || object == undefined) return object; //serialization only needs to happen for webGL\r\n\r\n    const type = this.webGLTypes.find((type) => object instanceof type);\r\n    if (type != undefined) {\r\n      const id = this.webGLObject.length;\r\n      this.webGLObject.push(object);\r\n\r\n      return {\r\n        webGLType: type.name,\r\n        id: id\r\n        };\r\n    } else\r\n      return object;\r\n  }\r\n}\r\n"],"sourceRoot":""} \ No newline at end of file