forked from BabylonJS/Website
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbabylon.digitalRainPostProcess.min.js
1 lines (1 loc) · 4.81 KB
/
babylon.digitalRainPostProcess.min.js
1
var BABYLON;!(function(t){var e=(function(e){function i(i,n,o,a){var r=e.call(this,a)||this;r.name=i,r._text==o,r._font==n,r.wrapU=t.Texture.CLAMP_ADDRESSMODE,r.wrapV=t.Texture.CLAMP_ADDRESSMODE;var l=r.getFontHeight(n),c=r.getFontWidth(n);r._charSize=Math.max(l.height,c);var g=r._charSize,f=Math.ceil(r._charSize*o.length);r._texture=a.getEngine().createDynamicTexture(g,f,!1,t.Texture.NEAREST_SAMPLINGMODE);var d=r.getSize(),h=document.createElement("canvas");h.width=d.width,h.height=d.height;var m=h.getContext("2d");m.textBaseline="top",m.font=n,m.fillStyle="white",m.imageSmoothingEnabled=!1;for(var s=0;s<o.length;s++)m.fillText(o[s],0,s*r._charSize-l.offset);return r.getScene().getEngine().updateDynamicTexture(r._texture,h,!1,!0),r}return __extends(i,e),Object.defineProperty(i.prototype,"charSize",{get:function(){return this._charSize},enumerable:!0,configurable:!0}),i.prototype.getFontWidth=function(t){var e=document.createElement("canvas"),i=e.getContext("2d");return i.fillStyle="white",i.font=t,i.measureText("W").width},i.prototype.getFontHeight=function(t){var e=document.createElement("canvas"),i=e.getContext("2d");i.fillRect(0,0,e.width,e.height),i.textBaseline="top",i.fillStyle="white",i.font=t,i.fillText("jH|",0,0);for(var n=i.getImageData(0,0,e.width,e.height).data,o=-1,a=-1,r=0;r<e.height;r++)for(var l=0;l<e.width;l++){var c=4*(r*e.width+l);{if(0!==n[c]){o===-1&&(o=r);break}if(l===e.width-1&&o!==-1){a=r,r=e.height;break}}}return{height:a-o+1,offset:o-1}},i.prototype.clone=function(){return new i(this.name,this._font,this._text,this.getScene())},i.Parse=function(e,n){var o=t.SerializationHelper.Parse((function(){return new i(e.name,e.font,e.text,n)}),e,n,null);return o},i})(t.BaseTexture);__decorate([t.serialize("font")],e.prototype,"_font",void 0),__decorate([t.serialize("text")],e.prototype,"_text",void 0),t.DigitalRainFontTexture=e;var i=(function(i){function n(n,o,a){var r=i.call(this,n,"digitalrain",["digitalRainFontInfos","digitalRainOptions","cosTimeZeroOne","matrixSpeed"],["digitalRainFont"],{width:o.getEngine().getRenderWidth(),height:o.getEngine().getRenderHeight()},o,t.Texture.TRILINEAR_SAMPLINGMODE,o.getEngine(),!0)||this;r.mixToTile=0,r.mixToNormal=0;var l="15px Monospace",c="古池や蛙飛び込む水の音ふるいけやかわずとびこむみずのおと初しぐれ猿も小蓑をほしげ也はつしぐれさるもこみのをほしげなり江戸の雨何石呑んだ時鳥えどのあめなんごくのんだほととぎす";a&&("string"==typeof a?l=a:(l=a.font||l,r.mixToTile=a.mixToTile||r.mixToTile,r.mixToNormal=a.mixToNormal||r.mixToNormal)),r._digitalRainFontTexture=new e(n,l,c,o.getScene());for(var g=r._digitalRainFontTexture.getSize(),f=0,d=0,h=new t.Matrix,m=0;m<16;m++)h.m[m]=Math.random();return r.onApply=function(t){t.setTexture("digitalRainFont",r._digitalRainFontTexture),t.setFloat4("digitalRainFontInfos",r._digitalRainFontTexture.charSize,c.length,g.width,g.height),t.setFloat4("digitalRainOptions",r.width,r.height,r.mixToNormal,r.mixToTile),t.setMatrix("matrixSpeed",h),f+=.003,d=f,t.setFloat("cosTimeZeroOne",d)},r}return __extends(n,i),n})(t.PostProcess);t.DigitalRainPostProcess=i})(BABYLON||(BABYLON={})),BABYLON.Effect.ShadersStore.digitalrainPixelShader="\nvarying vec2 vUV;\nuniform sampler2D textureSampler;\nuniform sampler2D digitalRainFont;\n\nuniform vec4 digitalRainFontInfos;\nuniform vec4 digitalRainOptions;\nuniform mat4 matrixSpeed;\nuniform float cosTimeZeroOne;\n\nfloat getLuminance(vec3 color)\n{\nreturn clamp(dot(color,vec3(0.2126,0.7152,0.0722)),0.,1.);\n}\n\nvoid main(void) \n{\nfloat caracterSize=digitalRainFontInfos.x;\nfloat numChar=digitalRainFontInfos.y-1.0;\nfloat fontx=digitalRainFontInfos.z;\nfloat fonty=digitalRainFontInfos.w;\nfloat screenx=digitalRainOptions.x;\nfloat screeny=digitalRainOptions.y;\nfloat ratio=screeny/fonty;\nfloat columnx=float(floor((gl_FragCoord.x)/caracterSize));\nfloat tileX=float(floor((gl_FragCoord.x)/caracterSize))*caracterSize/screenx;\nfloat tileY=float(floor((gl_FragCoord.y)/caracterSize))*caracterSize/screeny;\nvec2 tileUV=vec2(tileX,tileY);\nvec4 tileColor=texture2D(textureSampler,tileUV);\nvec4 baseColor=texture2D(textureSampler,vUV);\nfloat tileLuminance=getLuminance(tileColor.rgb);\nint st=int(mod(columnx,4.0));\nfloat speed=cosTimeZeroOne*(sin(tileX*314.5)*0.5+0.6); \nfloat x=float(mod(gl_FragCoord.x,caracterSize))/fontx;\nfloat y=float(mod(speed+gl_FragCoord.y/screeny,1.0));\ny*=ratio;\nvec4 finalColor=texture2D(digitalRainFont,vec2(x,1.0-y));\nvec3 high=finalColor.rgb*(vec3(1.2,1.2,1.2)*pow(1.0-y,30.0));\nfinalColor.rgb*=vec3(pow(tileLuminance,5.0),pow(tileLuminance,1.5),pow(tileLuminance,3.0));\nfinalColor.rgb+=high;\nfinalColor.rgb=clamp(finalColor.rgb,0.,1.);\nfinalColor.a=1.0;\nfinalColor=mix(finalColor,tileColor,digitalRainOptions.w);\nfinalColor=mix(finalColor,baseColor,digitalRainOptions.z);\ngl_FragColor=finalColor;\n}";