Elusien

SHOTCUT-Logo-Flip WebVfx Overlay HTML Filter

Jan 21st, 2018
233
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
HTML 36.90 KB | None | 0 0
  1. <html lang="en">
  2. <!-- See the result at: vimeo.com/251985026 -->
  3. <head>
  4. <meta charset="utf-8">
  5. <title>Shotcut Blink</title>
  6. <style>
  7.     html, body {margin:0; padding:0; width: 100%; height: 100%;}
  8.     #flip-container, #flipper, #front, #back {width: 75%; height: 100%; margin: auto;}
  9.     #flip-container { position: relative; }
  10.     #flipper {position: relative;}
  11.     #front, #back {
  12.         position:         absolute;
  13.         top:              0px;
  14.         left:             0px;
  15.         width:            100%;
  16.         height:           100%;
  17.         text-align:       center;
  18.         vertical-align:   middle;
  19.         color:            #bbb;
  20.         background-color: transparent;
  21.         font:             77px Liberation Sans, Arial, sans-serif;
  22.         text-shadow:      -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000;
  23.     }
  24. /* Rainbow-coloured letters */ 
  25.     #l1 {color: violet;}
  26.     #l2 {color: indigo;}
  27.     #l3 {color: blue;}
  28.     #l4 {color: green;}
  29.     #l5 {color: yellow;}
  30.     #l6 {color: orange;}
  31.     #l7 {color: red;}
  32. </style>
  33.  
  34. <script>
  35.     function Easing_Funs(){
  36.     /*
  37.         Easing Equations v1.3, Oct. 29, 2002, Open source under the BSD License.
  38.         Copyright © 2001-2002 Robert Penner. All rights reserved.
  39.  
  40.         These tweening functions provide different flavors of math-based motion under a consistent API.
  41.      
  42.         Math.easingType(t,b,c,d)
  43.             t: current time,
  44.             b: beginning value  (i.e  value at time_start),
  45.             c: change in value  (end_value - b), can be negative
  46.             d: duration         (i.e. time_end - time_start)
  47.  
  48.         Type of easing  HTML data-easing value      Description
  49.         --------------  ----------------------      -----------
  50.             Linear      "Linear" or "" (null)       linear tweening - no easing is performed
  51.             Quadratic   "InQuad"                    t^2         acceleration from zero velocity
  52.                         "OutQuad"                   t^2         deceleration  to  zero velocity
  53.                         "InOutQuad"                 t^2         acceleration until halfway, then deceleration
  54.             Cubic       "InCubic"                   t^3         acceleration from zero velocity
  55.                         "OutCubic"                  t^3         deceleration  to  zero velocity
  56.                         "InOutCubic"                t^3         acceleration until halfway, then deceleration
  57.             Quartic     "InQuartic"                 t^4         acceleration from zero velocity
  58.                         "OutQuartic"                t^4         deceleration  to  zero velocity
  59.                         "InOutQuartic"              t^4         acceleration until halfway, then deceleration
  60.             Quintic     "InQuintic"                 t^5         acceleration from zero velocity
  61.                         "OutQuintic"                t^5         deceleration  to  zero velocity
  62.                         "InOutQuintic"              t^5         acceleration until halfway, then deceleration
  63.             Sinusoidal  "InSine"                    sinusoidal  acceleration from zero velocity
  64.                         "OutSine"                   sinusoidal  deceleration  to  zero velocity
  65.                         "InOutSine"                 sinusoidal  acceleration until halfway, then deceleration
  66.             Exponential "InExpo"                    exponential acceleration from zero velocity
  67.                         "OutExpo"                   exponential deceleration  to  zero velocity
  68.                         "InOutExpo"                 exponential acceleration until halfway, then deceleration
  69.             Circular    "InCirc"                    circular    acceleration from zero velocity
  70.                         "OutCirc"                   circular    deceleration  to  zero velocity
  71.                         InOutCirc"                  circular    acceleration until halfway, then deceleration
  72.          
  73.       Changes:
  74.           1.3 - tweaked the exponential easing functions to make endpoints exact
  75.           1.2 - inline optimizations (changing t and multiplying in one step)--thanks to Tatsuo Kato for the idea
  76.  
  77.       Discussed in Chapter 7 of Robert Penner's Programming Macromedia Flash MX (including graphs of the easing equations)
  78.       http://www.robertpenner.com/profmx
  79.       http://www.amazon.com/exec/obidos/ASIN/0072223561/robertpennerc-20
  80.     */
  81.  
  82. this.linearTween    = function (t, b, c, d) {return c*t/d + b;};
  83. this.easeInQuad     = function (t, b, c, d) {return c*(t/=d)*t + b;};
  84. this.easeOutQuad    = function (t, b, c, d) {return -c *(t/=d)*(t-2) + b;};
  85. this.easeInOutQuad  = function (t, b, c, d) {return ((t/=d/2) < 1) ? c/2*t*t + b : -c/2*((--t)*(t-2) - 1) + b;};
  86. this.easeInCubic    = function (t, b, c, d) {return c*(t/=d)*t*t + b;};
  87. this.easeOutCubic   = function (t, b, c, d) {return c*((t=t/d-1)*t*t + 1) + b;};
  88. this.easeInOutCubic = function (t, b, c, d) {return ((t/=d/2) < 1) ? c/2*t*t*t + b : c/2*((t-=2)*t*t + 2) + b;};
  89. this.easeInQuart    = function (t, b, c, d) {return c*(t/=d)*t*t*t + b;};
  90. this.easeOutQuart   = function (t, b, c, d) {return -c * ((t=t/d-1)*t*t*t - 1) + b;};
  91. this.easeInOutQuart = function (t, b, c, d) {return ((t/=d/2) < 1) ? c/2*t*t*t*t + b : -c/2*((t-=2)*t*t*t - 2) + b;};
  92. this.easeInQuint    = function (t, b, c, d) {return c*(t/=d)*t*t*t*t + b;};
  93. this.easeOutQuint   = function (t, b, c, d) {return c*((t=t/d-1)*t*t*t*t + 1) + b;};
  94. this.easeInOutQuint = function (t, b, c, d) {return ((t/=d/2) < 1) ? c/2*t*t*t*t*t + b :  c/2*((t-=2)*t*t*t*t + 2) + b;};
  95. this.easeInSine     = function (t, b, c, d) {return -c * Math.cos(t/d * (Math.PI/2)) + c + b;};
  96. this.easeOutSine    = function (t, b, c, d) {return c * Math.sin(t/d * (Math.PI/2)) + b;};
  97. this.easeInOutSine  = function (t, b, c, d) {return -c/2 * (Math.cos(Math.PI*t/d) - 1) + b;};
  98. this.easeInExpo     = function (t, b, c, d) {return (t===0) ? b : c * Math.pow(2, 10 * (t/d - 1)) + b;};
  99. this.easeOutExpo    = function (t, b, c, d) {return (t==d) ? b+c : c * (-Math.pow(2, -10 * t/d) + 1) + b;};
  100. this.easeInOutExpo  = function (t, b, c, d) {return (t===0) ? b : ((t==d) ? b+c : (((t/=d/2) < 1) ? c/2 * Math.pow(2, 10 * (t - 1)) + b : c/2*(-Math.pow(2, -10 * --t) + 2) + b));};
  101. this.easeInCirc     = function (t, b, c, d) {return -c * (Math.sqrt(1 - (t/=d)*t) - 1) + b;};
  102. this.easeOutCirc    = function (t, b, c, d) {return c * Math.sqrt(1 - (t=t/d-1)*t) + b;};
  103. this.easeInOutCirc  = function (t, b, c, d) {return ((t/=d/2) < 1) ? -c/2 * (Math.sqrt(1 - t*t) - 1) + b : c/2 * (Math.sqrt(1 - (t-=2)*t) + 1) + b;};
  104.  
  105.     };      // #################### END OF EASING FUNCTIONS ####################
  106.    
  107.     function warning(mesg) {
  108. /*
  109.         ==============================================================================================================
  110.         Description
  111.         -----------
  112.         This function is used to display a warning message on the SHOTCUT screen or Browser window.
  113.  
  114.         Parameters          Description
  115.         ----------          -----------
  116.         mesg                The message to display e.g. "First_period must be between o.o and 1.0"
  117. */
  118.         var warn_div = document.getElementById("warning");
  119.         if (! warn_div){
  120.             warn_div = document.createElement("div");
  121.             warn_div.setAttribute("id", "warning");
  122.             var node = document.createTextNode("");
  123.             warn_div.appendChild(node);
  124.             document.getElementsByTagName("body")[0].appendChild(warn_div);
  125.             warn_div.style.position        = "absolute";
  126.             warn_div.style.top             = "0px";
  127.             warn_div.style.left            = "0px";
  128.             warn_div.style.backgroundColor = "#a00";
  129.             warn_div.style.color           = "#eee";
  130.             warn_div.style.fontSize        = "32px";
  131.         }
  132.         warn_div.innerHTML += 'Warning: ' + mesg + '<br>';
  133.     }       // #################### END OF warning ####################
  134.    
  135.     function Producer(flipper_style, front_style, back_style, easing_type, first_period) {
  136.  
  137. /*
  138.         ==============================================================================================================
  139.         Description
  140.         -----------
  141.         This function (or object) is called to save its parameters as its properties. These are required by the
  142.         render function in order to animate the objects on the screen by manipulating certain of their CSS properties.
  143.  
  144.         Parameters          Description
  145.         ----------          -----------
  146.         flipper_style       The CSS style object of the "#flipper" DIV
  147.         front_style         The CSS style object of the "#front" table
  148.         back_style          The CSS style object of the "#back" table
  149.         easing_type         The easing, or type of motion, used to movr the front and back (e.g. "InOutExpo")
  150.         first_period        A number >=0 and <1 that is the normalised time for the front to disappear
  151.         ==============================================================================================================
  152. */
  153.  
  154.         this.flipper_style = flipper_style;  // Add flipper style object  as a property of the Producer class
  155.         this.front_style   = front_style;
  156.         this.back_style    = back_style;
  157.         this.easing_type   = easing_type;
  158.         this.first_period  = first_period;
  159.     }       // #################### END OF warning ####################
  160.    
  161.    Producer.prototype.render = function(time) {
  162. /*
  163.         ==============================================================================================================
  164.         Description
  165.         -----------
  166.         This function is called once for each frame to manipulate the various objects' CSS properties by 1 increment.
  167.         By using "prototype" it is stored in the Producer object as a method called "render".
  168.         This is the main function, since it is where the animated frames are produced.
  169.         Parameters          Description
  170.         ----------          -----------
  171.         time                The current normalised (between 0.0 and 1.0) time. This is incremented on each call by an
  172.                             amount equal to 1/(duration*framerate), where duration = the length of the clip in seconds
  173.                             and framerate is the number of frames per second.                          
  174.         ==============================================================================================================
  175. */
  176.         var scale_value;
  177.         if (time < this.first_period){
  178.             this.back_style.visibility  = "hidden";
  179.             scale_value = window["easy"][this.easing_type](time, 1.0, -1.0, this.first_period);    
  180.             this.flipper_style.webkitTransform = 'scale(' + scale_value + "," + scale_value + ")";
  181.             this.front_style.visibility = "visible";
  182.         } else {   
  183.             this.front_style.visibility = "hidden";
  184.             scale_value = window["easy"][this.easing_type](time - this.first_period, 0.0, 1.0, 1.0 - this.first_period);
  185.             this.flipper_style.webkitTransform = 'scale(' + scale_value + "," + scale_value + ")";
  186.             this.back_style.visibility  = "visible";
  187.             this.front_style.visibility = "hidden";
  188.         }
  189.     };      // #################### END OF render ####################
  190.    
  191.    function start_process(p_front, p_back, p_flipper) {
  192. /*
  193.         ==============================================================================================================
  194.         Description
  195.         -----------
  196.         This function is called first, when all the HTML, CSS and javascript has been loaded by the browser or SHOTCUT.
  197.         It's main function is to check that the parameters have been supplied correctly and it then creates a Producer
  198.         object by calling the Producer constructor detailed above.
  199.  
  200.         Parameters          Description
  201.         ----------          -----------
  202.         p_font              The id of the table displayed at the front on the SHOTCUT screen, or Browser window. In the
  203.                             HTML below this is the string "front".
  204.         p_back              The id of the table displayed at the back on the SHOTCUT screen, or Browser window. In the
  205.                             HTML below this is the string "back".
  206.         p_flipper           The id of the DIV that contains the front and back tables. In the   HTML below this is the
  207.                             string "flipper". There is a "data-easing" attribute on this DIV in the HTML. It is there
  208.                             to enable the type of easing and the value of the first_period to be specified in the HTML.
  209.                             It's format is:
  210.                                             easing:first_period e.g. "InOutQuint" (it is case-insensitive)
  211.                             see the "easings" object below for valid values.
  212.         ==============================================================================================================
  213. */
  214.         var easings = {'linearTween'    : 'linear',
  215.                        'easeInQuad'     : 'inquad',     'easeOutQuad'    : 'outquad',   'easeInOutQuad'  : 'inoutquad',
  216.                        'easeIncubic'    : 'incubic',    'easeOutCubic'   : 'outcubic',  'easeInOutCubic' : 'inoutcubic',
  217.                        'easeInQuart'    : 'inquart',    'easeOutQuart'   : 'outquart',  'easeInOutQuart' : 'inoutquart',
  218.                        'easeInQuint'    : 'inquint',    'easeOutQuint'   : 'outquint',  'easeInOutQuint' : 'inoutquint',
  219.                        'easeInSine'     : 'insine',     'easeOutSine'    : 'outsine',   'easeInOutSine'  : 'inoutsine',
  220.                        'easeInExpo'     : 'inexpo',     'easeOutExpo'    : 'outexpo',   'easeInOutExpo'  : 'inoutexpo',
  221.                        'easeInCirc'     : 'incirc',     'easeOutCirc'    : 'outcirc',   'easeInOutCirc'  : 'inoutcirc'
  222.         };
  223.        
  224.         easy = new Easing_Funs();
  225.        
  226.         var front   = document.getElementById(p_front);
  227.         var back    = document.getElementById(p_back);
  228.        var flipper = document.getElementById(p_flipper);
  229.        
  230.         if (front   === null)   {warning('START_PROCESS: Parameter 1:' + p_front   + ' does not exist in the HTML.');}
  231.         if (back    === null)   {warning('START_PROCESS: Parameter 2:' + p_back    + ' does not exist in the HTML.');}
  232.         if (flipper === null)   {warning('START_PROCESS: Parameter 3:' + p_flipper + ' does not exist in the HTML.');}
  233.         if ((front  === null) || (back === null) || (flipper === null)) {
  234.             window.alert("Bad parameter(s) passed to function.\nstart_process(" + p_front + ", " + p_back + ", " + p_flipper + ")");
  235.             return false;
  236.         }
  237.        
  238.         var easing  = flipper.getAttribute("data-easing");
  239.         if (easing.length === 0) {easing = 'linear:0.5';}
  240.         var eterms  = easing.toLowerCase().split(':');
  241.         if (eterms.length === 1){
  242.             if (!isNaN(eterms[0])){
  243.                 eterms[1] = eterms[0];
  244.                 eterms[0] = "linear";
  245.             }else{
  246.                 eterms[1] = 0.5;
  247.             }      
  248.         }
  249.         if ((eterms[1] <= 0) || (eterms[1] > 1.0)) {
  250.             warning('START_PROCESS: First_period must be >= 0 and < 1, NOT ' + eterms[1] + '. Using 0.5 instead.');
  251.             eterms[1] = 0.5;
  252.         }
  253.        
  254.         var easing_type = '';
  255.         var found   = false;
  256.         for (var e in easings){
  257.             found = (easings[e] == eterms[0]);
  258.             if (found){
  259.                 easing_type = e;
  260.                 break;
  261.             }
  262.         }
  263.         if (! found ){
  264.             warning('START_PROCESS: No such easing as: ' + eterms[0] + '. Using "linear" instead.');
  265.             easing_type = 'linearTween';
  266.         }
  267.        
  268.         var first_period = +eterms[1];
  269.         if (first_period === 0) {first_period = 0.5;}
  270.        var producer = new Producer(flipper.style, front.style, back.style, easing_type, first_period);
  271.        
  272. /*  The following code checks to see if we are running as an Overlay HTML filter in SHOTCUT, or simply running in a browser window.
  273.     If we are in SHOTCUT this code is skipped, as we use the SHOTCUT webvfx object.
  274.     If we are in a Browser, we create our own webvfx object and use javascript's setTimeout function to call the render function
  275.     for each frame to manipulate the objects' CSS properties to produce the animation.
  276.    
  277.     It is much, much easier to develop and debug a SHOTCUT Overlay HTML Filter in a browser than in SHOTCUT itself. You have access
  278.     to all of the browser's development tools, like inspecting HTML elements, as well as being able to send debug information to
  279.     the javascript console and check it for error messages. Once you have done the development there you simple call this HTML file
  280.     as a WebVfx-enabled Overlay HTML filter in SHOTCUT without having to make any changes to it at all.
  281. */
  282.  
  283.         if (typeof webvfx == "undefined") {
  284.             frame_rate  = 30;
  285.             delay       = 1000/30;
  286.             duration    = 10;
  287.             niters      = duration*frame_rate;
  288.  
  289.             webvfx = {
  290.                         readyRender : function(torf){  
  291.                             var timeout_loop = function(iter, niters, delay){
  292.                                 setTimeout(function(){
  293.                                     var time = iter / niters;
  294.                                     webvfx.renderRequested.prod.render(time);
  295.                                     if (iter < (niters - 1))  timeout_loop(iter+1, niters, delay);
  296.                                 }, delay);
  297.                             }
  298.                             timeout_loop(0, niters, delay);        
  299.                         },
  300.                         renderRequested : {
  301.                             connect : function(prod, render_fun){
  302.                                 this.prod = prod;
  303.                             }
  304.                         }
  305.             };
  306.         }       // ..................... END OF if (typeof webvfx == "undefined") ....................
  307.        
  308.        webvfx.renderRequested.connect(producer, Producer.prototype.render);
  309.        webvfx.readyRender(true);  // This starts the rendering process.
  310.     }       // #################### END OF start_process ####################
  311.  
  312. //  ###############################################################################################
  313.     window.addEventListener("load", function(){start_process("front", "back", "flipper");}, false);
  314. //  ###############################################################################################
  315. </script>
  316. </head>
  317. <body>
  318.    
  319. <!--
  320.     =================================================================================
  321.                               A SHOTCUT Overlay HTML Filter
  322.                               -----------------------------
  323.     This HTML, together with the javascript and CSS, will put the word "SHOTCUT" in
  324.     the colours of the rainbow on the centre of the screen.
  325.     It will then shrink this, as if moving it to infinity on the z-axis.
  326.     It will then expand the Shotcut logo, as if moving it from infinity on the z-axis.
  327.     The motion (easing) is sinusoidal - see the javascript for different easing types.
  328.    
  329.     If you get a blank screen in SHOTCUT it is probably because you mis-typed the id
  330.     of the DIV or one (or both) of the TABLEs. Try feeding the whole filter into a
  331.     browser (e.g. Chrome) and, although the animation will not run, the screen or the
  332.     javascript console may help to track down the problem.
  333.    
  334.                     See the resulting video at: vimeo.com/251985026
  335.     =================================================================================
  336. -->
  337.  
  338. <div id="flip-container">
  339.     <div id="flipper" data-easing="OutSine:0.5">
  340.         <table id="front"> <!-- put the word e.g. "SHOTCUT" in the table cell in the  "front" DIV -->
  341.             <tr><td>
  342.                 <span id="l1">S</span><span id="l2">H</span><span id="l3">O</span><span id="l4">T</span><span id="l5">C</span><span id="l6">U</span><span id="l7">T</span>
  343.             </td></tr>
  344.         </table>
  345.         <table id="back"> <!--put the img (e.g. base64 encoded Shotcut logo) in the table cell in the "back" DIV -->
  346.             <tr><td><img alt="shotcut logo"
  347.                 src="">
  348.             </td></tr>
  349.         </table>
  350.     </div>
  351. </div>
  352. </body>
  353. </html>
Add Comment
Please, Sign In to add comment