-
Notifications
You must be signed in to change notification settings - Fork 149
Expand file tree
/
Copy pathblazor.extensions.canvas.js
More file actions
2 lines (2 loc) · 21.6 KB
/
blazor.extensions.canvas.js
File metadata and controls
2 lines (2 loc) · 21.6 KB
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={Canvas2d:new r.ContextManager("2d"),WebGL:new r.ContextManager("webgl")};t.initialize=function(){"undefined"==typeof window||window.BlazorExtensions?window.BlazorExtensions=Object.assign({},window.BlazorExtensions,e):window.BlazorExtensions=Object.assign({},e)}}(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;t<e.length;t++){let r=e[t].slice(2);e[t][1]?this.callWithContext(n,e[t][0],r):this.setPropertyWithContext(n,e[t][0],Array.isArray(r)&&r.length>0?r[0]:null)}},this.callWithContext=(t,e,n)=>this.serialize(this.prototypes[e].apply(t,null!=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||null==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<r;n++)i[n]=t.charCodeAt(n);return i}},this.serialize=t=>{if(t instanceof TextMetrics)return{width:t.width};if(!this.webGLContext||null==t)return t;const e=this.webGLTypes.find(e=>t instanceof e);if(null!=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","Canvas","extensionObject","Canvas2d","ContextManager","WebGL","initialize","window","contextName","contexts","Map","webGLObject","Array","webGLContext","webGLTypes","WebGLBuffer","WebGLShader","WebGLProgram","WebGLFramebuffer","WebGLRenderbuffer","WebGLTexture","WebGLUniformLocation","add","canvas","parameters","Error","this","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';\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":""}