From 6ff8bb700dff1c6e22551a4cea84b8ea4d98f8e0 Mon Sep 17 00:00:00 2001 From: tamat Date: Tue, 21 Apr 2020 12:38:54 +0200 Subject: [PATCH] fix in roundRect --- build/litegraph.js | 10 +- build/litegraph.min.js | 286 ++++++++++++++++++++--------------------- src/litegraph.js | 8 +- 3 files changed, 152 insertions(+), 152 deletions(-) diff --git a/build/litegraph.js b/build/litegraph.js index 6116c5c4b..926530b2f 100644 --- a/build/litegraph.js +++ b/build/litegraph.js @@ -10196,8 +10196,8 @@ LGraphNode.prototype.executeAction = function(action) //API ************************************************* //like rect but rounded corners - if (this.CanvasRenderingContext2D) { - CanvasRenderingContext2D.prototype.roundRect = function( + if (global.CanvasRenderingContext2D) { + global.CanvasRenderingContext2D.prototype.roundRect = function( x, y, width, @@ -27616,10 +27616,10 @@ LiteGraph.registerNodeType("audio/waveShaper", LGAudioWaveShaper); this._ws.onmessage = function(e) { that.boxcolor = "#AFA"; var data = JSON.parse(e.data); - if (data.room && data.room != this.properties.room) { + if (data.room && data.room != that.properties.room) { return; } - if (e.data.type == 1) { + if (data.type == 1) { if ( data.data.object_class && LiteGraph[data.data.object_class] @@ -27635,7 +27635,7 @@ LiteGraph.registerNodeType("audio/waveShaper", LGAudioWaveShaper); that.triggerSlot(0, data.data); } } else { - that._last_received_data[e.data.channel || 0] = data.data; + that._last_received_data[data.channel || 0] = data.data; } }; this._ws.onerror = function(e) { diff --git a/build/litegraph.min.js b/build/litegraph.min.js index cfe4fef25..0d7846dbd 100755 --- a/build/litegraph.min.js +++ b/build/litegraph.min.js @@ -28,8 +28,8 @@ c.STATUS_RUNNING){this.status=c.STATUS_RUNNING;if(this.onPlayEvent)this.onPlayEv b.runStep(1,!this.catch_errors);if(b.onAfterStep)b.onAfterStep()},a)}};c.prototype.stop=function(){if(this.status!=c.STATUS_STOPPED){this.status=c.STATUS_STOPPED;if(this.onStopEvent)this.onStopEvent();null!=this.execution_timer_id&&(-1!=this.execution_timer_id&&clearInterval(this.execution_timer_id),this.execution_timer_id=null);this.sendEventToAllNodes("onStop")}};c.prototype.runStep=function(a,b,d){a=a||1;var g=h.getTime();this.globaltime=0.001*(g-this.starttime);var f=this._nodes_executable?this._nodes_executable: this._nodes;if(f){d=d||f.length;if(b){for(var r=0;rs&&(s=f.size[0]),c+=f.size[1]+a+h.NODE_TITLE_HEIGHT;b+=s+a}this.setDirtyCanvas(!0,!0)};c.prototype.getTime=function(){return this.globaltime};c.prototype.getFixedTime=function(){return this.fixedtime};c.prototype.getElapsedTime=function(){return this.elapsed_time};c.prototype.sendEventToAllNodes=function(a,b,d){d=d||h.ALWAYS;var g=this._nodes_in_order? this._nodes_in_order:this._nodes;if(g)for(var f=0,r=g.length;fh.getTime()-this.last_mouseclick;this.canvas_mouse[0]=a.canvasX;this.canvas_mouse[1]=a.canvasY;this.canvas.focus(); h.closeAllContextMenus(b);if(!this.onMouse||!0!=this.onMouse(a)){if(1==a.which){a.ctrlKey&&(this.dragging_rectangle=new Float32Array(4),this.dragging_rectangle[0]=a.canvasX,this.dragging_rectangle[1]=a.canvasY,this.dragging_rectangle[2]=1,this.dragging_rectangle[3]=1,g=!0);var r=!1;if(d&&this.allow_interaction&&!g&&!this.read_only){this.live_mode||d.flags.pinned||this.bringToFront(d);if(!this.connecting_node&&!d.flags.collapsed&&!this.live_mode)if(!g&&!1!==d.resizable&&w(a.canvasX,a.canvasY,d.pos[0]+ -d.size[0]-5,d.pos[1]+d.size[1]-5,10,10))this.resizing_node=d,this.canvas.style.cursor="se-resize",g=!0;else{if(d.outputs)for(var s=0,c=d.outputs.length;sr[0]+4||a.canvasYr[1]+4)){this.showLinkMenu(d,a);this.over_link_center=null;break}this.selected_group=this.graph.getGroupOnPos(a.canvasX,a.canvasY);this.selected_group_resizing=!1;this.selected_group&&!this.read_only&&(a.ctrlKey&&(this.dragging_rectangle=null),10>C([a.canvasX, a.canvasY],[this.selected_group.pos[0]+this.selected_group.size[0],this.selected_group.pos[1]+this.selected_group.size[1]])*this.ds.scale?this.selected_group_resizing=!0:this.selected_group.recomputeInsideNodes());f&&!this.read_only&&this.allow_searchbox&&this.showSearchBox(a);r=!0}!g&&r&&this.allow_dragcanvas&&(this.dragging_canvas=!0)}else 2!=a.which&&3==a.which&&(this.read_only||this.processContextMenu(d,a));this.last_mouse[0]=a.localX;this.last_mouse[1]=a.localY;this.last_mouseclick=h.getTime(); @@ -158,65 +158,65 @@ this._bg_img.onload=function(){h.draw(!0,!0)}}d=null;null==this._pattern&&0this.ds.scale;if(this.live_mode){if(!a.flags.collapsed&&(b.shadowColor="transparent",a.onDrawForeground))a.onDrawForeground(b,this,this.canvas)}else{var r=this.editor_alpha;b.globalAlpha=r;this.render_shadows&&!f?(b.shadowColor= h.DEFAULT_SHADOW_COLOR,b.shadowOffsetX=2*this.ds.scale,b.shadowOffsetY=2*this.ds.scale,b.shadowBlur=3*this.ds.scale):b.shadowColor="transparent";if(!a.flags.collapsed||!a.onDrawCollapsed||!0!=a.onDrawCollapsed(b,this)){var s=a._shape||h.BOX_SHAPE;y.set(a.size);var c=a.horizontal;if(a.flags.collapsed){b.font=this.inner_text_font;var k=a.getTitle?a.getTitle():a.title;null!=k&&(a._collapsed_width=Math.min(a.size[0],b.measureText(k).width+2*h.NODE_TITLE_HEIGHT),y[0]=a._collapsed_width,y[1]=0)}a.clip_area&& -(b.save(),b.beginPath(),s==h.BOX_SHAPE?b.rect(0,0,y[0],y[1]):s==h.ROUND_SHAPE?b.roundRect(0,0,y[0],y[1],10):s==h.CIRCLE_SHAPE&&b.arc(0.5*y[0],0.5*y[1],0.5*y[0],0,2*Math.PI),b.clip());a.has_errors&&(g="red");this.drawNodeShape(a,b,y,d,g,a.is_selected,a.mouseOver);b.shadowColor="transparent";if(a.onDrawForeground)a.onDrawForeground(b,this,this.canvas);b.textAlign=c?"center":"left";b.font=this.inner_text_font;g=!f;s=this.connecting_output;b.lineWidth=1;var k=0,q=new Float32Array(2);if(!a.flags.collapsed){if(a.inputs)for(d= -0;dthis.ds.scale,k=a._shape||a.constructor.shape||h.ROUND_SHAPE,q=a.constructor.title_mode,p=!0;q==h.TRANSPARENT_TITLE?p=!1:q==h.AUTOHIDE_TITLE&&s&&(p=!0);v[0]=0;v[1]=p?-f:0;v[2]=d[0]+1;v[3]=p?d[1]+f:d[1];s=b.globalAlpha;b.beginPath();k==h.BOX_SHAPE|| -c?b.fillRect(v[0],v[1],v[2],v[3]):k==h.ROUND_SHAPE||k==h.CARD_SHAPE?b.roundRect(v[0],v[1],v[2],v[3],this.round_radius,k==h.CARD_SHAPE?0:this.round_radius):k==h.CIRCLE_SHAPE&&b.arc(0.5*d[0],0.5*d[1],0.5*d[0],0,2*Math.PI);b.fill();a.flags.collapsed||(b.shadowColor="transparent",b.fillStyle="rgba(0,0,0,0.2)",b.fillRect(0,-1,v[2],2));b.shadowColor="transparent";if(a.onDrawBackground)a.onDrawBackground(b,this,this.canvas);if(p||q==h.TRANSPARENT_TITLE){if(a.onDrawTitleBar)a.onDrawTitleBar(b,f,d,this.ds.scale, -g);else if(q!=h.TRANSPARENT_TITLE&&(a.constructor.title_color||this.render_title_colored)){p=a.constructor.title_color||g;a.flags.collapsed&&(b.shadowColor=h.DEFAULT_SHADOW_COLOR);if(this.use_gradients){var t=e.gradients[p];t||(t=e.gradients[p]=b.createLinearGradient(0,0,400,0),t.addColorStop(0,p),t.addColorStop(1,"#000"));b.fillStyle=t}else b.fillStyle=p;b.beginPath();k==h.BOX_SHAPE||c?b.rect(0,-f,d[0]+1,f):k!=h.ROUND_SHAPE&&k!=h.CARD_SHAPE||b.roundRect(0,-f,d[0]+1,f,this.round_radius,a.flags.collapsed? +d[1]-5),a.fill(),a.shadowColor="transparent",a.textAlign="center",a.fillStyle="#CEC",a.fillText(f,d[0],d[1]-15-24*0.3))}};var v=new Float32Array(4);e.prototype.drawNodeShape=function(a,b,d,g,f,r,s){b.strokeStyle=g;b.fillStyle=f;f=h.NODE_TITLE_HEIGHT;var c=0.5>this.ds.scale,k=a._shape||a.constructor.shape||h.ROUND_SHAPE,p=a.constructor.title_mode,q=!0;p==h.TRANSPARENT_TITLE?q=!1:p==h.AUTOHIDE_TITLE&&s&&(q=!0);v[0]=0;v[1]=q?-f:0;v[2]=d[0]+1;v[3]=q?d[1]+f:d[1];s=b.globalAlpha;b.beginPath();k==h.BOX_SHAPE|| +c?b.fillRect(v[0],v[1],v[2],v[3]):k==h.ROUND_SHAPE||k==h.CARD_SHAPE?b.roundRect(v[0],v[1],v[2],v[3],this.round_radius,k==h.CARD_SHAPE?0:this.round_radius):k==h.CIRCLE_SHAPE&&b.arc(0.5*d[0],0.5*d[1],0.5*d[0],0,2*Math.PI);b.fill();a.flags.collapsed||(b.shadowColor="transparent",b.fillStyle="rgba(0,0,0,0.2)",b.fillRect(0,-1,v[2],2));b.shadowColor="transparent";if(a.onDrawBackground)a.onDrawBackground(b,this,this.canvas);if(q||p==h.TRANSPARENT_TITLE){if(a.onDrawTitleBar)a.onDrawTitleBar(b,f,d,this.ds.scale, +g);else if(p!=h.TRANSPARENT_TITLE&&(a.constructor.title_color||this.render_title_colored)){q=a.constructor.title_color||g;a.flags.collapsed&&(b.shadowColor=h.DEFAULT_SHADOW_COLOR);if(this.use_gradients){var t=e.gradients[q];t||(t=e.gradients[q]=b.createLinearGradient(0,0,400,0),t.addColorStop(0,q),t.addColorStop(1,"#000"));b.fillStyle=t}else b.fillStyle=q;b.beginPath();k==h.BOX_SHAPE||c?b.rect(0,-f,d[0]+1,f):k!=h.ROUND_SHAPE&&k!=h.CARD_SHAPE||b.roundRect(0,-f,d[0]+1,f,this.round_radius,a.flags.collapsed? this.round_radius:0);b.fill();b.shadowColor="transparent"}if(a.onDrawTitleBox)a.onDrawTitleBox(b,f,d,this.ds.scale);else k==h.ROUND_SHAPE||k==h.CIRCLE_SHAPE||k==h.CARD_SHAPE?(c&&(b.fillStyle="black",b.beginPath(),b.arc(0.5*f,-0.5*f,6,0,2*Math.PI),b.fill()),b.fillStyle=a.boxcolor||h.NODE_DEFAULT_BOXCOLOR,c?b.fillRect(0.5*f-5,-0.5*f-5,10,10):(b.beginPath(),b.arc(0.5*f,-0.5*f,5,0,2*Math.PI),b.fill())):(c&&(b.fillStyle="black",b.fillRect(0.5*(f-10)-1,-0.5*(f+10)-1,12,12)),b.fillStyle=a.boxcolor||h.NODE_DEFAULT_BOXCOLOR, b.fillRect(0.5*(f-10),-0.5*(f+10),10,10));b.globalAlpha=s;if(a.onDrawTitleText)a.onDrawTitleText(b,f,d,this.ds.scale,this.title_text_font,r);!c&&(b.font=this.title_text_font,c=String(a.getTitle()))&&(b.fillStyle=r?"white":a.constructor.title_text_color||this.node_title_color,a.flags.collapsed?(b.textAlign="left",b.measureText(c),b.fillText(c.substr(0,20),f,h.NODE_TITLE_TEXT_Y-f),b.textAlign="left"):(b.textAlign="left",b.fillText(c,f,h.NODE_TITLE_TEXT_Y-f)));if(a.onDrawTitle)a.onDrawTitle(b)}if(r){if(a.onBounding)a.onBounding(v); -q==h.TRANSPARENT_TITLE&&(v[1]-=f,v[3]+=f);b.lineWidth=1;b.globalAlpha=0.8;b.beginPath();k==h.BOX_SHAPE?b.rect(-6+v[0],-6+v[1],12+v[2],12+v[3]):k==h.ROUND_SHAPE||k==h.CARD_SHAPE&&a.flags.collapsed?b.roundRect(-6+v[0],-6+v[1],12+v[2],12+v[3],2*this.round_radius):k==h.CARD_SHAPE?b.roundRect(-6+v[0],-6+v[1],12+v[2],12+v[3],2*this.round_radius,2):k==h.CIRCLE_SHAPE&&b.arc(0.5*d[0],0.5*d[1],0.5*d[0]+6,0,2*Math.PI);b.strokeStyle="#FFF";b.stroke();b.strokeStyle=g;b.globalAlpha=1}};var G=new Float32Array(4), -q=new Float32Array(4),p=new Float32Array(2),k=new Float32Array(2);e.prototype.drawConnections=function(a){var b=h.getTime(),d=this.visible_area;G[0]=d[0]-20;G[1]=d[1]-20;G[2]=d[2]+40;G[3]=d[3]+40;a.lineWidth=this.connections_width;a.fillStyle="#AAA";a.strokeStyle="#AAA";a.globalAlpha=this.editor_alpha;for(var d=this.graph._nodes,g=0,f=d.length;gq[2]&&(q[0]+=q[2],q[2]=Math.abs(q[2]));0>q[3]&&(q[1]+=q[3],q[3]=Math.abs(q[3]));if(u(q,G)){var n=e.outputs[z],z=r.inputs[s];if(n&&z&&(e=n.dir||(e.horizontal?h.DOWN:h.RIGHT),z=z.dir||(r.horizontal?h.UP:h.LEFT),this.renderLink(a,l,t,c,!1,0,null,e,z),c&&c._last_time&&1E3>b-c._last_time)){var n= -2-0.002*(b-c._last_time),K=a.globalAlpha;a.globalAlpha=K*n;this.renderLink(a,l,t,c,!0,n,"white",e,z);a.globalAlpha=K}}}}}}a.globalAlpha=1};e.prototype.renderLink=function(a,b,d,g,f,r,c,k,q,p){g&&this.visible_links.push(g);!c&&g&&(c=g.color||e.link_type_colors[g.type]);c||(c=this.default_link_color);null!=g&&this.highlighted_links[g.id]&&(c="#FFF");k=k||h.RIGHT;q=q||h.LEFT;var z=C(b,d);this.render_connections_border&&0.6b[1]?0:Math.PI,a.save(),a.translate(t[0],t[1]),a.rotate(l),a.beginPath(),a.moveTo(-5,-3),a.lineTo(0,7),a.lineTo(5,-3),a.fill(),a.restore(),a.save(),a.translate(p[0],p[1]),a.rotate(n),a.beginPath(),a.moveTo(-5,-3),a.lineTo(0,7),a.lineTo(5,-3),a.fill(),a.restore()),a.beginPath(),a.arc(f[0],f[1],5,0,2*Math.PI),a.fill());if(r)for(a.fillStyle= -c,t=0;5>t;++t)r=(0.001*h.getTime()+0.2*t)%1,f=this.computeConnectionPoint(b,d,r,k,q),a.beginPath(),a.arc(f[0],f[1],5,0,2*Math.PI),a.fill()};e.prototype.computeConnectionPoint=function(a,b,d,g,f){g=g||h.RIGHT;f=f||h.LEFT;var r=C(a,b),c=[a[0],a[1]],k=[b[0],b[1]];switch(g){case h.LEFT:c[0]+=-0.25*r;break;case h.RIGHT:c[0]+=0.25*r;break;case h.UP:c[1]+=-0.25*r;break;case h.DOWN:c[1]+=0.25*r}switch(f){case h.LEFT:k[0]+=-0.25*r;break;case h.RIGHT:k[0]+=0.25*r;break;case h.UP:k[1]+=-0.25*r;break;case h.DOWN:k[1]+= +p==h.TRANSPARENT_TITLE&&(v[1]-=f,v[3]+=f);b.lineWidth=1;b.globalAlpha=0.8;b.beginPath();k==h.BOX_SHAPE?b.rect(-6+v[0],-6+v[1],12+v[2],12+v[3]):k==h.ROUND_SHAPE||k==h.CARD_SHAPE&&a.flags.collapsed?b.roundRect(-6+v[0],-6+v[1],12+v[2],12+v[3],2*this.round_radius):k==h.CARD_SHAPE?b.roundRect(-6+v[0],-6+v[1],12+v[2],12+v[3],2*this.round_radius,2):k==h.CIRCLE_SHAPE&&b.arc(0.5*d[0],0.5*d[1],0.5*d[0]+6,0,2*Math.PI);b.strokeStyle="#FFF";b.stroke();b.strokeStyle=g;b.globalAlpha=1}};var G=new Float32Array(4), +p=new Float32Array(4),q=new Float32Array(2),k=new Float32Array(2);e.prototype.drawConnections=function(a){var b=h.getTime(),d=this.visible_area;G[0]=d[0]-20;G[1]=d[1]-20;G[2]=d[2]+40;G[3]=d[3]+40;a.lineWidth=this.connections_width;a.fillStyle="#AAA";a.strokeStyle="#AAA";a.globalAlpha=this.editor_alpha;for(var d=this.graph._nodes,g=0,f=d.length;gp[2]&&(p[0]+=p[2],p[2]=Math.abs(p[2]));0>p[3]&&(p[1]+=p[3],p[3]=Math.abs(p[3]));if(u(p,G)){var n=e.outputs[z],z=r.inputs[s];if(n&&z&&(e=n.dir||(e.horizontal?h.DOWN:h.RIGHT),z=z.dir||(r.horizontal?h.UP:h.LEFT),this.renderLink(a,l,t,c,!1,0,null,e,z),c&&c._last_time&&1E3>b-c._last_time)){var n= +2-0.002*(b-c._last_time),K=a.globalAlpha;a.globalAlpha=K*n;this.renderLink(a,l,t,c,!0,n,"white",e,z);a.globalAlpha=K}}}}}}a.globalAlpha=1};e.prototype.renderLink=function(a,b,d,g,f,r,c,k,p,q){g&&this.visible_links.push(g);!c&&g&&(c=g.color||e.link_type_colors[g.type]);c||(c=this.default_link_color);null!=g&&this.highlighted_links[g.id]&&(c="#FFF");k=k||h.RIGHT;p=p||h.LEFT;var z=C(b,d);this.render_connections_border&&0.6b[1]?0:Math.PI,a.save(),a.translate(t[0],t[1]),a.rotate(l),a.beginPath(),a.moveTo(-5,-3),a.lineTo(0,7),a.lineTo(5,-3),a.fill(),a.restore(),a.save(),a.translate(q[0],q[1]),a.rotate(n),a.beginPath(),a.moveTo(-5,-3),a.lineTo(0,7),a.lineTo(5,-3),a.fill(),a.restore()),a.beginPath(),a.arc(f[0],f[1],5,0,2*Math.PI),a.fill());if(r)for(a.fillStyle= +c,t=0;5>t;++t)r=(0.001*h.getTime()+0.2*t)%1,f=this.computeConnectionPoint(b,d,r,k,p),a.beginPath(),a.arc(f[0],f[1],5,0,2*Math.PI),a.fill()};e.prototype.computeConnectionPoint=function(a,b,d,g,f){g=g||h.RIGHT;f=f||h.LEFT;var r=C(a,b),c=[a[0],a[1]],k=[b[0],b[1]];switch(g){case h.LEFT:c[0]+=-0.25*r;break;case h.RIGHT:c[0]+=0.25*r;break;case h.UP:c[1]+=-0.25*r;break;case h.DOWN:c[1]+=0.25*r}switch(f){case h.LEFT:k[0]+=-0.25*r;break;case h.RIGHT:k[0]+=0.25*r;break;case h.UP:k[1]+=-0.25*r;break;case h.DOWN:k[1]+= 0.25*r}g=(1-d)*(1-d)*(1-d);f=3*(1-d)*(1-d)*d;r=3*(1-d)*d*d;d*=d*d;return[g*a[0]+f*c[0]+r*k[0]+d*b[0],g*a[1]+f*c[1]+r*k[1]+d*b[1]]};e.prototype.drawExecutionOrder=function(a){a.shadowColor="transparent";a.globalAlpha=0.25;a.textAlign="center";a.strokeStyle="white";a.globalAlpha=0.75;for(var b=this.visible_nodes,d=0;dt.last_y&&st.options.max&&(t.value=t.options.max);else if("mousedown"==d.type){var l=t.options.values; -l&&l.constructor===Function&&(l=t.options.values(t,a));var z=null;"number"!=t.type&&(z=l.constructor===Array?l:Object.keys(l));c=40>c?-1:c>k-40?1:0;if("number"==t.type)t.value+=0.1*c*(t.options.step||1),null!=t.options.min&&t.valuet.options.max&&(t.value=t.options.max);else if(c)q=-1,q=l.constructor===Object?z.indexOf(String(t.value))+c:z.indexOf(t.value)+c,q>=z.length&&(q=z.length-1),0>q&&(q=0),t.value=l.constructor===Array?l[q]: -q;else{var n=l!=z?Object.values(l):l;new h.ContextMenu(n,{scale:Math.max(1,this.ds.scale),event:d,className:"dark",callback:y.bind(t)},q);var y=function(a,b,d){l!=z&&(a=n.indexOf(a));this.value=a;f(this,a);e.dirty_canvas=!0;return!1}}}else"mouseup"==d.type&&"number"==t.type&&(c=40>c?-1:c>k-40?1:0,200>d.click_time&&0==c&&this.prompt("Value",t.value,function(a){this.value=Number(a);f(this,this.value)}.bind(t),d));g!=t.value&&setTimeout(function(){f(this,this.value)}.bind(t),20);this.dirty_canvas=!0; +h.NODE_TITLE_HEIGHT+0.5,g.pos[1]-h.NODE_TITLE_HEIGHT+0.5,h.NODE_TITLE_HEIGHT,h.NODE_TITLE_HEIGHT);a.fillStyle="#FFF";a.fillText(g.order,g.pos[0]+-0.5*h.NODE_TITLE_HEIGHT,g.pos[1]-6)}a.globalAlpha=1};e.prototype.drawNodeWidgets=function(a,b,d,g){if(!a.widgets||!a.widgets.length)return 0;var f=a.size[0],r=a.widgets;b+=2;var c=h.NODE_WIDGET_HEIGHT,k=0.5t.last_y&&st.options.max&&(t.value=t.options.max);else if("mousedown"==d.type){var l=t.options.values; +l&&l.constructor===Function&&(l=t.options.values(t,a));var z=null;"number"!=t.type&&(z=l.constructor===Array?l:Object.keys(l));c=40>c?-1:c>k-40?1:0;if("number"==t.type)t.value+=0.1*c*(t.options.step||1),null!=t.options.min&&t.valuet.options.max&&(t.value=t.options.max);else if(c)e=-1,e=l.constructor===Object?z.indexOf(String(t.value))+c:z.indexOf(t.value)+c,e>=z.length&&(e=z.length-1),0>e&&(e=0),t.value=l.constructor===Array?l[e]: +e;else{var n=l!=z?Object.values(l):l;new h.ContextMenu(n,{scale:Math.max(1,this.ds.scale),event:d,className:"dark",callback:y.bind(t)},e);var y=function(a,b,d){l!=z&&(a=n.indexOf(a));this.value=a;f(this,a);p.dirty_canvas=!0;return!1}}}else"mouseup"==d.type&&"number"==t.type&&(c=40>c?-1:c>k-40?1:0,200>d.click_time&&0==c&&this.prompt("Value",t.value,function(a){this.value=Number(a);f(this,this.value)}.bind(t),d));g!=t.value&&setTimeout(function(){f(this,this.value)}.bind(t),20);this.dirty_canvas=!0; break;case "toggle":"mousedown"==d.type&&(t.value=!t.value,setTimeout(function(){f(t,t.value)},20));break;case "string":case "text":"mousedown"==d.type&&this.prompt("Value",t.value,function(a){this.value=a;f(this,a)}.bind(t),d);break;default:t.mouse&&t.mouse(ctx,d,[c,s],a)}return t}}return null};e.prototype.drawGroups=function(a,b){if(this.graph){var d=this.graph._groups;b.save();b.globalAlpha=0.5*this.editor_alpha;for(var g=0;gd&&0.01>b.editor_alpha&&(clearInterval(g),1>d&&(b.live_mode=!0));1"+p+""+a+"",value:p});if(q.length)return new h.ContextMenu(q, +s.graph.add(r));f&&f(r)}var s=e.active_canvas,k=s.getCanvasWindow();a=h.getNodeTypesCategories(s.filter);b=[];for(var p in a)a[p]&&b.push({value:a[p],content:a[p],has_submenu:!0});var q=new h.ContextMenu(b,{event:d,callback:function(a,b,d){a=h.getNodeTypesInCategory(a.value,s.filter);b=[];for(var f in a)a[f].skip_list||b.push({content:a[f].title,value:a[f].type});new h.ContextMenu(b,{event:d,callback:c,parentMenu:q},k);return!1},parentMenu:g},k);return!1};e.onMenuCollapseAll=function(){};e.onMenuNodeEdit= +function(){};e.showMenuNodeOptionalInputs=function(a,b,d,g,f){function c(a,b,d){f&&(a.callback&&a.callback.call(s,f,a,b,d),a.value&&(f.addInput(a.value[0],a.value[1],a.value[2]),f.setDirtyCanvas(!0,!0)))}if(f){var s=this;a=e.active_canvas.getCanvasWindow();b=f.optional_inputs;f.onGetInputs&&(b=f.onGetInputs());var k=[];if(b)for(var p in b){var q=b[p];if(q){var l=q[0];q[2]&&q[2].label&&(l=q[2].label);l={content:l,value:q};q[1]==h.ACTION&&(l.className="event");k.push(l)}else k.push(null)}this.onMenuNodeInputs&& +(k=this.onMenuNodeInputs(k));if(k.length)return new h.ContextMenu(k,{event:d,callback:c,parentMenu:g,node:f},a),!1}};e.showMenuNodeOptionalOutputs=function(a,b,d,g,f){function c(a,b,d){if(f&&(a.callback&&a.callback.call(k,f,a,b,d),a.value))if(d=a.value[1],!d||d.constructor!==Object&&d.constructor!==Array)f.addOutput(a.value[0],a.value[1],a.value[2]),f.setDirtyCanvas(!0,!0);else{a=[];for(var p in d)a.push({content:p,value:d[p]});new h.ContextMenu(a,{event:b,callback:c,parentMenu:g,node:f});return!1}} +if(f){var k=this;a=e.active_canvas.getCanvasWindow();b=f.optional_outputs;f.onGetOutputs&&(b=f.onGetOutputs());var p=[];if(b)for(var q in b){var l=b[q];if(!l)p.push(null);else if(!f.flags||!f.flags.skip_repeated_outputs||-1==f.findOutputSlot(l[0])){var z=l[0];l[2]&&l[2].label&&(z=l[2].label);z={content:z,value:l};l[1]==h.EVENT&&(z.className="event");p.push(z)}}this.onMenuNodeOutputs&&(p=this.onMenuNodeOutputs(p));if(p.length)return new h.ContextMenu(p,{event:d,callback:c,parentMenu:g,node:f},a),!1}}; +e.onShowMenuNodeProperties=function(a,b,d,g,f){function c(a,b,d,g){f&&(b=this.getBoundingClientRect(),k.showEditPropertyValue(f,a.value,{position:[b.left,b.top]}))}if(f&&f.properties){var k=e.active_canvas;b=k.getCanvasWindow();var p=[],q;for(q in f.properties)a=void 0!==f.properties[q]?f.properties[q]:" ","object"==typeof a&&(a=JSON.stringify(a)),a=e.decodeHTML(a),p.push({content:""+q+""+a+"",value:q});if(p.length)return new h.ContextMenu(p, {event:d,callback:c,parentMenu:g,allow_html:!0,node:f},b),!1}};e.decodeHTML=function(a){var b=document.createElement("div");b.innerText=a;return b.innerHTML};e.onResizeNode=function(a,b,d,g,f){f&&(f.size=f.computeSize(),f.setDirtyCanvas(!0,!0))};e.prototype.showLinkMenu=function(a,b){var d=this;console.log(a);var g=new h.ContextMenu(["Add Node",null,"Delete"],{event:b,title:null!=a.data?a.data.constructor.name:null,callback:function(b,h,c){switch(b){case "Add Node":e.onMenuAdd(null,null,c,g,function(b){console.log("node autoconnect"); -var f=d.graph.getNodeById(a.origin_id),g=d.graph.getNodeById(a.target_id);b.inputs&&b.inputs.length&&b.outputs&&b.outputs.length&&f.outputs[a.origin_slot].type==b.inputs[0].type&&b.outputs[0].type==g.inputs[0].type&&(f.connect(a.origin_slot,b,0),b.connect(0,g,a.target_slot),b.pos[0]-=0.5*b.size[0])});break;case "Delete":d.graph.removeLink(a.id)}}});return!1};e.onShowPropertyEditor=function(a,b,d,g,f){function h(){var b=q.value;"Number"==a.type?b=Number(b):"Boolean"==a.type&&(b=Boolean(b));f[c]=b; -k.parentNode&&k.parentNode.removeChild(k);f.setDirtyCanvas(!0,!0)}var c=a.property||"title";b=f[c];var k=document.createElement("div");k.className="graphdialog";k.innerHTML="";k.querySelector(".name").innerText=c;var q=k.querySelector("input");q&&(q.value=b,q.addEventListener("blur",function(a){this.focus()}),q.addEventListener("keydown",function(a){13==a.keyCode&&(h(),a.preventDefault(),a.stopPropagation())})); -b=e.active_canvas.canvas;d=b.getBoundingClientRect();var p=g=-20;d&&(g-=d.left,p-=d.top);event?(k.style.left=event.clientX+g+"px",k.style.top=event.clientY+p+"px"):(k.style.left=0.5*b.width+g+"px",k.style.top=0.5*b.height+p+"px");k.querySelector("button").addEventListener("click",h);b.parentNode.appendChild(k)};e.prototype.prompt=function(a,b,d,g){var f=this;a=a||"";var h=!1,c=document.createElement("div");c.className="graphdialog rounded";c.innerHTML=" "; +var f=d.graph.getNodeById(a.origin_id),g=d.graph.getNodeById(a.target_id);b.inputs&&b.inputs.length&&b.outputs&&b.outputs.length&&f.outputs[a.origin_slot].type==b.inputs[0].type&&b.outputs[0].type==g.inputs[0].type&&(f.connect(a.origin_slot,b,0),b.connect(0,g,a.target_slot),b.pos[0]-=0.5*b.size[0])});break;case "Delete":d.graph.removeLink(a.id)}}});return!1};e.onShowPropertyEditor=function(a,b,d,g,f){function h(){var b=p.value;"Number"==a.type?b=Number(b):"Boolean"==a.type&&(b=Boolean(b));f[c]=b; +k.parentNode&&k.parentNode.removeChild(k);f.setDirtyCanvas(!0,!0)}var c=a.property||"title";b=f[c];var k=document.createElement("div");k.className="graphdialog";k.innerHTML="";k.querySelector(".name").innerText=c;var p=k.querySelector("input");p&&(p.value=b,p.addEventListener("blur",function(a){this.focus()}),p.addEventListener("keydown",function(a){13==a.keyCode&&(h(),a.preventDefault(),a.stopPropagation())})); +b=e.active_canvas.canvas;d=b.getBoundingClientRect();var q=g=-20;d&&(g-=d.left,q-=d.top);event?(k.style.left=event.clientX+g+"px",k.style.top=event.clientY+q+"px"):(k.style.left=0.5*b.width+g+"px",k.style.top=0.5*b.height+q+"px");k.querySelector("button").addEventListener("click",h);b.parentNode.appendChild(k)};e.prototype.prompt=function(a,b,d,g){var f=this;a=a||"";var h=!1,c=document.createElement("div");c.className="graphdialog rounded";c.innerHTML=" "; c.close=function(){f.prompt_box=null;c.parentNode&&c.parentNode.removeChild(c)};1e.search_limit)break}}q=null;if(Array.prototype.filter)q=Object.keys(h.registered_node_types).filter(l); -else for(k in q=[],h.registered_node_types)l(k)&&q.push(k);for(k=0;ke.search_limit);k++);var l=function(a){var b=h.registered_node_types[a];return s&&b.filter!=s?!1:-1!==a.toLowerCase().indexOf(d)}}}var f=this,c=e.active_canvas,k=c.canvas,q=k.ownerDocument||document,p=document.createElement("div");p.className="litegraph litesearchbox graphdialog rounded";p.innerHTML="Search
"; -p.close=function(){f.search_box=null;q.body.focus();q.body.style.overflow="";setTimeout(function(){f.canvas.focus()},20);p.parentNode&&p.parentNode.removeChild(p)};var l=null;1k.height-200&&(z.style.maxHeight=k.height-a.layerY-20+"px");u.focus();return p};e.prototype.showEditPropertyValue=function(a,b,d){function g(){f(t.value)}function f(f){"number"==typeof a.properties[b]&&(f=Number(f));if("array"==h||"object"==h)f=JSON.parse(f);a.properties[b]=f;a._graph&&a._graph._version++;if(a.onPropertyChanged)a.onPropertyChanged(b, -f);if(d.onclose)d.onclose();p.close();a.setDirtyCanvas(!0,!0)}if(a&&void 0!==a.properties[b]){d=d||{};var c=a.getPropertyInfo(b),h=c.type,k="";if("string"==h||"number"==h||"array"==h||"object"==h)k="";else if("enum"==h&&c.values){var k=""}else if("boolean"== -h)k="";else{console.warn("unknown type: "+h);return}var p=this.createDialog(""+b+""+k+"",d);if("enum"==h&&c.values){var t=p.querySelector("select");t.addEventListener("change",function(a){f(a.target.value)})}else if("boolean"==h)(t=p.querySelector("input"))&&t.addEventListener("click",function(a){f(!!t.checked)});else if(t=p.querySelector("input"))t.addEventListener("blur", -function(a){this.focus()}),e=void 0!==a.properties[b]?a.properties[b]:"",e=JSON.stringify(e),t.value=e,t.addEventListener("keydown",function(a){13==a.keyCode&&(g(),a.preventDefault(),a.stopPropagation())});p.querySelector("button").addEventListener("click",g);return p}};e.prototype.createDialog=function(a,b){b=b||{};var d=document.createElement("div");d.className="graphdialog";d.innerHTML=a;var g=this.canvas.getBoundingClientRect(),f=-20,c=-20;g&&(f-=g.left,c-=g.top);b.position?(f+=b.position[0], +b.configure(d.data.json)}}q.close()}function d(a){var b=y;y&&y.classList.remove("selected");y?(y=a?y.nextSibling:y.previousSibling)||(y=b):y=a?z.childNodes[0]:z.childNodes[z.childNodes.length];y&&(y.classList.add("selected"),y.scrollIntoView({block:"end",behavior:"smooth"}))}function g(){function a(d,f){var g=document.createElement("div");t||(t=d);g.innerText=d;g.dataset.type=escape(d);g.className="litegraph lite-search-item";f&&(g.className+=" "+f);g.addEventListener("click",function(a){b(unescape(this.dataset.type))}); +z.appendChild(g)}n=null;var d=u.value;t=null;z.innerHTML="";if(d)if(f.onSearchBox){var g=f.onSearchBox(z,d,c);if(g)for(var k=0;ke.search_limit)break}}s=null;if(Array.prototype.filter)s=Object.keys(h.registered_node_types).filter(l); +else for(k in s=[],h.registered_node_types)l(k)&&s.push(k);for(k=0;ke.search_limit);k++);var l=function(a){var b=h.registered_node_types[a];return p&&b.filter!=p?!1:-1!==a.toLowerCase().indexOf(d)}}}var f=this,c=e.active_canvas,k=c.canvas,p=k.ownerDocument||document,q=document.createElement("div");q.className="litegraph litesearchbox graphdialog rounded";q.innerHTML="Search
"; +q.close=function(){f.search_box=null;p.body.focus();p.body.style.overflow="";setTimeout(function(){f.canvas.focus()},20);q.parentNode&&q.parentNode.removeChild(q)};var l=null;1k.height-200&&(z.style.maxHeight=k.height-a.layerY-20+"px");u.focus();return q};e.prototype.showEditPropertyValue=function(a,b,d){function g(){f(t.value)}function f(f){"number"==typeof a.properties[b]&&(f=Number(f));if("array"==h||"object"==h)f=JSON.parse(f);a.properties[b]=f;a._graph&&a._graph._version++;if(a.onPropertyChanged)a.onPropertyChanged(b, +f);if(d.onclose)d.onclose();e.close();a.setDirtyCanvas(!0,!0)}if(a&&void 0!==a.properties[b]){d=d||{};var c=a.getPropertyInfo(b),h=c.type,k="";if("string"==h||"number"==h||"array"==h||"object"==h)k="";else if("enum"==h&&c.values){var k=""}else if("boolean"== +h)k="";else{console.warn("unknown type: "+h);return}var e=this.createDialog(""+b+""+k+"",d);if("enum"==h&&c.values){var t=e.querySelector("select");t.addEventListener("change",function(a){f(a.target.value)})}else if("boolean"==h)(t=e.querySelector("input"))&&t.addEventListener("click",function(a){f(!!t.checked)});else if(t=e.querySelector("input"))t.addEventListener("blur", +function(a){this.focus()}),q=void 0!==a.properties[b]?a.properties[b]:"",q=JSON.stringify(q),t.value=q,t.addEventListener("keydown",function(a){13==a.keyCode&&(g(),a.preventDefault(),a.stopPropagation())});e.querySelector("button").addEventListener("click",g);return e}};e.prototype.createDialog=function(a,b){b=b||{};var d=document.createElement("div");d.className="graphdialog";d.innerHTML=a;var g=this.canvas.getBoundingClientRect(),f=-20,c=-20;g&&(f-=g.left,c-=g.top);b.position?(f+=b.position[0], c+=b.position[1]):b.event?(f+=b.event.clientX,c+=b.event.clientY):(f+=0.5*this.canvas.width,c+=0.5*this.canvas.height);d.style.left=f+"px";d.style.top=c+"px";this.canvas.parentNode.appendChild(d);d.close=function(){this.parentNode&&this.parentNode.removeChild(this)};return d};e.onMenuNodeCollapse=function(a,b,d,g,f){f.collapse()};e.onMenuNodePin=function(a,b,d,g,f){f.pin()};e.onMenuNodeMode=function(a,b,d,g,f){new h.ContextMenu(["Always","On Event","On Trigger","Never"],{event:d,callback:function(a){if(f)switch(a){case "On Event":f.mode= h.ON_EVENT;break;case "On Trigger":f.mode=h.ON_TRIGGER;break;case "Never":f.mode=h.NEVER;break;default:f.mode=h.ALWAYS}},parentMenu:g,node:f});return!1};e.onMenuNodeColors=function(a,b,d,g,f){if(!f)throw"no node for color";b=[];b.push({value:null,content:"No color"});for(var c in e.node_colors)a=e.node_colors[c],a={value:c,content:""+c+""},b.push(a);new h.ContextMenu(b,{event:d,callback:function(a){f&&((a=a.value?e.node_colors[a.value]:null)?f.constructor===h.LGraphGroup?f.color=a.groupcolor:(f.color=a.color,f.bgcolor=a.bgcolor):(delete f.color,delete f.bgcolor),f.setDirtyCanvas(!0,!0))},parentMenu:g,node:f});return!1};e.onMenuNodeShapes=function(a,b,d,g,f){if(!f)throw"no node passed";new h.ContextMenu(h.VALID_SHAPES,{event:d,callback:function(a){f&&(f.shape=a,f.setDirtyCanvas(!0))},parentMenu:g,node:f}); @@ -227,8 +227,8 @@ callback:e.onShowMenuNodeProperties},null,{content:"Title",callback:e.onShowProp (d=a.onGetOutputs())&&d.length&&(b[1].disabled=!1);a.getExtraMenuOptions&&(d=a.getExtraMenuOptions(this))&&(d.push(null),b=d.concat(b));!1!==a.clonable&&b.push({content:"Clone",callback:e.onMenuNodeClone});!1!==a.removable&&b.push(null,{content:"Remove",callback:e.onMenuNodeRemove});if(a.graph&&a.graph.onGetNodeMenuOptions)a.graph.onGetNodeMenuOptions(b,a);return b};e.prototype.getGroupMenuOptions=function(a){return[{content:"Title",callback:e.onShowPropertyEditor},{content:"Color",has_submenu:!0, callback:e.onMenuNodeColors},{content:"Font size",property:"font_size",type:"Number",callback:e.onShowPropertyEditor},null,{content:"Remove",callback:e.onMenuNodeRemove}]};e.prototype.processContextMenu=function(a,b){var d=this,g=e.active_canvas.getCanvasWindow(),f=null,c={event:b,callback:function(b,f,g){if(b)if("Remove Slot"==b.content)b=b.slot,b.input?a.removeInput(b.slot):b.output&&a.removeOutput(b.slot);else if("Disconnect Links"==b.content)b=b.slot,b.output?a.disconnectOutput(b.slot):b.input&& a.disconnectInput(b.slot);else if("Rename Slot"==b.content){b=b.slot;var c=b.input?a.getInputInfo(b.slot):a.getOutputInfo(b.slot),h=d.createDialog("Name",f),k=h.querySelector("input");k&&c&&(k.value=c.label||"");h.querySelector("button").addEventListener("click",function(a){k.value&&(c&&(c.label=k.value),d.setDirty(!0));h.close()})}},extra:a};a&&(c.title=a.type);var k=null;a&&(k=a.getSlotInPosition(b.canvasX,b.canvasY),e.active_node= -a);if(k){f=[];k&&k.output&&k.output.links&&k.output.links.length&&f.push({content:"Disconnect Links",slot:k});var q=k.input||k.output;f.push(q.locked?"Cannot remove":{content:"Remove Slot",slot:k});f.push(q.nameLocked?"Cannot rename":{content:"Rename Slot",slot:k});c.title=(k.input?k.input.type:k.output.type)||"*";k.input&&k.input.type==h.ACTION&&(c.title="Action");k.output&&k.output.type==h.EVENT&&(c.title="Event")}else a?f=this.getNodeMenuOptions(a):(f=this.getCanvasMenuOptions(),(k=this.graph.getGroupOnPos(b.canvasX, -b.canvasY))&&f.push(null,{content:"Edit Group",has_submenu:!0,submenu:{title:"Group",extra:k,options:this.getGroupMenuOptions(k)}}));f&&new h.ContextMenu(f,c,g)};this.CanvasRenderingContext2D&&(CanvasRenderingContext2D.prototype.roundRect=function(a,b,d,g,f,c){void 0===f&&(f=5);void 0===c&&(c=f);this.moveTo(a+f,b);this.lineTo(a+d-f,b);this.quadraticCurveTo(a+d,b,a+d,b+f);this.lineTo(a+d,b+g-c);this.quadraticCurveTo(a+d,b+g,a+d-c,b+g);this.lineTo(a+c,b+g);this.quadraticCurveTo(a,b+g,a,b+g-c);this.lineTo(a, +a);if(k){f=[];k&&k.output&&k.output.links&&k.output.links.length&&f.push({content:"Disconnect Links",slot:k});var p=k.input||k.output;f.push(p.locked?"Cannot remove":{content:"Remove Slot",slot:k});f.push(p.nameLocked?"Cannot rename":{content:"Rename Slot",slot:k});c.title=(k.input?k.input.type:k.output.type)||"*";k.input&&k.input.type==h.ACTION&&(c.title="Action");k.output&&k.output.type==h.EVENT&&(c.title="Event")}else a?f=this.getNodeMenuOptions(a):(f=this.getCanvasMenuOptions(),(k=this.graph.getGroupOnPos(b.canvasX, +b.canvasY))&&f.push(null,{content:"Edit Group",has_submenu:!0,submenu:{title:"Group",extra:k,options:this.getGroupMenuOptions(k)}}));f&&new h.ContextMenu(f,c,g)};B.CanvasRenderingContext2D&&(B.CanvasRenderingContext2D.prototype.roundRect=function(a,b,d,g,f,c){void 0===f&&(f=5);void 0===c&&(c=f);this.moveTo(a+f,b);this.lineTo(a+d-f,b);this.quadraticCurveTo(a+d,b,a+d,b+f);this.lineTo(a+d,b+g-c);this.quadraticCurveTo(a+d,b+g,a+d-c,b+g);this.lineTo(a+c,b+g);this.quadraticCurveTo(a,b+g,a,b+g-c);this.lineTo(a, b+f);this.quadraticCurveTo(a,b,a+f,b)});h.compareObjects=function(a,b){for(var d in a)if(a[d]!=b[d])return!1;return!0};h.distance=C;h.colorToString=function(a){return"rgba("+Math.round(255*a[0]).toFixed()+","+Math.round(255*a[1]).toFixed()+","+Math.round(255*a[2]).toFixed()+","+(4==a.length?a[3].toFixed(2):"1.0")+")"};h.isInsideRectangle=w;h.growBounding=function(a,b,d){ba[2]&&(a[2]=b);da[3]&&(a[3]=d)};h.isInsideBounding=function(a,b){return a[0]b[1][0]||a[1]>b[1][1]?!1:!0};h.overlapBounding=u;h.hex2num=function(a){"#"==a.charAt(0)&&(a=a.slice(1));a=a.toUpperCase();for(var b=Array(3),d=0,g,f,c=0;6>c;c+=2)g="0123456789ABCDEF".indexOf(a.charAt(c)),f="0123456789ABCDEF".indexOf(a.charAt(c+1)),b[d]=16*g+f,d++;return b};h.num2hex=function(a){for(var b="#",d,g,f=0;3>f;f++)d=a[f]/16,g=a[f]%16,b+="0123456789ABCDEF".charAt(d)+"0123456789ABCDEF".charAt(g);return b};D.prototype.addItem=function(a,b,d){function g(a){var b=this.value;b&&b.has_submenu&& f.call(this,a)}function f(a){var b=this.value,f=!0;c.current_submenu&&c.current_submenu.close(a);if(d.callback){var g=d.callback.call(this,b,d,a,c,d.node);!0===g&&(f=!1)}if(b&&(b.callback&&!d.ignore_item_callbacks&&!0!==b.disabled&&(g=b.callback.call(this,b,d,a,c,d.extra),!0===g&&(f=!1)),b.submenu)){if(!b.submenu.options)throw"ContextMenu submenu needs options";new c.constructor(b.submenu.options,{callback:b.submenu.callback,event:a,parentMenu:c,ignore_item_callbacks:b.submenu.ignore_item_callbacks, @@ -240,7 +240,7 @@ b){var d=a.clientX,g=a.clientY,f=b.getBoundingClientRect();return f?g>f.top&&ga[1])){var g=this.size[0]-2*this.margin,f=this.size[1]-2*this.margin,c=a[0]-this.margin,h=a[1]-this.margin;this.selected=this.getCloserPoint([c,h],30/b.ds.scale);-1==this.selected&&(g=[c/g,1-h/f],d.push(g),d.sort(function(a,b){return a[0]-b[0]}),this.selected=d.indexOf(g),this.must_update=!0);if(-1!=this.selected)return!0}};A.prototype.onMouseMove=function(a,b){var d=this.points;if(d){var g= this.selected;if(!(0>g)){var f=(a[0]-this.margin)/(this.size[0]-2*this.margin),c=(a[1]-this.margin)/(this.size[1]-2*this.margin);this._nearest=this.getCloserPoint([a[0]-this.margin,a[1]-this.margin],30/b.ds.scale);var h=d[g];if(h){var k=0==g||g==d.length-1;!k&&(-10>a[0]||a[0]>this.size[0]+10||-10>a[1]||a[1]>this.size[1]+10)?(d.splice(g,1),this.selected=-1):(h[0]=k?0==g?0:1:Math.clamp(f,0,1),h[1]=1-Math.clamp(c,0,1),d.sort(function(a,b){return a[0]-b[0]}),this.selected=d.indexOf(h),this.must_update= -!0)}}}};A.prototype.onMouseUp=function(a,b){this.selected=-1;return!1};A.prototype.getCloserPoint=function(a,b){var d=this.points;if(!d)return-1;b=b||30;for(var g=this.size[0]-2*this.margin,f=this.size[1]-2*this.margin,c=d.length,h=[0,0],k=1E6,q=-1,e=0;ek||p>b||(q=e,k=p)}return q};h.CurveEditor=A;h.getParameterNames=function(a){return(a+"").replace(/[/][/].*$/gm,"").replace(/\s+/g,"").replace(/[/][*][^/*]*[*][/]/g,"").split("){", +!0)}}}};A.prototype.onMouseUp=function(a,b){this.selected=-1;return!1};A.prototype.getCloserPoint=function(a,b){var d=this.points;if(!d)return-1;b=b||30;for(var g=this.size[0]-2*this.margin,f=this.size[1]-2*this.margin,c=d.length,h=[0,0],k=1E6,p=-1,q=0;qk||e>b||(p=q,k=e)}return p};h.CurveEditor=A;h.getParameterNames=function(a){return(a+"").replace(/[/][/].*$/gm,"").replace(/\s+/g,"").replace(/[/][*][^/*]*[*][/]/g,"").split("){", 1)[0].replace(/^[^(]*[(]/,"").replace(/=[^,]+/g,"").split(",").filter(Boolean)};Math.clamp=function(a,b,d){return b>a?b:dthis.size[0]-g.NODE_TITLE_HEIGHT&&0>b[1]){var c=this;setTimeout(function(){d.openSubgraph(c.subgraph)},10)}};m.prototype.onAction=function(a,b){this.subgraph.onAction(a,b)};m.prototype.onExecute=function(){if(this.enabled= @@ -272,10 +272,10 @@ u.prototype.onPropertyChanged=function(a,b){this.widget.value=b;if(null!=b&&""!= a[Math.floor(Number(b))])};g.registerNodeType("basic/array[]",A);h.title="Table[row][col]";h.desc="Returns an element from a table";h.prototype.onExecute=function(){var a=this.getInputData(0),b=this.getInputData(1),d=this.getInputData(2);null==b&&(b=this.properties.row);null==d&&(d=this.properties.column);null!=a&&null!=b&&null!=d&&((b=a[Math.floor(Number(b))])?this.setOutputData(0,b[Math.floor(Number(d))]):this.setOutputData(0,null))};g.registerNodeType("basic/table[][]",h);z.title="Object property"; z.desc="Outputs the property of an object";z.prototype.setValue=function(a){this.properties.value=a;this.widget.value=a};z.prototype.getTitle=function(){return this.flags.collapsed?"in."+this.properties.value:this.title};z.prototype.onPropertyChanged=function(a,b){this.widget.value=b};z.prototype.onExecute=function(){var a=this.getInputData(0);null!=a&&this.setOutputData(0,a[this.properties.value])};g.registerNodeType("basic/object_property",z);y.title="Object keys";y.desc="Outputs an array with the keys of an object"; y.prototype.onExecute=function(){var a=this.getInputData(0);null!=a&&this.setOutputData(0,Object.keys(a))};g.registerNodeType("basic/object_keys",y);v.title="Merge Objects";v.desc="Creates an object copying properties from others";v.prototype.onExecute=function(){var a=this.getInputData(0),b=this.getInputData(1),d=this._result;if(a)for(var g in a)d[g]=a[g];if(b)for(g in b)d[g]=b[g];this.setOutputData(0,d)};g.registerNodeType("basic/merge_objects",v);G.title="Variable";G.desc="store/read variable value"; -G.prototype.onExecute=function(){this.value=this.getInputData(0);this.graph&&(this.graph.vars[this.properties.varname]=this.value);this.properties.global&&(B[this.properties.varname]=this.value);this.setOutputData(0,this.value)};G.prototype.getTitle=function(){return this.properties.varname};g.registerNodeType("basic/variable",G);g.wrapFunctionAsNode("basic/length",function(a){return a&&null!=a.length?Number(a.length):0},["*"],"number");q.title="Download";q.desc="Download some data";q.prototype.downloadAsFile= -function(){if(null!=this.value){var a=null,a=this.value.constructor===String?this.value:JSON.stringify(this.value),a=new Blob([a]),b=URL.createObjectURL(a),a=document.createElement("a");a.setAttribute("href",b);a.setAttribute("download",this.properties.filename);a.style.display="none";document.body.appendChild(a);a.click();document.body.removeChild(a);setTimeout(function(){URL.revokeObjectURL(b)},6E4)}};q.prototype.onAction=function(a,b){var d=this;setTimeout(function(){d.downloadAsFile()},100)}; -q.prototype.onExecute=function(){this.inputs[0]&&(this.value=this.getInputData(0))};q.prototype.getTitle=function(){return this.flags.collapsed?this.properties.filename:this.title};g.registerNodeType("basic/download",q);p.title="Watch";p.desc="Show value of input";p.prototype.onExecute=function(){this.inputs[0]&&(this.value=this.getInputData(0))};p.prototype.getTitle=function(){return this.flags.collapsed?this.inputs[0].label:this.title};p.toString=function(a){if(null==a)return"null";if(a.constructor=== -Number)return a.toFixed(3);if(a.constructor===Array){for(var b="[",d=0;d","enum",{values:a.values});this.size=[80,60]}function b(){this.addInput("inc","number");this.addOutput("total","number");this.addProperty("increment",1);this.addProperty("value",0)}function d(){this.addInput("v","number");this.addOutput("sin","number");this.addProperty("amplitude", 1);this.addProperty("offset",0);this.bgImageUrl="nodes/imgs/icon-sin.png"}function g(){this.addInput("x","number");this.addInput("y","number");this.addOutput("","number");this.properties={x:1,y:1,formula:"x+y"};this.code_widget=this.addWidget("text","F(x,y)",this.properties.formula,function(a,b,d){d.properties.formula=a});this.addWidget("toggle","allow",E.allow_scripts,function(a){E.allow_scripts=a});this._func=null}function f(){this.addInput("vec2","vec2");this.addOutput("x","number");this.addOutput("y", "number")}function r(){this.addInputs([["x","number"],["y","number"]]);this.addOutput("vec2","vec2");this.properties={x:0,y:0};this._data=new Float32Array(2)}function s(){this.addInput("vec3","vec3");this.addOutput("x","number");this.addOutput("y","number");this.addOutput("z","number")}function I(){this.addInputs([["x","number"],["y","number"],["z","number"]]);this.addOutput("vec3","vec3");this.properties={x:0,y:0,z:0};this._data=new Float32Array(3)}function J(){this.addInput("vec4","vec4");this.addOutput("x", @@ -347,10 +347,10 @@ null!=a&&(a=Math.max(this.properties.min,a),a=Math.min(this.properties.max,a),th (d=c);this.setOutputData(0,a*(1-d)+b*d)};u.prototype.onGetInputs=function(){return[["f","number"]]};E.registerNodeType("math/lerp",u);D.title="Abs";D.desc="Absolute";D.prototype.onExecute=function(){var a=this.getInputData(0);null!=a&&this.setOutputData(0,Math.abs(a))};E.registerNodeType("math/abs",D);A.title="Floor";A.desc="Floor number to remove fractional part";A.prototype.onExecute=function(){var a=this.getInputData(0);null!=a&&this.setOutputData(0,Math.floor(a))};E.registerNodeType("math/floor", A);h.title="Frac";h.desc="Returns fractional part";h.prototype.onExecute=function(){var a=this.getInputData(0);null!=a&&this.setOutputData(0,a%1)};E.registerNodeType("math/frac",h);z.title="Smoothstep";z.desc="Smoothstep";z.prototype.onExecute=function(){var a=this.getInputData(0);if(void 0!==a){var b=this.properties.A,a=Math.clamp((a-b)/(this.properties.B-b),0,1);this.setOutputData(0,a*a*(3-2*a))}};E.registerNodeType("math/smoothstep",z);y.title="Scale";y.desc="v * factor";y.prototype.onExecute= function(){var a=this.getInputData(0);null!=a&&this.setOutputData(0,a*this.properties.factor)};E.registerNodeType("math/scale",y);v.title="Gate";v.desc="if v is true, then outputs A, otherwise B";v.prototype.onExecute=function(){var a=this.getInputData(0);this.setOutputData(0,this.getInputData(a?1:2))};E.registerNodeType("math/gate",v);G.title="Average";G.desc="Average Filter";G.prototype.onExecute=function(){var a=this.getInputData(0);null==a&&(a=0);var b=this._values.length;this._values[this._current% -b]=a;this._current+=1;this._current>b&&(this._current=0);for(var d=a=0;db&&(b=1);this.properties.samples=Math.round(b);var d=this._values;this._values=new Float32Array(this.properties.samples);d.length<=this._values.length?this._values.set(d):this._values.set(d.subarray(0,this._values.length))};E.registerNodeType("math/average",G);q.title="TendTo";q.desc="moves the output value always closer to the input"; -q.prototype.onExecute=function(){var a=this.getInputData(0);null==a&&(a=0);var b=this.properties.factor;this._value=null==this._value?a:this._value*(1-b)+a*b;this.setOutputData(0,this._value)};E.registerNodeType("math/tendTo",q);p.values="+ - * / % ^ max min".split(" ");p.title="Operation";p.desc="Easy math operators";p["@OP"]={type:"enum",title:"operation",values:p.values};p.size=[100,60];p.prototype.getTitle=function(){return"max"==this.properties.OP||"min"==this.properties.OP?this.properties.OP+ -"(A,B)":"A "+this.properties.OP+" B"};p.prototype.setValue=function(a){"string"==typeof a&&(a=parseFloat(a));this.properties.value=a};p.prototype.onExecute=function(){var a=this.getInputData(0),b=this.getInputData(1);null!=a?this.properties.A=a:a=this.properties.A;null!=b?this.properties.B=b:b=this.properties.B;var d=0;switch(this.properties.OP){case "+":d=a+b;break;case "-":d=a-b;break;case "x":case "X":case "*":d=a*b;break;case "/":d=a/b;break;case "%":d=a%b;break;case "^":d=Math.pow(a,b);break; -case "max":d=Math.max(a,b);break;case "min":d=Math.min(a,b);break;default:console.warn("Unknown operation: "+this.properties.OP)}this.setOutputData(0,d)};p.prototype.onDrawBackground=function(a){this.flags.collapsed||(a.font="40px Arial",a.fillStyle="#666",a.textAlign="center",a.fillText(this.properties.OP,0.5*this.size[0],0.5*(this.size[1]+E.NODE_TITLE_HEIGHT)),a.textAlign="left")};E.registerNodeType("math/operation",p);E.registerSearchboxExtra("math/operation","MAX",{properties:{OP:"max"},title:"MAX()"}); +b]=a;this._current+=1;this._current>b&&(this._current=0);for(var d=a=0;db&&(b=1);this.properties.samples=Math.round(b);var d=this._values;this._values=new Float32Array(this.properties.samples);d.length<=this._values.length?this._values.set(d):this._values.set(d.subarray(0,this._values.length))};E.registerNodeType("math/average",G);p.title="TendTo";p.desc="moves the output value always closer to the input"; +p.prototype.onExecute=function(){var a=this.getInputData(0);null==a&&(a=0);var b=this.properties.factor;this._value=null==this._value?a:this._value*(1-b)+a*b;this.setOutputData(0,this._value)};E.registerNodeType("math/tendTo",p);q.values="+ - * / % ^ max min".split(" ");q.title="Operation";q.desc="Easy math operators";q["@OP"]={type:"enum",title:"operation",values:q.values};q.size=[100,60];q.prototype.getTitle=function(){return"max"==this.properties.OP||"min"==this.properties.OP?this.properties.OP+ +"(A,B)":"A "+this.properties.OP+" B"};q.prototype.setValue=function(a){"string"==typeof a&&(a=parseFloat(a));this.properties.value=a};q.prototype.onExecute=function(){var a=this.getInputData(0),b=this.getInputData(1);null!=a?this.properties.A=a:a=this.properties.A;null!=b?this.properties.B=b:b=this.properties.B;var d=0;switch(this.properties.OP){case "+":d=a+b;break;case "-":d=a-b;break;case "x":case "X":case "*":d=a*b;break;case "/":d=a/b;break;case "%":d=a%b;break;case "^":d=Math.pow(a,b);break; +case "max":d=Math.max(a,b);break;case "min":d=Math.min(a,b);break;default:console.warn("Unknown operation: "+this.properties.OP)}this.setOutputData(0,d)};q.prototype.onDrawBackground=function(a){this.flags.collapsed||(a.font="40px Arial",a.fillStyle="#666",a.textAlign="center",a.fillText(this.properties.OP,0.5*this.size[0],0.5*(this.size[1]+E.NODE_TITLE_HEIGHT)),a.textAlign="left")};E.registerNodeType("math/operation",q);E.registerSearchboxExtra("math/operation","MAX",{properties:{OP:"max"},title:"MAX()"}); E.registerSearchboxExtra("math/operation","MIN",{properties:{OP:"min"},title:"MIN()"});k.title="Compare";k.desc="compares between two values";k.prototype.onExecute=function(){var a=this.getInputData(0),b=this.getInputData(1);void 0!==a?this.properties.A=a:a=this.properties.A;void 0!==b?this.properties.B=b:b=this.properties.B;for(var d=0,c=this.outputs.length;dB":f= a>b;break;case "A=B":f=a>=b}this.setOutputData(d,f)}}};k.prototype.onGetOutputs=function(){return[["A==B","boolean"],["A!=B","boolean"],["A>B","boolean"],["A=B","boolean"],["A<=B","boolean"]]};E.registerNodeType("math/compare",k);E.registerSearchboxExtra("math/compare","==",{outputs:[["A==B","boolean"]],title:"A==B"});E.registerSearchboxExtra("math/compare","!=",{outputs:[["A!=B","boolean"]],title:"A!=B"});E.registerSearchboxExtra("math/compare", ">",{outputs:[["A>B","boolean"]],title:"A>B"});E.registerSearchboxExtra("math/compare","<",{outputs:[["A=",{outputs:[["A>=B","boolean"]],title:"A>=B"});E.registerSearchboxExtra("math/compare","<=",{outputs:[["A<=B","boolean"]],title:"A<=B"});a.values="> < == != <= >= || &&".split(" ");a["@OP"]={type:"enum",title:"operation",values:a.values};a.title="Condition";a.desc="evaluates condition between A and B";a.prototype.getTitle= @@ -391,19 +391,19 @@ m.desc="select one element from a sequence from a string";m.prototype.onProperty "image"],["img2","image"],["fade","number"]]);this.addOutput("","image");this.properties={fade:0.5,width:512,height:512}}function e(){this.addInput("","image");this.addOutput("","image");this.properties={width:256,height:256,x:0,y:0,scale:1};this.size=[50,20]}function C(){this.addInput("clear",h.ACTION);this.addOutput("","canvas");this.properties={width:512,height:512,autoclear:!0};this.canvas=document.createElement("canvas");this.ctx=this.canvas.getContext("2d")}function w(){this.addInput("canvas", "canvas");this.addInput("img","image,canvas");this.addInput("x","number");this.addInput("y","number");this.properties={x:0,y:0,opacity:1}}function u(){this.addInput("canvas","canvas");this.addInput("x","number");this.addInput("y","number");this.addInput("w","number");this.addInput("h","number");this.properties={x:0,y:0,w:10,h:10,color:"white",opacity:1}}function D(){this.addInput("t","number");this.addOutputs([["frame","image"],["t","number"],["d","number"]]);this.properties={url:"",use_proxy:!0}} function A(){this.addOutput("Webcam","image");this.properties={facingMode:"user"};this.boxcolor="black";this.frame=0}var h=B.LiteGraph;c.title="Plot";c.desc="Plots data over time";c.colors=["#FFF","#F99","#9F9","#99F"];c.prototype.onExecute=function(c){if(!this.flags.collapsed){c=this.size;for(var e=0;4>e;++e){var h=this.getInputData(e);if(null!=h){var l=this.values[e];l.push(h);l.length>c[0]&&l.shift()}}}};c.prototype.onDrawBackground=function(e){if(!this.flags.collapsed){var h=this.size,l=0.5*h[1]/ -this.properties.scale,n=c.colors,q=0.5*h[1];e.fillStyle="#000";e.fillRect(0,0,h[0],h[1]);e.strokeStyle="#555";e.beginPath();e.moveTo(0,q);e.lineTo(h[0],q);e.stroke();if(this.inputs)for(var p=0;4>p;++p){var k=this.values[p];if(this.inputs[p]&&this.inputs[p].link){e.strokeStyle=n[p];e.beginPath();var a=k[0]*l*-1+q;e.moveTo(0,Math.clamp(a,0,h[1]));for(var b=1;bq;++q){var k=this.values[q];if(this.inputs[q]&&this.inputs[q].link){e.strokeStyle=n[q];e.beginPath();var a=k[0]*l*-1+p;e.moveTo(0,Math.clamp(a,0,h[1]));for(var b=1;be&&(e=0);if(0!=c.length){var h=[0,0,0];if(0==e)h=c[0];else if(1==e)h=c[c.length-1];else{var l= -(c.length-1)*e,e=c[Math.floor(l)],c=c[Math.floor(l)+1],l=l-Math.floor(l);h[0]=e[0]*(1-l)+c[0]*l;h[1]=e[1]*(1-l)+c[1]*l;h[2]=e[2]*(1-l)+c[2]*l}for(var q in h)h[q]/=255;this.boxcolor=colorToString(h);this.setOutputData(0,h)}};h.registerNodeType("color/palette",n);l.title="Frame";l.desc="Frame viewerew";l.widgets=[{name:"resize",text:"Resize box",type:"button"},{name:"view",text:"View Image",type:"button"}];l.prototype.onDrawBackground=function(c){this.frame&&!this.flags.collapsed&&c.drawImage(this.frame, +(c.length-1)*e,e=c[Math.floor(l)],c=c[Math.floor(l)+1],l=l-Math.floor(l);h[0]=e[0]*(1-l)+c[0]*l;h[1]=e[1]*(1-l)+c[1]*l;h[2]=e[2]*(1-l)+c[2]*l}for(var p in h)h[p]/=255;this.boxcolor=colorToString(h);this.setOutputData(0,h)}};h.registerNodeType("color/palette",n);l.title="Frame";l.desc="Frame viewerew";l.widgets=[{name:"resize",text:"Resize box",type:"button"},{name:"view",text:"View Image",type:"button"}];l.prototype.onDrawBackground=function(c){this.frame&&!this.flags.collapsed&&c.drawImage(this.frame, 0,0,this.size[0],this.size[1])};l.prototype.onExecute=function(){this.frame=this.getInputData(0);this.setDirtyCanvas(!0)};l.prototype.onWidget=function(c,e){if("resize"==e.name&&this.frame){var h=this.frame.width,l=this.frame.height;h||null==this.frame.videoWidth||(h=this.frame.videoWidth,l=this.frame.videoHeight);h&&l&&(this.size=[h,l]);this.setDirtyCanvas(!0,!0)}else"view"==e.name&&this.show()};l.prototype.show=function(){showElement&&this.frame&&showElement(this.frame)};h.registerNodeType("graphics/frame", l);x.title="Image fade";x.desc="Fades between images";x.widgets=[{name:"resizeA",text:"Resize to A",type:"button"},{name:"resizeB",text:"Resize to B",type:"button"}];x.prototype.onAdded=function(){this.createCanvas();var c=this.canvas.getContext("2d");c.fillStyle="#000";c.fillRect(0,0,this.properties.width,this.properties.height)};x.prototype.createCanvas=function(){this.canvas=document.createElement("canvas");this.canvas.width=this.properties.width;this.canvas.height=this.properties.height};x.prototype.onExecute= function(){var c=this.canvas.getContext("2d");this.canvas.width=this.canvas.width;var e=this.getInputData(0);null!=e&&c.drawImage(e,0,0,this.canvas.width,this.canvas.height);e=this.getInputData(2);null==e?e=this.properties.fade:this.properties.fade=e;c.globalAlpha=e;e=this.getInputData(1);null!=e&&c.drawImage(e,0,0,this.canvas.width,this.canvas.height);c.globalAlpha=1;this.setOutputData(0,this.canvas);this.setDirtyCanvas(!0)};h.registerNodeType("graphics/imagefade",x);e.title="Crop";e.desc="Crop Image"; e.prototype.onAdded=function(){this.createCanvas()};e.prototype.createCanvas=function(){this.canvas=document.createElement("canvas");this.canvas.width=this.properties.width;this.canvas.height=this.properties.height};e.prototype.onExecute=function(){var c=this.getInputData(0);c&&(c.width?(this.canvas.getContext("2d").drawImage(c,-this.properties.x,-this.properties.y,c.width*this.properties.scale,c.height*this.properties.scale),this.setOutputData(0,this.canvas)):this.setOutputData(0,null))};e.prototype.onDrawBackground= function(c){this.flags.collapsed||this.canvas&&c.drawImage(this.canvas,0,0,this.canvas.width,this.canvas.height,0,0,this.size[0],this.size[1])};e.prototype.onPropertyChanged=function(c,e){this.properties[c]=e;"scale"==c?(this.properties[c]=parseFloat(e),0==this.properties[c]&&(console.error("Error in scale"),this.properties[c]=1)):this.properties[c]=parseInt(e);this.createCanvas();return!0};h.registerNodeType("graphics/cropImage",e);C.title="Canvas";C.desc="Canvas to render stuff";C.prototype.onExecute= function(){var c=this.canvas,e=this.properties.width|0,h=this.properties.height|0;c.width!=e&&(c.width=e);c.height!=h&&(c.height=h);this.properties.autoclear&&this.ctx.clearRect(0,0,c.width,c.height);this.setOutputData(0,c)};C.prototype.onAction=function(c,e){"clear"==c&&this.ctx.clearRect(0,0,this.canvas.width,this.canvas.height)};h.registerNodeType("graphics/canvas",C);w.title="DrawImage";w.desc="Draws image into a canvas";w.prototype.onExecute=function(){var c=this.getInputData(0);if(c){var e= -this.getInputOrProperty("img");if(e){var h=this.getInputOrProperty("x"),l=this.getInputOrProperty("y");c.getContext("2d").drawImage(e,h,l)}}};h.registerNodeType("graphics/drawImage",w);u.title="DrawRectangle";u.desc="Draws rectangle in canvas";u.prototype.onExecute=function(){var c=this.getInputData(0);if(c){var e=this.getInputOrProperty("x"),h=this.getInputOrProperty("y"),l=this.getInputOrProperty("w"),q=this.getInputOrProperty("h");c.getContext("2d").fillRect(e,h,l,q)}};h.registerNodeType("graphics/drawRectangle", +this.getInputOrProperty("img");if(e){var h=this.getInputOrProperty("x"),l=this.getInputOrProperty("y");c.getContext("2d").drawImage(e,h,l)}}};h.registerNodeType("graphics/drawImage",w);u.title="DrawRectangle";u.desc="Draws rectangle in canvas";u.prototype.onExecute=function(){var c=this.getInputData(0);if(c){var e=this.getInputOrProperty("x"),h=this.getInputOrProperty("y"),l=this.getInputOrProperty("w"),p=this.getInputOrProperty("h");c.getContext("2d").fillRect(e,h,l,p)}};h.registerNodeType("graphics/drawRectangle", u);D.title="Video";D.desc="Video playback";D.widgets=[{name:"play",text:"PLAY",type:"minibutton"},{name:"stop",text:"STOP",type:"minibutton"},{name:"demo",text:"Demo video",type:"button"},{name:"mute",text:"Mute video",type:"button"}];D.prototype.onExecute=function(){if(this.properties.url&&(this.properties.url!=this._video_url&&this.loadVideo(this.properties.url),this._video&&0!=this._video.width)){var c=this.getInputData(0);c&&0<=c&&1>=c&&(this._video.currentTime=c*this._video.duration,this._video.pause()); this._video.dirty=!0;this.setOutputData(0,this._video);this.setOutputData(1,this._video.currentTime);this.setOutputData(2,this._video.duration);this.setDirtyCanvas(!0)}};D.prototype.onStart=function(){this.play()};D.prototype.onStop=function(){this.stop()};D.prototype.loadVideo=function(c){this._video_url=c;var e=c.substr(0,10).indexOf(":"),l="";-1!=e&&(l=c.substr(0,e));e="";l&&(e=c.substr(0,c.indexOf("/",l.length+3)),e=e.substr(l.length+3));this.properties.use_proxy&&l&&h.proxy&&e!=location.host&& (c=h.proxy+c.substr(c.indexOf(":")+3));this._video=document.createElement("video");this._video.src=c;this._video.type="type=video/mp4";this._video.muted=!0;this._video.autoplay=!0;var n=this;this._video.addEventListener("loadedmetadata",function(c){console.log("Duration: "+this.duration+" seconds");console.log("Size: "+this.videoWidth+","+this.videoHeight);n.setDirtyCanvas(!0);this.width=this.videoWidth;this.height=this.videoHeight});this._video.addEventListener("progress",function(c){console.log("video loading...")}); @@ -421,7 +421,7 @@ function C(){this.addInput("in","Texture");this.addInput("warp","Texture");this. "Texture");this.addOutput("","Texture");this.properties={size:0,generate_mipmaps:!1,precision:c.DEFAULT}}function D(){this.addInput("Texture","Texture");this.addOutput("","Texture");this.properties={iterations:1,generate_mipmaps:!1,precision:c.DEFAULT}}function A(){this.addInput("Texture","Texture");this.addOutput("tex","Texture");this.addOutput("avg","vec4");this.addOutput("lum","number");this.properties={use_previous_frame:!0,high_quality:!1};this._uniforms={u_texture:0,u_mipmap_offset:0};this._luminance= new Float32Array(4)}function h(){this.addInput("Texture","Texture");this.addOutput("min_t","Texture");this.addOutput("max_t","Texture");this.addOutput("min","vec4");this.addOutput("max","vec4");this.properties={mode:"max",use_previous_frame:!0};this._uniforms={u_texture:0};this._max=new Float32Array(4);this._min=new Float32Array(4);this._textures_chain=[]}function z(){this.addInput("in","Texture");this.addInput("factor","Number");this.addOutput("out","Texture");this.properties={factor:0.5};this._uniforms= {u_texture:0,u_textureB:1,u_factor:this.properties.factor}}function y(){this.addInput("in","Texture");this.addOutput("avg","Texture");this.addOutput("array","Texture");this.properties={samples:64,frames_interval:1};this._uniforms={u_texture:0,u_textureB:1,u_samples:this.properties.samples,u_isamples:1/this.properties.samples};this.frame=0}function v(){this.addInput("Image","image");this.addOutput("","Texture");this.properties={}}function G(){this.addInput("Texture","Texture");this.addInput("LUT", -"Texture");this.addInput("Intensity","number");this.addOutput("","Texture");this.properties={enabled:!0,intensity:1,precision:c.DEFAULT,texture:null};G._shader||(G._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,G.pixel_shader))}function q(){this.addInput("Texture","Texture");this.addOutput("R","Texture");this.addOutput("G","Texture");this.addOutput("B","Texture");this.addOutput("A","Texture");q._shader||(q._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,q.pixel_shader))}function p(){this.addInput("R", +"Texture");this.addInput("Intensity","number");this.addOutput("","Texture");this.properties={enabled:!0,intensity:1,precision:c.DEFAULT,texture:null};G._shader||(G._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,G.pixel_shader))}function p(){this.addInput("Texture","Texture");this.addOutput("R","Texture");this.addOutput("G","Texture");this.addOutput("B","Texture");this.addOutput("A","Texture");p._shader||(p._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,p.pixel_shader))}function q(){this.addInput("R", "Texture");this.addInput("G","Texture");this.addInput("B","Texture");this.addInput("A","Texture");this.addOutput("Texture","Texture");this.properties={precision:c.DEFAULT,R:1,G:1,B:1,A:1};this._color=vec4.create();this._uniforms={u_textureR:0,u_textureG:1,u_textureB:2,u_textureA:3,u_color:this._color}}function k(){this.addOutput("Texture","Texture");this._tex_color=vec4.create();this.properties={color:vec4.create(),precision:c.DEFAULT}}function a(){this.addInput("A","color");this.addInput("B","color"); this.addOutput("Texture","Texture");this.properties={angle:0,scale:1,A:[0,0,0],B:[1,1,1],texture_size:32};a._shader||(a._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,a.pixel_shader));this._uniforms={u_angle:0,u_colorA:vec3.create(),u_colorB:vec3.create()}}function b(){this.addInput("A","Texture");this.addInput("B","Texture");this.addInput("Mixer","Texture");this.addOutput("Texture","Texture");this.properties={factor:0.5,size_from_biggest:!0,invert:!1,precision:c.DEFAULT};this._uniforms={u_textureA:0, u_textureB:1,u_textureMix:2,u_mix:vec4.create()}}function d(){this.addInput("Tex.","Texture");this.addOutput("Edges","Texture");this.properties={invert:!0,threshold:!1,factor:1,precision:c.DEFAULT};d._shader||(d._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,d.pixel_shader))}function g(){this.addInput("Texture","Texture");this.addInput("Distance","number");this.addInput("Range","number");this.addOutput("Texture","Texture");this.properties={distance:100,range:50,only_depth:!1,high_precision:!1}; @@ -445,8 +445,8 @@ F.registerNodeType("texture/preview",m),n.title="Save",n.desc="Save a texture in a),this._texture=a,this.setOutputData(0,a),this.setOutputData(1,this.properties.name))},F.registerNodeType("texture/save",n),l.widgets_info={uvcode:{widget:"code"},pixelcode:{widget:"code"},precision:{widget:"combo",values:c.MODE_VALUES}},l.title="Operation",l.desc="Texture shader operation",l.presets={},l.prototype.getExtraMenuOptions=function(a){var b=this;return[{content:b.properties.show?"Hide Texture":"Show Texture",callback:function(){b.properties.show=!b.properties.show}}]},l.prototype.onPropertyChanged= function(){this.has_error=!1},l.prototype.onDrawBackground=function(a){this.flags.collapsed||20>=this.size[1]||!this.properties.show||!this._tex||this._tex.gl!=a||(a.save(),a.drawImage(this._tex,0,0,this.size[0],this.size[1]),a.restore())},l.prototype.onExecute=function(){var a=this.getInputData(0);if(this.isOutputConnected(0))if(this.properties.precision===c.PASS_THROUGH)this.setOutputData(0,a);else{var b=this.getInputData(1);if(this.properties.uvcode||this.properties.pixelcode){var d=512,g=512; a?(d=a.width,g=a.height):b&&(d=b.width,g=b.height);b||(b=GL.Texture.getWhiteTexture());var f=c.getTextureType(this.properties.precision,a);this._tex=a||this._tex?c.getTargetTexture(a||this._tex,this._tex,this.properties.precision):new GL.Texture(d,g,{type:f,format:gl.RGBA,filter:gl.LINEAR});f="";this.properties.uvcode&&(f="uv = "+this.properties.uvcode,-1!=this.properties.uvcode.indexOf(";")&&(f=this.properties.uvcode));var e="";this.properties.pixelcode&&(e="result = "+this.properties.pixelcode, --1!=this.properties.pixelcode.indexOf(";")&&(e=this.properties.pixelcode));var k=this._shader;if(!(this.has_error||k&&this._shader_code==f+"|"+e)){var h=c.replaceCode(l.pixel_shader,{UV_CODE:f,PIXEL_CODE:e});try{k=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,h),this.boxcolor="#00FF00"}catch(q){GL.Shader.dumpErrorToConsole(q,Shader.SCREEN_VERTEX_SHADER,h);this.boxcolor="#FF0000";this.has_error=!0;return}this._shader=k;this._shader_code=f+"|"+e}if(this._shader){var p=this.getInputData(2);null!=p?this.properties.value= -p:p=parseFloat(this.properties.value);var r=this.graph.getTime();this._tex.drawTo(function(){gl.disable(gl.DEPTH_TEST);gl.disable(gl.CULL_FACE);gl.disable(gl.BLEND);a&&a.bind(0);b&&b.bind(1);var c=Mesh.getScreenQuad();k.uniforms({u_texture:0,u_textureB:1,value:p,texSize:[d,g],time:r}).draw(c)});this.setOutputData(0,this._tex)}}}},l.pixel_shader="precision highp float;\n\t\t\n\t\tuniform sampler2D u_texture;\n\t\tuniform sampler2D u_textureB;\n\t\tvarying vec2 v_coord;\n\t\tuniform vec2 texSize;\n\t\tuniform float time;\n\t\tuniform float value;\n\t\t\n\t\tvoid main() {\n\t\t\tvec2 uv = v_coord;\n\t\t\t{{UV_CODE}};\n\t\t\tvec4 color4 = texture2D(u_texture, uv);\n\t\t\tvec3 color = color4.rgb;\n\t\t\tvec4 color4B = texture2D(u_textureB, uv);\n\t\t\tvec3 colorB = color4B.rgb;\n\t\t\tvec3 result = color;\n\t\t\tfloat alpha = 1.0;\n\t\t\t{{PIXEL_CODE}};\n\t\t\tgl_FragColor = vec4(result, alpha);\n\t\t}\n\t\t", +-1!=this.properties.pixelcode.indexOf(";")&&(e=this.properties.pixelcode));var k=this._shader;if(!(this.has_error||k&&this._shader_code==f+"|"+e)){var h=c.replaceCode(l.pixel_shader,{UV_CODE:f,PIXEL_CODE:e});try{k=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,h),this.boxcolor="#00FF00"}catch(p){GL.Shader.dumpErrorToConsole(p,Shader.SCREEN_VERTEX_SHADER,h);this.boxcolor="#FF0000";this.has_error=!0;return}this._shader=k;this._shader_code=f+"|"+e}if(this._shader){var q=this.getInputData(2);null!=q?this.properties.value= +q:q=parseFloat(this.properties.value);var r=this.graph.getTime();this._tex.drawTo(function(){gl.disable(gl.DEPTH_TEST);gl.disable(gl.CULL_FACE);gl.disable(gl.BLEND);a&&a.bind(0);b&&b.bind(1);var c=Mesh.getScreenQuad();k.uniforms({u_texture:0,u_textureB:1,value:q,texSize:[d,g],time:r}).draw(c)});this.setOutputData(0,this._tex)}}}},l.pixel_shader="precision highp float;\n\t\t\n\t\tuniform sampler2D u_texture;\n\t\tuniform sampler2D u_textureB;\n\t\tvarying vec2 v_coord;\n\t\tuniform vec2 texSize;\n\t\tuniform float time;\n\t\tuniform float value;\n\t\t\n\t\tvoid main() {\n\t\t\tvec2 uv = v_coord;\n\t\t\t{{UV_CODE}};\n\t\t\tvec4 color4 = texture2D(u_texture, uv);\n\t\t\tvec3 color = color4.rgb;\n\t\t\tvec4 color4B = texture2D(u_textureB, uv);\n\t\t\tvec3 colorB = color4B.rgb;\n\t\t\tvec3 result = color;\n\t\t\tfloat alpha = 1.0;\n\t\t\t{{PIXEL_CODE}};\n\t\t\tgl_FragColor = vec4(result, alpha);\n\t\t}\n\t\t", l.registerPreset=function(a,b){l.presets[a]=b},l.registerPreset("",""),l.registerPreset("bypass","color"),l.registerPreset("add","color + colorB * value"),l.registerPreset("substract","(color - colorB) * value"),l.registerPreset("mate","mix( color, colorB, color4B.a * value)"),l.registerPreset("invert","vec3(1.0) - color"),l.registerPreset("multiply","color * colorB * value"),l.registerPreset("divide","(color / colorB) / value"),l.registerPreset("difference","abs(color - colorB) * value"),l.registerPreset("max", "max(color, colorB) * value"),l.registerPreset("min","min(color, colorB) * value"),l.registerPreset("displace","texture2D(u_texture, uv + (colorB.xy - vec2(0.5)) * value).xyz"),l.registerPreset("grayscale","vec3(color.x + color.y + color.z) * value / 3.0"),l.registerPreset("saturation","mix( vec3(color.x + color.y + color.z) / 3.0, color, value )"),l.registerPreset("threshold","vec3(color.x > colorB.x * value ? 1.0 : 0.0,color.y > colorB.y * value ? 1.0 : 0.0,color.z > colorB.z * value ? 1.0 : 0.0)"), l.prototype.onInspect=function(a){var b=this;a.addCombo("Presets","",{values:Object.keys(l.presets),callback:function(d){var c=l.presets[d];c&&(b.setProperty("pixelcode",c),b.title=d,a.refresh())}})},F.registerNodeType("texture/operation",l),x.title="Shader",x.desc="Texture shader",x.widgets_info={code:{type:"code",lang:"glsl"},precision:{widget:"combo",values:c.MODE_VALUES}},x.prototype.onPropertyChanged=function(a,b){if("code"==a){var d=this.getShader();if(d){var c=d.uniformInfo;if(this.inputs)for(var g= @@ -467,7 +467,7 @@ w.gamma_pixel_shader="precision highp float;\n\t\tprecision highp float;\n\t\tva values:c.MODE_VALUES}},u.prototype.onExecute=function(){var a=this.getInputData(0);if((a||this._temp_texture)&&this.isOutputConnected(0)){if(a){var b=a.width,d=a.height;0!=this.properties.size&&(d=b=this.properties.size);var g=this._temp_texture,f=a.type;this.properties.precision===c.LOW?f=gl.UNSIGNED_BYTE:this.properties.precision===c.HIGH&&(f=gl.HIGH_PRECISION_FORMAT);g&&g.width==b&&g.height==d&&g.type==f||(g=gl.LINEAR,this.properties.generate_mipmaps&&isPowerOfTwo(b)&&isPowerOfTwo(d)&&(g=gl.LINEAR_MIPMAP_LINEAR), this._temp_texture=new GL.Texture(b,d,{type:f,format:gl.RGBA,minFilter:g,magFilter:gl.LINEAR}));a.copyTo(this._temp_texture);this.properties.generate_mipmaps&&(this._temp_texture.bind(0),gl.generateMipmap(this._temp_texture.texture_type),this._temp_texture.unbind(0))}this.setOutputData(0,this._temp_texture)}},F.registerNodeType("texture/copy",u),D.title="Downsample",D.desc="Downsample Texture",D.widgets_info={iterations:{type:"number",step:1,precision:0,min:0},precision:{widget:"combo",values:c.MODE_VALUES}}, D.prototype.onExecute=function(){var a=this.getInputData(0);if((a||this._temp_texture)&&this.isOutputConnected(0)&&a&&a.texture_type===GL.TEXTURE_2D)if(1>this.properties.iterations)this.setOutputData(0,a);else{var b=D._shader;b||(D._shader=b=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,D.pixel_shader));var d=a.width|0,g=a.height|0,f=a.type;this.properties.precision===c.LOW?f=gl.UNSIGNED_BYTE:this.properties.precision===c.HIGH&&(f=gl.HIGH_PRECISION_FORMAT);var e=this.properties.iterations||1,k=a,h= -null,l=[],a={type:f,format:a.format},f=vec2.create(),q={u_offset:f};this._texture&&GL.Texture.releaseTemporary(this._texture);for(var p=0;p>1||0;g=g>>1||0;h=GL.Texture.getTemporary(d,g,a);l.push(h);k.setParameter(GL.TEXTURE_MAG_FILTER,GL.NEAREST);k.copyTo(h,b,q);if(1==d&&1==g)break;k=h}this._texture=l.pop();for(p=0;p>1||0;g=g>>1||0;h=GL.Texture.getTemporary(d,g,a);l.push(h);k.setParameter(GL.TEXTURE_MAG_FILTER,GL.NEAREST);k.copyTo(h,b,p);if(1==d&&1==g)break;k=h}this._texture=l.pop();for(q=0;qc;c++)this.isOutputConnected(c)?(this._channels[c]&&this._channels[c].width==a.width&&this._channels[c].height==a.height&&this._channels[c].type==a.type&&this._channels[c].format==b||(this._channels[c]=new GL.Texture(a.width,a.height,{type:a.type,format:b,filter:gl.LINEAR})), -d++):this._channels[c]=null;if(d){gl.disable(gl.BLEND);gl.disable(gl.DEPTH_TEST);for(var g=Mesh.getScreenQuad(),f=q._shader,e=[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],c=0;4>c;c++)this._channels[c]&&(this._channels[c].drawTo(function(){a.bind(0);f.uniforms({u_texture:0,u_mask:e[c]}).draw(g)}),this.setOutputData(c,this._channels[c]))}}},q.pixel_shader="precision highp float;\n\t\tprecision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform sampler2D u_texture;\n\t\tuniform vec4 u_mask;\n\t\t\n\t\tvoid main() {\n\t\t gl_FragColor = vec4( vec3( length( texture2D(u_texture, v_coord) * u_mask )), 1.0 );\n\t\t}\n\t\t", -F.registerNodeType("texture/textureChannels",q),p.title="Channels to Texture",p.desc="Split texture channels",p.widgets_info={precision:{widget:"combo",values:c.MODE_VALUES}},p.prototype.onExecute=function(){var a=c.getWhiteTexture(),b=this.getInputData(0)||a,d=this.getInputData(1)||a,g=this.getInputData(2)||a,f=this.getInputData(3)||a;gl.disable(gl.BLEND);gl.disable(gl.DEPTH_TEST);var e=Mesh.getScreenQuad();p._shader||(p._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,p.pixel_shader));var k=p._shader, -a=Math.max(b.width,d.width,g.width,f.width),h=Math.max(b.height,d.height,g.height,f.height),l=this.properties.precision==c.HIGH?c.HIGH_PRECISION_FORMAT:gl.UNSIGNED_BYTE;this._texture&&this._texture.width==a&&this._texture.height==h&&this._texture.type==l||(this._texture=new GL.Texture(a,h,{type:l,format:gl.RGBA,filter:gl.LINEAR}));a=this._color;a[0]=this.properties.R;a[1]=this.properties.G;a[2]=this.properties.B;a[3]=this.properties.A;var q=this._uniforms;this._texture.drawTo(function(){b.bind(0); -d.bind(1);g.bind(2);f.bind(3);k.uniforms(q).draw(e)});this.setOutputData(0,this._texture)},p.pixel_shader="precision highp float;\n\t\tprecision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform sampler2D u_textureR;\n\t\tuniform sampler2D u_textureG;\n\t\tuniform sampler2D u_textureB;\n\t\tuniform sampler2D u_textureA;\n\t\tuniform vec4 u_color;\n\t\t\n\t\tvoid main() {\n\t\t gl_FragColor = u_color * vec4( \t\t\t\t\ttexture2D(u_textureR, v_coord).r,\t\t\t\t\ttexture2D(u_textureG, v_coord).r,\t\t\t\t\ttexture2D(u_textureB, v_coord).r,\t\t\t\t\ttexture2D(u_textureA, v_coord).r);\n\t\t}\n\t\t", -F.registerNodeType("texture/channelsTexture",p),k.title="Color",k.desc="Generates a 1x1 texture with a constant color",k.widgets_info={precision:{widget:"combo",values:c.MODE_VALUES}},k.prototype.onDrawBackground=function(a){var b=this.properties.color;a.fillStyle="rgb("+Math.floor(255*Math.clamp(b[0],0,1))+","+Math.floor(255*Math.clamp(b[1],0,1))+","+Math.floor(255*Math.clamp(b[2],0,1))+")";this.flags.collapsed?this.boxcolor=a.fillStyle:a.fillRect(0,0,this.size[0],this.size[1])},k.prototype.onExecute= +F.registerNodeType("texture/LUT",G),p.title="Texture to Channels",p.desc="Split texture channels",p.prototype.onExecute=function(){var a=this.getInputData(0);if(a){this._channels||(this._channels=Array(4));for(var b=gl.RGB,d=0,c=0;4>c;c++)this.isOutputConnected(c)?(this._channels[c]&&this._channels[c].width==a.width&&this._channels[c].height==a.height&&this._channels[c].type==a.type&&this._channels[c].format==b||(this._channels[c]=new GL.Texture(a.width,a.height,{type:a.type,format:b,filter:gl.LINEAR})), +d++):this._channels[c]=null;if(d){gl.disable(gl.BLEND);gl.disable(gl.DEPTH_TEST);for(var g=Mesh.getScreenQuad(),f=p._shader,e=[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],c=0;4>c;c++)this._channels[c]&&(this._channels[c].drawTo(function(){a.bind(0);f.uniforms({u_texture:0,u_mask:e[c]}).draw(g)}),this.setOutputData(c,this._channels[c]))}}},p.pixel_shader="precision highp float;\n\t\tprecision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform sampler2D u_texture;\n\t\tuniform vec4 u_mask;\n\t\t\n\t\tvoid main() {\n\t\t gl_FragColor = vec4( vec3( length( texture2D(u_texture, v_coord) * u_mask )), 1.0 );\n\t\t}\n\t\t", +F.registerNodeType("texture/textureChannels",p),q.title="Channels to Texture",q.desc="Split texture channels",q.widgets_info={precision:{widget:"combo",values:c.MODE_VALUES}},q.prototype.onExecute=function(){var a=c.getWhiteTexture(),b=this.getInputData(0)||a,d=this.getInputData(1)||a,g=this.getInputData(2)||a,f=this.getInputData(3)||a;gl.disable(gl.BLEND);gl.disable(gl.DEPTH_TEST);var e=Mesh.getScreenQuad();q._shader||(q._shader=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,q.pixel_shader));var k=q._shader, +a=Math.max(b.width,d.width,g.width,f.width),h=Math.max(b.height,d.height,g.height,f.height),l=this.properties.precision==c.HIGH?c.HIGH_PRECISION_FORMAT:gl.UNSIGNED_BYTE;this._texture&&this._texture.width==a&&this._texture.height==h&&this._texture.type==l||(this._texture=new GL.Texture(a,h,{type:l,format:gl.RGBA,filter:gl.LINEAR}));a=this._color;a[0]=this.properties.R;a[1]=this.properties.G;a[2]=this.properties.B;a[3]=this.properties.A;var p=this._uniforms;this._texture.drawTo(function(){b.bind(0); +d.bind(1);g.bind(2);f.bind(3);k.uniforms(p).draw(e)});this.setOutputData(0,this._texture)},q.pixel_shader="precision highp float;\n\t\tprecision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform sampler2D u_textureR;\n\t\tuniform sampler2D u_textureG;\n\t\tuniform sampler2D u_textureB;\n\t\tuniform sampler2D u_textureA;\n\t\tuniform vec4 u_color;\n\t\t\n\t\tvoid main() {\n\t\t gl_FragColor = u_color * vec4( \t\t\t\t\ttexture2D(u_textureR, v_coord).r,\t\t\t\t\ttexture2D(u_textureG, v_coord).r,\t\t\t\t\ttexture2D(u_textureB, v_coord).r,\t\t\t\t\ttexture2D(u_textureA, v_coord).r);\n\t\t}\n\t\t", +F.registerNodeType("texture/channelsTexture",q),k.title="Color",k.desc="Generates a 1x1 texture with a constant color",k.widgets_info={precision:{widget:"combo",values:c.MODE_VALUES}},k.prototype.onDrawBackground=function(a){var b=this.properties.color;a.fillStyle="rgb("+Math.floor(255*Math.clamp(b[0],0,1))+","+Math.floor(255*Math.clamp(b[1],0,1))+","+Math.floor(255*Math.clamp(b[2],0,1))+")";this.flags.collapsed?this.boxcolor=a.fillStyle:a.fillRect(0,0,this.size[0],this.size[1])},k.prototype.onExecute= function(){var a=this.properties.precision==c.HIGH?c.HIGH_PRECISION_FORMAT:gl.UNSIGNED_BYTE;this._tex&&this._tex.type==a||(this._tex=new GL.Texture(1,1,{format:gl.RGBA,type:a,minFilter:gl.NEAREST}));a=this.properties.color;if(this.inputs)for(var b=0;b>=1;1<(d|0)&&(d>>=1);if(2>b)break;l=k[m]=GL.Texture.getTemporary(b,d,g);r[0]=1/q.width;r[1]=1/q.height;q.blit(l,h.uniforms(e));q=l}this.isOutputConnected(2)&&(b=this._average_texture,b&&b.type==a.type&&b.format==a.format||(b=this._average_texture=new GL.Texture(1,1,{type:a.type,format:a.format,filter:gl.LINEAR})),r[0]=1/q.width,r[1]=1/q.height,e.u_intensity=n,e.u_delta=1,q.blit(b,h.uniforms(e)),this.setOutputData(2,b));gl.enable(gl.BLEND);gl.blendFunc(gl.ONE,gl.ONE);e.u_intensity= -this.getInputOrProperty("persistence");e.u_delta=0.5;for(m-=2;0<=m;m--)l=k[m],k[m]=null,r[0]=1/q.width,r[1]=1/q.height,q.blit(l,h.uniforms(e)),GL.Texture.releaseTemporary(q),q=l;gl.disable(gl.BLEND);this.isOutputConnected(1)&&(k=this._glow_texture,k&&k.width==a.width&&k.height==a.height&&k.type==f&&k.format==a.format||(k=this._glow_texture=new GL.Texture(a.width,a.height,{type:f,format:a.format,filter:gl.LINEAR})),q.blit(k),this.setOutputData(1,k));if(this.isOutputConnected(0)){k=this._final_texture; +h||(h=s._cut_shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,s.cut_pixel_shader));gl.disable(gl.DEPTH_TEST);gl.disable(gl.BLEND);e.u_threshold=this.getInputOrProperty("threshold");var l=k[0]=GL.Texture.getTemporary(b,d,g);a.blit(l,h.uniforms(e));var p=l,q=this.getInputOrProperty("iterations"),q=Math.clamp(q,1,16)|0,r=e.u_texel_size,n=this.getInputOrProperty("intensity");e.u_intensity=1;e.u_delta=this.properties.scale;h=s._shader;h||(h=s._shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,s.scale_pixel_shader)); +for(var m=1;m>=1;1<(d|0)&&(d>>=1);if(2>b)break;l=k[m]=GL.Texture.getTemporary(b,d,g);r[0]=1/p.width;r[1]=1/p.height;p.blit(l,h.uniforms(e));p=l}this.isOutputConnected(2)&&(b=this._average_texture,b&&b.type==a.type&&b.format==a.format||(b=this._average_texture=new GL.Texture(1,1,{type:a.type,format:a.format,filter:gl.LINEAR})),r[0]=1/p.width,r[1]=1/p.height,e.u_intensity=n,e.u_delta=1,p.blit(b,h.uniforms(e)),this.setOutputData(2,b));gl.enable(gl.BLEND);gl.blendFunc(gl.ONE,gl.ONE);e.u_intensity= +this.getInputOrProperty("persistence");e.u_delta=0.5;for(m-=2;0<=m;m--)l=k[m],k[m]=null,r[0]=1/p.width,r[1]=1/p.height,p.blit(l,h.uniforms(e)),GL.Texture.releaseTemporary(p),p=l;gl.disable(gl.BLEND);this.isOutputConnected(1)&&(k=this._glow_texture,k&&k.width==a.width&&k.height==a.height&&k.type==f&&k.format==a.format||(k=this._glow_texture=new GL.Texture(a.width,a.height,{type:f,format:a.format,filter:gl.LINEAR})),p.blit(k),this.setOutputData(1,k));if(this.isOutputConnected(0)){k=this._final_texture; k&&k.width==a.width&&k.height==a.height&&k.type==f&&k.format==a.format||(k=this._final_texture=new GL.Texture(a.width,a.height,{type:f,format:a.format,filter:gl.LINEAR}));var t=this.getInputData(1),u=this.getInputOrProperty("dirt_factor");e.u_intensity=n;h=t?s._dirt_final_shader:s._final_shader;h||(h=t?s._dirt_final_shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,s.final_pixel_shader,{USE_DIRT:""}):s._final_shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,s.final_pixel_shader));k.drawTo(function(){a.bind(0); -q.bind(1);t&&(h.setUniform("u_dirt_factor",u),h.setUniform("u_dirt_texture",t.bind(2)));h.toViewport(e)});this.setOutputData(0,k)}GL.Texture.releaseTemporary(q)}},s.cut_pixel_shader="precision highp float;\n\tvarying vec2 v_coord;\n\tuniform sampler2D u_texture;\n\tuniform float u_threshold;\n\tvoid main() {\n\t\tgl_FragColor = max( texture2D( u_texture, v_coord ) - vec4( u_threshold ), vec4(0.0) );\n\t}",s.scale_pixel_shader="precision highp float;\n\tvarying vec2 v_coord;\n\tuniform sampler2D u_texture;\n\tuniform vec2 u_texel_size;\n\tuniform float u_delta;\n\tuniform float u_intensity;\n\t\n\tvec4 sampleBox(vec2 uv) {\n\t\tvec4 o = u_texel_size.xyxy * vec2(-u_delta, u_delta).xxyy;\n\t\tvec4 s = texture2D( u_texture, uv + o.xy ) + texture2D( u_texture, uv + o.zy) + texture2D( u_texture, uv + o.xw) + texture2D( u_texture, uv + o.zw);\n\t\treturn s * 0.25;\n\t}\n\tvoid main() {\n\t\tgl_FragColor = u_intensity * sampleBox( v_coord );\n\t}", +p.bind(1);t&&(h.setUniform("u_dirt_factor",u),h.setUniform("u_dirt_texture",t.bind(2)));h.toViewport(e)});this.setOutputData(0,k)}GL.Texture.releaseTemporary(p)}},s.cut_pixel_shader="precision highp float;\n\tvarying vec2 v_coord;\n\tuniform sampler2D u_texture;\n\tuniform float u_threshold;\n\tvoid main() {\n\t\tgl_FragColor = max( texture2D( u_texture, v_coord ) - vec4( u_threshold ), vec4(0.0) );\n\t}",s.scale_pixel_shader="precision highp float;\n\tvarying vec2 v_coord;\n\tuniform sampler2D u_texture;\n\tuniform vec2 u_texel_size;\n\tuniform float u_delta;\n\tuniform float u_intensity;\n\t\n\tvec4 sampleBox(vec2 uv) {\n\t\tvec4 o = u_texel_size.xyxy * vec2(-u_delta, u_delta).xxyy;\n\t\tvec4 s = texture2D( u_texture, uv + o.xy ) + texture2D( u_texture, uv + o.zy) + texture2D( u_texture, uv + o.xw) + texture2D( u_texture, uv + o.zw);\n\t\treturn s * 0.25;\n\t}\n\tvoid main() {\n\t\tgl_FragColor = u_intensity * sampleBox( v_coord );\n\t}", s.final_pixel_shader="precision highp float;\n\tvarying vec2 v_coord;\n\tuniform sampler2D u_texture;\n\tuniform sampler2D u_glow_texture;\n\t#ifdef USE_DIRT\n\t\tuniform sampler2D u_dirt_texture;\n\t#endif\n\tuniform vec2 u_texel_size;\n\tuniform float u_delta;\n\tuniform float u_intensity;\n\tuniform float u_dirt_factor;\n\t\n\tvec4 sampleBox(vec2 uv) {\n\t\tvec4 o = u_texel_size.xyxy * vec2(-u_delta, u_delta).xxyy;\n\t\tvec4 s = texture2D( u_glow_texture, uv + o.xy ) + texture2D( u_glow_texture, uv + o.zy) + texture2D( u_glow_texture, uv + o.xw) + texture2D( u_glow_texture, uv + o.zw);\n\t\treturn s * 0.25;\n\t}\n\tvoid main() {\n\t\tvec4 glow = sampleBox( v_coord );\n\t\t#ifdef USE_DIRT\n\t\t\tglow = mix( glow, glow * texture2D( u_dirt_texture, v_coord ), u_dirt_factor );\n\t\t#endif\n\t\tgl_FragColor = texture2D( u_texture, v_coord ) + u_intensity * glow;\n\t}", F.registerNodeType("texture/glow",s),I.title="Kuwahara Filter",I.desc="Filters a texture giving an artistic oil canvas painting",I.max_radius=10,I._shaders=[],I.prototype.onExecute=function(){var a=this.getInputData(0);if(a&&this.isOutputConnected(0)){var b=this._temp_texture;b&&b.width==a.width&&b.height==a.height&&b.type==a.type||(this._temp_texture=new GL.Texture(a.width,a.height,{type:a.type,format:gl.RGBA,filter:gl.LINEAR}));b=this.properties.radius;b=Math.min(Math.floor(b),I.max_radius);if(0== b)this.setOutputData(0,a);else{var d=this.properties.intensity,c=F.camera_aspect;c||void 0===window.gl||(c=gl.canvas.height/gl.canvas.width);c||(c=1);c=this.properties.preserve_aspect?c:1;I._shaders[b]||(I._shaders[b]=new GL.Shader(Shader.SCREEN_VERTEX_SHADER,I.pixel_shader,{RADIUS:b.toFixed(0)}));var g=I._shaders[b],f=GL.Mesh.getScreenQuad();a.bind(0);this._temp_texture.drawTo(function(){g.uniforms({u_texture:0,u_intensity:d,u_resolution:[a.width,a.height],u_iResolution:[1/a.width,1/a.height]}).draw(f)}); @@ -542,12 +542,12 @@ F.registerNodeType("texture/exposition",N),K.title="Tone Mapping",K.desc="Applie b.height==a.height&&b.type==a.type||(b=this._temp_texture=new GL.Texture(a.width,a.height,{type:a.type,format:gl.RGBA,filter:gl.LINEAR}));var d=this.getInputData(1);null==d&&(d=this.properties.average_lum);var g=this._uniforms,f=null;d.constructor===Number?(this.properties.average_lum=d,g.u_average_lum=this.properties.average_lum,f=K._shader,f||(f=K._shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,K.pixel_shader))):d.constructor===GL.Texture&&(g.u_average_texture=d.bind(1),f=K._shader_texture, f||(f=K._shader_texture=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,K.pixel_shader,{AVG_TEXTURE:""})));g.u_lumwhite2=this.properties.lum_white*this.properties.lum_white;g.u_scale=this.properties.scale;g.u_igamma=1/this.properties.gamma;gl.disable(gl.DEPTH_TEST);b.drawTo(function(){a.bind(0);f.uniforms(g).draw(GL.Mesh.getScreenQuad())});this.setOutputData(0,this._temp_texture)}},K.pixel_shader="precision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform sampler2D u_texture;\n\t\tuniform float u_scale;\n\t\t#ifdef AVG_TEXTURE\n\t\t\tuniform sampler2D u_average_texture;\n\t\t#else\n\t\t\tuniform float u_average_lum;\n\t\t#endif\n\t\tuniform float u_lumwhite2;\n\t\tuniform float u_igamma;\n\t\tvec3 RGB2xyY (vec3 rgb)\n\t\t{\n\t\t\t const mat3 RGB2XYZ = mat3(0.4124, 0.3576, 0.1805,\n\t\t\t\t\t\t\t\t\t 0.2126, 0.7152, 0.0722,\n\t\t\t\t\t\t\t\t\t 0.0193, 0.1192, 0.9505);\n\t\t\tvec3 XYZ = RGB2XYZ * rgb;\n\t\t\t\n\t\t\tfloat f = (XYZ.x + XYZ.y + XYZ.z);\n\t\t\treturn vec3(XYZ.x / f,\n\t\t\t\t\t\tXYZ.y / f,\n\t\t\t\t\t\tXYZ.y);\n\t\t}\n\t\t\n\t\tvoid main() {\n\t\t\tvec4 color = texture2D( u_texture, v_coord );\n\t\t\tvec3 rgb = color.xyz;\n\t\t\tfloat average_lum = 0.0;\n\t\t\t#ifdef AVG_TEXTURE\n\t\t\t\tvec3 pixel = texture2D(u_average_texture,vec2(0.5)).xyz;\n\t\t\t\taverage_lum = (pixel.x + pixel.y + pixel.z) / 3.0;\n\t\t\t#else\n\t\t\t\taverage_lum = u_average_lum;\n\t\t\t#endif\n\t\t\t//Ld - this part of the code is the same for both versions\n\t\t\tfloat lum = dot(rgb, vec3(0.2126, 0.7152, 0.0722));\n\t\t\tfloat L = (u_scale / average_lum) * lum;\n\t\t\tfloat Ld = (L * (1.0 + L / u_lumwhite2)) / (1.0 + L);\n\t\t\t//first\n\t\t\t//vec3 xyY = RGB2xyY(rgb);\n\t\t\t//xyY.z *= Ld;\n\t\t\t//rgb = xyYtoRGB(xyY);\n\t\t\t//second\n\t\t\trgb = (rgb / lum) * Ld;\n\t\t\trgb = max(rgb,vec3(0.001));\n\t\t\trgb = pow( rgb, vec3( u_igamma ) );\n\t\t\tgl_FragColor = vec4( rgb, color.a );\n\t\t}", F.registerNodeType("texture/tonemapping",K),M.title="Perlin",M.desc="Generates a perlin noise texture",M.widgets_info={precision:{widget:"combo",values:c.MODE_VALUES},width:{type:"Number",precision:0,step:1},height:{type:"Number",precision:0,step:1},octaves:{type:"Number",precision:0,step:1,min:1,max:50}},M.prototype.onGetInputs=function(){return[["seed","Number"],["persistence","Number"],["octaves","Number"],["scale","Number"],["amplitude","Number"],["offset","vec2"]]},M.prototype.onExecute=function(){if(this.isOutputConnected(0)){var a= -this.properties.width|0,b=this.properties.height|0;0==a&&(a=gl.viewport_data[2]);0==b&&(b=gl.viewport_data[3]);var d=c.getTextureType(this.properties.precision),g=this._texture;g&&g.width==a&&g.height==b&&g.type==d||(g=this._texture=new GL.Texture(a,b,{type:d,format:gl.RGB,filter:gl.LINEAR}));var f=this.getInputOrProperty("persistence"),e=this.getInputOrProperty("octaves"),k=this.getInputOrProperty("offset"),h=this.getInputOrProperty("scale"),l=this.getInputOrProperty("amplitude"),q=this.getInputOrProperty("seed"), -d=""+a+b+d+f+e+h+q+k[0]+k[1]+l;if(d!=this._key){this._key=d;var p=this._uniforms;p.u_persistence=f;p.u_octaves=e;p.u_offset.set(k);p.u_scale=h;p.u_amplitude=l;p.u_seed=128*q;p.u_viewport[0]=a;p.u_viewport[1]=b;var r=M._shader;r||(r=M._shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,M.pixel_shader));gl.disable(gl.BLEND);gl.disable(gl.DEPTH_TEST);g.drawTo(function(){r.uniforms(p).draw(GL.Mesh.getScreenQuad())})}this.setOutputData(0,g)}},M.pixel_shader="precision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform vec2 u_offset;\n\t\tuniform float u_scale;\n\t\tuniform float u_persistence;\n\t\tuniform int u_octaves;\n\t\tuniform float u_amplitude;\n\t\tuniform vec2 u_viewport;\n\t\tuniform float u_seed;\n\t\t#define M_PI 3.14159265358979323846\n\t\t\n\t\tfloat rand(vec2 c){\treturn fract(sin(dot(c.xy ,vec2( 12.9898 + u_seed,78.233 + u_seed))) * 43758.5453); }\n\t\t\n\t\tfloat noise(vec2 p, float freq ){\n\t\t\tfloat unit = u_viewport.x/freq;\n\t\t\tvec2 ij = floor(p/unit);\n\t\t\tvec2 xy = mod(p,unit)/unit;\n\t\t\t//xy = 3.*xy*xy-2.*xy*xy*xy;\n\t\t\txy = .5*(1.-cos(M_PI*xy));\n\t\t\tfloat a = rand((ij+vec2(0.,0.)));\n\t\t\tfloat b = rand((ij+vec2(1.,0.)));\n\t\t\tfloat c = rand((ij+vec2(0.,1.)));\n\t\t\tfloat d = rand((ij+vec2(1.,1.)));\n\t\t\tfloat x1 = mix(a, b, xy.x);\n\t\t\tfloat x2 = mix(c, d, xy.x);\n\t\t\treturn mix(x1, x2, xy.y);\n\t\t}\n\t\t\n\t\tfloat pNoise(vec2 p, int res){\n\t\t\tfloat persistance = u_persistence;\n\t\t\tfloat n = 0.;\n\t\t\tfloat normK = 0.;\n\t\t\tfloat f = 4.;\n\t\t\tfloat amp = 1.0;\n\t\t\tint iCount = 0;\n\t\t\tfor (int i = 0; i<50; i++){\n\t\t\t\tn+=amp*noise(p, f);\n\t\t\t\tf*=2.;\n\t\t\t\tnormK+=amp;\n\t\t\t\tamp*=persistance;\n\t\t\t\tif (iCount >= res)\n\t\t\t\t\tbreak;\n\t\t\t\tiCount++;\n\t\t\t}\n\t\t\tfloat nf = n/normK;\n\t\t\treturn nf*nf*nf*nf;\n\t\t}\n\t\tvoid main() {\n\t\t\tvec2 uv = v_coord * u_scale * u_viewport + u_offset * u_scale;\n\t\t\tvec4 color = vec4( pNoise( uv, u_octaves ) * u_amplitude );\n\t\t\tgl_FragColor = color;\n\t\t}", +this.properties.width|0,b=this.properties.height|0;0==a&&(a=gl.viewport_data[2]);0==b&&(b=gl.viewport_data[3]);var d=c.getTextureType(this.properties.precision),g=this._texture;g&&g.width==a&&g.height==b&&g.type==d||(g=this._texture=new GL.Texture(a,b,{type:d,format:gl.RGB,filter:gl.LINEAR}));var f=this.getInputOrProperty("persistence"),e=this.getInputOrProperty("octaves"),k=this.getInputOrProperty("offset"),h=this.getInputOrProperty("scale"),l=this.getInputOrProperty("amplitude"),p=this.getInputOrProperty("seed"), +d=""+a+b+d+f+e+h+p+k[0]+k[1]+l;if(d!=this._key){this._key=d;var q=this._uniforms;q.u_persistence=f;q.u_octaves=e;q.u_offset.set(k);q.u_scale=h;q.u_amplitude=l;q.u_seed=128*p;q.u_viewport[0]=a;q.u_viewport[1]=b;var r=M._shader;r||(r=M._shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,M.pixel_shader));gl.disable(gl.BLEND);gl.disable(gl.DEPTH_TEST);g.drawTo(function(){r.uniforms(q).draw(GL.Mesh.getScreenQuad())})}this.setOutputData(0,g)}},M.pixel_shader="precision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform vec2 u_offset;\n\t\tuniform float u_scale;\n\t\tuniform float u_persistence;\n\t\tuniform int u_octaves;\n\t\tuniform float u_amplitude;\n\t\tuniform vec2 u_viewport;\n\t\tuniform float u_seed;\n\t\t#define M_PI 3.14159265358979323846\n\t\t\n\t\tfloat rand(vec2 c){\treturn fract(sin(dot(c.xy ,vec2( 12.9898 + u_seed,78.233 + u_seed))) * 43758.5453); }\n\t\t\n\t\tfloat noise(vec2 p, float freq ){\n\t\t\tfloat unit = u_viewport.x/freq;\n\t\t\tvec2 ij = floor(p/unit);\n\t\t\tvec2 xy = mod(p,unit)/unit;\n\t\t\t//xy = 3.*xy*xy-2.*xy*xy*xy;\n\t\t\txy = .5*(1.-cos(M_PI*xy));\n\t\t\tfloat a = rand((ij+vec2(0.,0.)));\n\t\t\tfloat b = rand((ij+vec2(1.,0.)));\n\t\t\tfloat c = rand((ij+vec2(0.,1.)));\n\t\t\tfloat d = rand((ij+vec2(1.,1.)));\n\t\t\tfloat x1 = mix(a, b, xy.x);\n\t\t\tfloat x2 = mix(c, d, xy.x);\n\t\t\treturn mix(x1, x2, xy.y);\n\t\t}\n\t\t\n\t\tfloat pNoise(vec2 p, int res){\n\t\t\tfloat persistance = u_persistence;\n\t\t\tfloat n = 0.;\n\t\t\tfloat normK = 0.;\n\t\t\tfloat f = 4.;\n\t\t\tfloat amp = 1.0;\n\t\t\tint iCount = 0;\n\t\t\tfor (int i = 0; i<50; i++){\n\t\t\t\tn+=amp*noise(p, f);\n\t\t\t\tf*=2.;\n\t\t\t\tnormK+=amp;\n\t\t\t\tamp*=persistance;\n\t\t\t\tif (iCount >= res)\n\t\t\t\t\tbreak;\n\t\t\t\tiCount++;\n\t\t\t}\n\t\t\tfloat nf = n/normK;\n\t\t\treturn nf*nf*nf*nf;\n\t\t}\n\t\tvoid main() {\n\t\t\tvec2 uv = v_coord * u_scale * u_viewport + u_offset * u_scale;\n\t\t\tvec4 color = vec4( pNoise( uv, u_octaves ) * u_amplitude );\n\t\t\tgl_FragColor = color;\n\t\t}", F.registerNodeType("texture/perlin",M),L.title="Canvas2D",L.desc="Executes Canvas2D code inside a texture or the viewport.",L.help="Set width and height to 0 to match viewport size.",L.default_code="//vars: canvas,ctx,time\nctx.fillStyle='red';\nctx.fillRect(0,0,50,50);\n",L.widgets_info={precision:{widget:"combo",values:c.MODE_VALUES},code:{type:"code"},width:{type:"Number",precision:0,step:1},height:{type:"Number",precision:0,step:1}},L.prototype.onPropertyChanged=function(a,b){"code"==a&&this.compileCode(b)}, L.prototype.compileCode=function(a){this._func=null;if(F.allow_scripts)try{this._func=new Function("canvas","ctx","time","script","v",a),this.boxcolor="#00FF00"}catch(b){this.boxcolor="#FF0000",console.error("Error parsing script"),console.error(b)}},L.prototype.onExecute=function(){var a=this._func;a&&this.isOutputConnected(0)&&this.executeDraw(a)},L.prototype.executeDraw=function(a){var b=this.properties.width||gl.canvas.width,d=this.properties.height||gl.canvas.height,g=this._temp_texture,f=c.getTextureType(this.properties.precision); -g&&g.width==b&&g.height==d&&g.type==f||(g=this._temp_texture=new GL.Texture(b,d,{format:gl.RGBA,filter:gl.LINEAR,type:f}));var e=this.getInputData(0),k=this.properties,h=this,l=this.graph.getTime(),q=gl,p=gl.canvas;if(this.properties.use_html_canvas||!B.enableWebGLCanvas)this._canvas?(p=this._canvas,q=this._ctx):(p=this._canvas=createCanvas(b.height),q=this._ctx=p.getContext("2d")),p.width=b,p.height=d;if(q==gl)g.drawTo(function(){gl.start2D();k.clear&&(gl.clearColor(0,0,0,0),gl.clear(gl.COLOR_BUFFER_BIT)); -try{a.draw?a.draw.call(h,p,q,l,a,e):a.call(h,p,q,l,a,e),h.boxcolor="#00FF00"}catch(b){h.boxcolor="#FF0000",console.error("Error executing script"),console.error(b)}gl.finish2D()});else{k.clear&&q.clearRect(0,0,p.width,p.height);try{a.draw?a.draw.call(this,p,q,l,a,e):a.call(this,p,q,l,a,e),this.boxcolor="#00FF00"}catch(r){this.boxcolor="#FF0000",console.error("Error executing script"),console.error(r)}g.uploadImage(p)}this.setOutputData(0,g)},F.registerNodeType("texture/canvas2D",L),O.title="Matte", +g&&g.width==b&&g.height==d&&g.type==f||(g=this._temp_texture=new GL.Texture(b,d,{format:gl.RGBA,filter:gl.LINEAR,type:f}));var e=this.getInputData(0),k=this.properties,h=this,l=this.graph.getTime(),p=gl,q=gl.canvas;if(this.properties.use_html_canvas||!B.enableWebGLCanvas)this._canvas?(q=this._canvas,p=this._ctx):(q=this._canvas=createCanvas(b.height),p=this._ctx=q.getContext("2d")),q.width=b,q.height=d;if(p==gl)g.drawTo(function(){gl.start2D();k.clear&&(gl.clearColor(0,0,0,0),gl.clear(gl.COLOR_BUFFER_BIT)); +try{a.draw?a.draw.call(h,q,p,l,a,e):a.call(h,q,p,l,a,e),h.boxcolor="#00FF00"}catch(b){h.boxcolor="#FF0000",console.error("Error executing script"),console.error(b)}gl.finish2D()});else{k.clear&&p.clearRect(0,0,q.width,q.height);try{a.draw?a.draw.call(this,q,p,l,a,e):a.call(this,q,p,l,a,e),this.boxcolor="#00FF00"}catch(r){this.boxcolor="#FF0000",console.error("Error executing script"),console.error(r)}g.uploadImage(q)}this.setOutputData(0,g)},F.registerNodeType("texture/canvas2D",L),O.title="Matte", O.desc="Extracts background",O.widgets_info={key_color:{widget:"color"},precision:{widget:"combo",values:c.MODE_VALUES}},O.prototype.onExecute=function(){if(this.isOutputConnected(0)){var a=this.getInputData(0);if(this.properties.precision===c.PASS_THROUGH)this.setOutputData(0,a);else if(a){this._tex=c.getTargetTexture(a,this._tex,this.properties.precision);gl.disable(gl.BLEND);gl.disable(gl.DEPTH_TEST);this._uniforms||(this._uniforms={u_texture:0,u_key_color:this.properties.key_color,u_threshold:1, u_slope:1});var b=this._uniforms,d=Mesh.getScreenQuad(),g=O._shader;g||(g=O._shader=new GL.Shader(GL.Shader.SCREEN_VERTEX_SHADER,O.pixel_shader));b.u_key_color=this.properties.key_color;b.u_threshold=this.properties.threshold;b.u_slope=this.properties.slope;this._tex.drawTo(function(){a.bind(0);g.uniforms(b).draw(d)});this.setOutputData(0,this._tex)}}},O.pixel_shader="precision highp float;\n\t\tvarying vec2 v_coord;\n\t\tuniform sampler2D u_texture;\n\t\tuniform vec3 u_key_color;\n\t\tuniform float u_threshold;\n\t\tuniform float u_slope;\n\t\t\n\t\tvoid main() {\n\t\t\tvec3 color = texture2D( u_texture, v_coord ).xyz;\n\t\t\tfloat diff = length( normalize(color) - normalize(u_key_color) );\n\t\t\tfloat edge = u_threshold * (1.0 - u_slope);\n\t\t\tfloat alpha = smoothstep( edge, u_threshold, diff);\n\t\t\tgl_FragColor = vec4( color, alpha );\n\t\t}", F.registerNodeType("texture/matte",O),P.title="CubemapToTexture2D",P.desc="Transforms a CUBEMAP texture into a TEXTURE2D in Polar Representation",P.prototype.onExecute=function(){if(this.isOutputConnected(0)){var a=this.getInputData(0);if(a&&a.texture_type==GL.TEXTURE_CUBE_MAP){!this._last_tex||this._last_tex.height==a.height&&this._last_tex.type==a.type||(this._last_tex=null);var b=this.getInputOrProperty("yaw");this._last_tex=GL.Texture.cubemapToTexture2D(a,a.height,this._last_tex,!0,b);this.setOutputData(0, @@ -558,46 +558,46 @@ this.addOutput("out","geometry");this.properties={};this.geometry={type:"triangl "geometry");this.addOutput("","geometry");this.properties={top_cap:!0,bottom_cap:!0,offset:[0,100,0]};this._last_geo_version=this.version=-1;this._must_update=!0}function w(){this.addInput("in","geometry");this.addOutput("out","geometry");this.properties={code:"V[1] += 0.01 * Math.sin(I + T*0.001);",execute_every_frame:!1};this.geometry=null;this.version=this.geometry_id=-1;this.must_update=!0;this.func=this.vertices=null}function u(){this.addInput("in","geometry");this.addOutput("out","geometry"); this.properties={min_dist:0.4,max_dist:0.5,max_connections:0,probability:1};this.version=this.geometry_id=-1;this.my_version=1;this.must_update=!0}function D(){this.addInput("mesh","mesh");this.addOutput("out","geometry");this.geometry={};this.last_mesh=null}function A(){this.addInput("in","geometry");this.addOutput("mesh","mesh");this.properties={};this.version=-1;this.mesh=null}function h(){this.addInput("mesh","mesh");this.addInput("mat4","mat4");this.addInput("tex","texture");this.properties= {enabled:!0,primitive:GL.TRIANGLES,additive:!1,color:[1,1,1],opacity:1};this.color=vec4.create([1,1,1,1]);this.model_matrix=mat4.create();this.uniforms={u_color:this.color,u_model:this.model_matrix}}function z(){this.addInput("size","number");this.addOutput("out","mesh");this.properties={type:1,size:1,subdivisions:32};this.version=1E5*Math.random()|0;this.last_info={type:-1,size:-1,subdivisions:-1}}function y(){this.addInput("in","geometry");this.addInput("mat4","mat4");this.addInput("tex","texture"); -this.properties={enabled:!0,point_size:0.1,fixed_size:!1,additive:!0,color:[1,1,1],opacity:1};this.color=vec4.create([1,1,1,1]);this.uniforms={u_point_size:1,u_perspective:1,u_point_perspective:1,u_color:this.color};this.version=this.geometry_id=-1;this.mesh=null}var v=B.LiteGraph,G=new Float32Array(16),q=new Float32Array(16),p=new Float32Array(16),k=new Float32Array(16),a={u_view:G,u_projection:q,u_viewprojection:p,u_model:k};v.LGraphRender={onRequestCameraMatrices:null};B.LGraphPoints3D=m;m.RECTANGLE= +this.properties={enabled:!0,point_size:0.1,fixed_size:!1,additive:!0,color:[1,1,1],opacity:1};this.color=vec4.create([1,1,1,1]);this.uniforms={u_point_size:1,u_perspective:1,u_point_perspective:1,u_color:this.color};this.version=this.geometry_id=-1;this.mesh=null}var v=B.LiteGraph,G=new Float32Array(16),p=new Float32Array(16),q=new Float32Array(16),k=new Float32Array(16),a={u_view:G,u_projection:p,u_viewprojection:q,u_model:k};v.LGraphRender={onRequestCameraMatrices:null};B.LGraphPoints3D=m;m.RECTANGLE= 1;m.CIRCLE=2;m.CUBE=10;m.SPHERE=11;m.HEMISPHERE=12;m.INSIDE_SPHERE=13;m.OBJECT=20;m.OBJECT_UNIFORMLY=21;m.OBJECT_INSIDE=22;m.MODE_VALUES={rectangle:m.RECTANGLE,circle:m.CIRCLE,cube:m.CUBE,sphere:m.SPHERE,hemisphere:m.HEMISPHERE,inside_sphere:m.INSIDE_SPHERE,object:m.OBJECT,object_uniformly:m.OBJECT_UNIFORMLY,object_inside:m.OBJECT_INSIDE};m.widgets_info={mode:{widget:"combo",values:m.MODE_VALUES}};m.title="list of points";m.desc="returns an array of points";m.prototype.onPropertyChanged=function(a, d){this.must_update=!0};m.prototype.onExecute=function(){var a=this.getInputData(0);if(a!=this._old_obj||a&&a._version!=this._old_obj_version)this._old_obj=a,this.must_update=!0;a=this.getInputData(1);null==a&&(a=this.properties.radius);this._last_radius!=a&&(this._last_radius=a,this.must_update=!0);if(this.must_update||this.properties.force_update)this.must_update=!1,this.updatePoints();this.geometry.vertices=this.points;this.geometry.normals=this.normals;this.geometry._version=this.version;this.setOutputData(0, this.geometry)};m.prototype.updatePoints=function(){var a=this.properties.num_points|0;1>a&&(a=1);this.points&&this.points.length==3*a||(this.points=new Float32Array(3*a));this.properties.generate_normals?this.normals&&this.normals.length==this.points.length||(this.normals=new Float32Array(this.points.length)):this.normals=null;var d=this._last_radius||this.properties.radius,c=this.properties.mode,f=this.getInputData(0);this._old_obj_version=f?f._version:null;this.points=m.generatePoints(d,a,c,this.points, -this.normals,this.properties.regular,f);this.version++};m.generatePoints=function(a,d,c,f,e,k,h){var l=3*d;f&&f.length==l||(f=new Float32Array(l));var q=new Float32Array(3),p=new Float32Array([0,1,0]);if(k)if(c==m.RECTANGLE){l=Math.floor(Math.sqrt(d));for(d=0;de||wk&&kh))break}this.geometry.indices=this.indices=new Uint32Array(l)}this.indices&&this.indices.length?(this.geometry.indices=this.indices,this.setOutputData(0,this.geometry)):this.setOutputData(0,null)}};v.registerNodeType("geometry/connectPoints",u);"undefined"!=typeof GL&&(D.title="to geometry",D.desc="converts a mesh to geometry",D.prototype.onExecute= +function(){var a=this.getInputData(0);if(a){if(this.geometry_id!=a._id||this.version!=a._version||this.must_update){this.must_update=!1;this.geometry_id=a._id;this.version=a._version;this.geometry={};for(var d in a)this.geometry[d]=a[d];this.geometry._id=c();this.geometry._version=this.my_version++;var a=a.vertices,g=a.length,f=this.properties.min_dist,e=this.properties.max_dist,k=this.properties.probability,h=this.properties.max_connections,p=[];for(d=0;de||wk&&kh))break}this.geometry.indices=this.indices=new Uint32Array(p)}this.indices&&this.indices.length?(this.geometry.indices=this.indices,this.setOutputData(0,this.geometry)):this.setOutputData(0,null)}};v.registerNodeType("geometry/connectPoints",u);"undefined"!=typeof GL&&(D.title="to geometry",D.desc="converts a mesh to geometry",D.prototype.onExecute= function(){var a=this.getInputData(0);if(a){if(a!=this.last_mesh){this.last_mesh=a;for(i in a.vertexBuffers)this.geometry[i]=a.vertexBuffers[i].data;a.indexBuffers.triangles&&(this.geometry.indices=a.indexBuffers.triangles.data);this.geometry._id=c();this.geometry._version=0}this.setOutputData(0,this.geometry);this.geometry&&this.setOutputData(1,this.geometry.vertices)}},v.registerNodeType("geometry/toGeometry",D),A.title="Geo to Mesh",A.prototype.updateMesh=function(a){this.mesh||(this.mesh=new GL.Mesh); for(var d in a)if("_"!=d[0]){var c=a[d],f=GL.Mesh.common_buffers[d];if(f||"indices"==d){var f=f?f.spacing:3,e=this.mesh.vertexBuffers[d];e&&e.data.length==c.length?(e.data.set(c),e.upload(GL.DYNAMIC_DRAW)):e=new GL.Buffer("indices"==d?GL.ELEMENT_ARRAY_BUFFER:GL.ARRAY_BUFFER,c,f,GL.DYNAMIC_DRAW);this.mesh.addBuffer(d,e)}}if(this.mesh.vertexBuffers.normals&&this.mesh.vertexBuffers.normals.data.length!=this.mesh.vertexBuffers.vertices.data.length){c=new Float32Array([0,1,0]);f=new Float32Array(this.mesh.vertexBuffers.vertices.data.length); for(d=0;dh[1])){var k=this.getKeyIndex(h);this.keys[k]=!0;this._last_key=k;var k=12*(this.properties.start_octave-1)+29+k,a=new c;a.setup([c.NOTEON,k,100]);this.trigger("note",a);return!0}};y.prototype.onMouseMove=function(e,h){if(!(0>h[1]||-1==this._last_key)){this.setDirtyCanvas(!0); var k=this.getKeyIndex(h);if(this._last_key==k)return!0;this.keys[this._last_key]=!1;var a=12*(this.properties.start_octave-1)+29+this._last_key,b=new c;b.setup([c.NOTEOFF,a,100]);this.trigger("note",b);this.keys[k]=!0;a=12*(this.properties.start_octave-1)+29+k;b=new c;b.setup([c.NOTEON,a,100]);this.trigger("note",b);this._last_key=k;return!0}};y.prototype.onMouseUp=function(e,h){if(!(0>h[1])){var k=this.getKeyIndex(h);this.keys[k]=!1;this._last_key=-1;var k=12*(this.properties.start_octave-1)+29+ k,a=new c;a.setup([c.NOTEOFF,k,100]);this.trigger("note",a);return!0}};v.registerNodeType("midi/keys",y)})(this); -(function(B){function c(){this.properties={src:"",gain:0.5,loop:!0,autoplay:!0,playbackRate:1};this._loading_audio=!1;this._audiobuffer=null;this._audionodes=[];this._last_sourcenode=null;this.addOutput("out","audio");this.addInput("gain","number");this.audionode=p.getAudioContext().createGain();this.audionode.graphnode=this;this.audionode.gain.value=this.properties.gain;this.properties.src&&this.loadSound(this.properties.src)}function m(){this.properties={gain:0.5};this._audionodes=[];this._media_stream= -null;this.addOutput("out","audio");this.addInput("gain","number");this.audionode=p.getAudioContext().createGain();this.audionode.graphnode=this;this.audionode.gain.value=this.properties.gain}function n(){this.properties={fftSize:2048,minDecibels:-100,maxDecibels:-10,smoothingTimeConstant:0.5};this.audionode=p.getAudioContext().createAnalyser();this.audionode.graphnode=this;this.audionode.fftSize=this.properties.fftSize;this.audionode.minDecibels=this.properties.minDecibels;this.audionode.maxDecibels= -this.properties.maxDecibels;this.audionode.smoothingTimeConstant=this.properties.smoothingTimeConstant;this.addInput("in","audio");this.addOutput("freqs","array");this.addOutput("samples","array");this._time_bin=this._freq_bin=null}function l(){this.properties={gain:1};this.audionode=p.getAudioContext().createGain();this.addInput("in","audio");this.addInput("gain","number");this.addOutput("out","audio")}function x(){this.properties={impulse_src:"",normalize:!0};this.audionode=p.getAudioContext().createConvolver(); -this.addInput("in","audio");this.addOutput("out","audio")}function e(){this.properties={threshold:-50,knee:40,ratio:12,reduction:-20,attack:0,release:0.25};this.audionode=p.getAudioContext().createDynamicsCompressor();this.addInput("in","audio");this.addOutput("out","audio")}function C(){this.properties={};this.audionode=p.getAudioContext().createWaveShaper();this.addInput("in","audio");this.addInput("shape","waveshape");this.addOutput("out","audio")}function w(){this.properties={gain1:0.5,gain2:0.5}; -this.audionode=p.getAudioContext().createGain();this.audionode1=p.getAudioContext().createGain();this.audionode1.gain.value=this.properties.gain1;this.audionode2=p.getAudioContext().createGain();this.audionode2.gain.value=this.properties.gain2;this.audionode1.connect(this.audionode);this.audionode2.connect(this.audionode);this.addInput("in1","audio");this.addInput("in1 gain","number");this.addInput("in2","audio");this.addInput("in2 gain","number");this.addOutput("out","audio")}function u(){this.properties= -{A:0.1,D:0.1,S:0.1,R:0.1};this.audionode=p.getAudioContext().createGain();this.audionode.gain.value=0;this.addInput("in","audio");this.addInput("gate","bool");this.addOutput("out","audio");this.gate=!1}function D(){this.properties={delayTime:0.5};this.audionode=p.getAudioContext().createDelay(10);this.audionode.delayTime.value=this.properties.delayTime;this.addInput("in","audio");this.addInput("time","number");this.addOutput("out","audio")}function A(){this.properties={frequency:350,detune:0,Q:1}; -this.addProperty("type","lowpass","enum",{values:"lowpass highpass bandpass lowshelf highshelf peaking notch allpass".split(" ")});this.audionode=p.getAudioContext().createBiquadFilter();this.addInput("in","audio");this.addOutput("out","audio")}function h(){this.properties={frequency:440,detune:0,type:"sine"};this.addProperty("type","sine","enum",{values:["sine","square","sawtooth","triangle","custom"]});this.audionode=p.getAudioContext().createOscillator();this.addOutput("out","audio")}function z(){this.properties= -{continuous:!0,mark:-1};this.addInput("data","array");this.addInput("mark","number");this.size=[300,200];this._last_buffer=null}function y(){this.properties={band:440,amplitude:1};this.addInput("freqs","array");this.addOutput("signal","number")}function v(){if(!v.default_code){var c=v.default_function.toString(),a=c.indexOf("{")+1,b=c.lastIndexOf("}");v.default_code=c.substr(a,b-a)}this.properties={code:v.default_code};c=p.getAudioContext();c.createScriptProcessor?this.audionode=c.createScriptProcessor(4096, -1,1):(console.warn("ScriptProcessorNode deprecated"),this.audionode=c.createGain());this.processCode();v._bypass_function||(v._bypass_function=this.audionode.onaudioprocess);this.addInput("in","audio");this.addOutput("out","audio")}function G(){this.audionode=p.getAudioContext().destination;this.addInput("in","audio")}var q=B.LiteGraph,p={};B.LGAudio=p;p.getAudioContext=function(){if(!this._audio_context){window.AudioContext=window.AudioContext||window.webkitAudioContext;if(!window.AudioContext)return console.error("AudioContext not supported by browser"), -null;this._audio_context=new AudioContext;this._audio_context.onmessage=function(c){console.log("msg",c)};this._audio_context.onended=function(c){console.log("ended",c)};this._audio_context.oncomplete=function(c){console.log("complete",c)}}return this._audio_context};p.connect=function(c,a){try{c.connect(a)}catch(b){console.warn("LGraphAudio:",b)}};p.disconnect=function(c,a){try{c.disconnect(a)}catch(b){console.warn("LGraphAudio:",b)}};p.changeAllAudiosConnections=function(c,a){if(c.inputs)for(var b= -0;b=this.size[0]&&(e=this.size[0]-1),c.strokeStyle="red",c.beginPath(),c.moveTo(e,d),c.lineTo(e,0),c.stroke())}};z.title="Visualization";z.desc="Audio Visualization";q.registerNodeType("audio/visualization",z);y.prototype.onExecute=function(){if(this._freqs=this.getInputData(0)){var c=this.properties.band,a=this.getInputData(1); -void 0!==a&&(c=a);a=p.getAudioContext().sampleRate/this._freqs.length;a=c/a*2;a>=this._freqs.length?a=this._freqs[this._freqs.length-1]:(c=a|0,a-=c,a=this._freqs[c]*(1-a)+this._freqs[c+1]*a);this.setOutputData(0,a/255*this.properties.amplitude)}};y.prototype.onGetInputs=function(){return[["band","number"]]};y.title="Signal";y.desc="extract the signal of some frequency";q.registerNodeType("audio/signal",y);v.prototype.onAdded=function(c){c.status==LGraph.STATUS_RUNNING&&(this.audionode.onaudioprocess= +0;f=this.size[0]&&(e=this.size[0]-1),c.strokeStyle="red",c.beginPath(),c.moveTo(e,d),c.lineTo(e,0),c.stroke())}};z.title="Visualization";z.desc="Audio Visualization";p.registerNodeType("audio/visualization",z);y.prototype.onExecute=function(){if(this._freqs=this.getInputData(0)){var c=this.properties.band,a=this.getInputData(1); +void 0!==a&&(c=a);a=q.getAudioContext().sampleRate/this._freqs.length;a=c/a*2;a>=this._freqs.length?a=this._freqs[this._freqs.length-1]:(c=a|0,a-=c,a=this._freqs[c]*(1-a)+this._freqs[c+1]*a);this.setOutputData(0,a/255*this.properties.amplitude)}};y.prototype.onGetInputs=function(){return[["band","number"]]};y.title="Signal";y.desc="extract the signal of some frequency";p.registerNodeType("audio/signal",y);v.prototype.onAdded=function(c){c.status==LGraph.STATUS_RUNNING&&(this.audionode.onaudioprocess= this._callback)};v["@code"]={widget:"code",type:"code"};v.prototype.onStart=function(){this.audionode.onaudioprocess=this._callback};v.prototype.onStop=function(){this.audionode.onaudioprocess=v._bypass_function};v.prototype.onPause=function(){this.audionode.onaudioprocess=v._bypass_function};v.prototype.onUnpause=function(){this.audionode.onaudioprocess=this._callback};v.prototype.onExecute=function(){};v.prototype.onRemoved=function(){this.audionode.onaudioprocess=v._bypass_function};v.prototype.processCode= function(){try{this._script=new new Function("properties",this.properties.code)(this.properties),this._old_code=this.properties.code,this._callback=this._script.onaudioprocess}catch(c){console.error("Error in onaudioprocess code",c),this._callback=v._bypass_function,this.audionode.onaudioprocess=this._callback}};v.prototype.onPropertyChanged=function(c,a){"code"==c&&(this.properties.code=a,this.processCode(),this.graph&&this.graph.status==LGraph.STATUS_RUNNING&&(this.audionode.onaudioprocess=this._callback))}; -v.default_function=function(){this.onaudioprocess=function(c){var a=c.inputBuffer;c=c.outputBuffer;for(var b=0;b