<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  
  

  


  

  <head>
    <title>
      /tags/wmvplayer-1.1/wmvplayer.js –
      JW Player – Trac
    </title>
        <link rel="search" href="/trac/search" />
        <link rel="help" href="/trac/wiki/TracGuide" />
        <link rel="alternate" href="/trac/browser/tags/wmvplayer-1.1/wmvplayer.js?format=txt" type="text/plain" title="Plain Text" /><link rel="alternate" href="/trac/export/330/tags/wmvplayer-1.1/wmvplayer.js" type="text/x-javascript; charset=iso-8859-15" title="Original Format" />
        <link rel="up" href="/trac/browser/tags/wmvplayer-1.1" title="Parent directory" />
        <link rel="start" href="/trac/wiki" />
        <link rel="stylesheet" href="/trac/chrome/common/css/trac.css" type="text/css" /><link rel="stylesheet" href="/trac/chrome/common/css/code.css" type="text/css" /><link rel="stylesheet" href="/trac/chrome/common/css/browser.css" type="text/css" />
        <link rel="shortcut icon" href="http://www.longtailvideo.com/favicon.ico" type="image/x-icon" />
        <link rel="icon" href="http://www.longtailvideo.com/favicon.ico" type="image/x-icon" />
      <link type="application/opensearchdescription+xml" rel="search" href="/trac/search/opensearch" title="Search JW Player" />
    <script type="text/javascript" src="/trac/chrome/common/js/jquery.js"></script><script type="text/javascript" src="/trac/chrome/common/js/trac.js"></script><script type="text/javascript" src="/trac/chrome/common/js/search.js"></script>
    <!--[if lt IE 7]>
    <script type="text/javascript" src="/trac/chrome/common/js/ie_pre7_hacks.js"></script>
    <![endif]-->
    <script type="text/javascript">
      jQuery(document).ready(function($) {
        $("#jumploc input").hide();
        $("#jumploc select").change(function () {
          this.parentNode.parentNode.submit();
        })
      });
    </script>
    <link rel="stylesheet" type="text/css" href="/trac/chrome/site/style.css" />
    <script type="text/javascript" src="/trac/chrome/site/swfobject.js"></script>
  </head>
  <body>
    <div id="banner">
      <div id="header">
        <a id="logo" href="http://developer.longtailvideo.com/trac"><img src="/trac/chrome/site/logo.gif" alt="" /></a>
      </div>
      <form id="search" action="/trac/search" method="get">
        <div>
          <label for="proj-search">Search:</label>
          <input type="text" id="proj-search" name="q" size="18" value="" />
          <input type="submit" value="Search" />
        </div>
      </form>
      <div id="metanav" class="nav">
    <ul>
      <li class="last first"><a href="/trac/login">Login</a></li>
    </ul>
  </div>
    </div>
    <div id="mainnav" class="nav">
    <ul>
      <li class="first"><a href="/trac/wiki">Wiki</a></li><li><a href="/trac/roadmap">Roadmap</a></li><li class="active"><a href="/trac/browser">Source Code</a></li><li><a href="/trac/report/3">Tickets</a></li><li class="last"><a href="/trac/testing">Testing</a></li>
    </ul>
  </div>
    <div id="main">
      <div id="ctxtnav" class="nav">
        <h2>Context Navigation</h2>
          <ul>
            <li class="first "><a href="/trac/changeset/90/tags/wmvplayer-1.1/wmvplayer.js">Last Change</a></li><li><a href="/trac/browser/tags/wmvplayer-1.1/wmvplayer.js?annotate=blame&amp;rev=90" title="Annotate each line with the last changed revision (this can be time consuming...)">Annotate</a></li><li class="last"><a href="/trac/log/tags/wmvplayer-1.1/wmvplayer.js">Revision Log</a></li>
          </ul>
        <hr />
      </div>
    <div id="content" class="browser">
      <h1>
    <a class="pathentry first" title="Go to root directory" href="/trac/browser">root</a><span class="pathentry sep">/</span><a class="pathentry" title="View tags" href="/trac/browser/tags">tags</a><span class="pathentry sep">/</span><a class="pathentry" title="View wmvplayer-1.1" href="/trac/browser/tags/wmvplayer-1.1">wmvplayer-1.1</a><span class="pathentry sep">/</span><a class="pathentry" title="View wmvplayer.js" href="/trac/browser/tags/wmvplayer-1.1/wmvplayer.js">wmvplayer.js</a>
    <br style="clear: both" />
  </h1>
      <div id="jumprev">
        <form action="" method="get">
          <div>
            <label for="rev">
              View revision:</label>
            <input type="text" id="rev" name="rev" size="6" />
          </div>
        </form>
      </div>
      <div id="jumploc">
        <form action="" method="get">
          <div class="buttons">
            <label for="preselected">Visit:</label>
            <select id="preselected" name="preselected">
              <option selected="selected"></option>
              <optgroup label="branches">
                <option value="/trac/browser/trunk">trunk</option><option value="/trac/browser/branches/temp">branches/temp</option>
              </optgroup><optgroup label="tags">
                <option value="/trac/browser/tags/desktopplayer-1.0?rev=151">tags/desktopplayer-1.0</option><option value="/trac/browser/tags/flvplayer-2.5?rev=90">tags/flvplayer-2.5</option><option value="/trac/browser/tags/imagerotator-3.2?rev=90">tags/imagerotator-3.2</option><option value="/trac/browser/tags/imagerotator-3.8?rev=90">tags/imagerotator-3.8</option><option value="/trac/browser/tags/imagerotator-3.14?rev=90">tags/imagerotator-3.14</option><option value="/trac/browser/tags/imagerotator-3.15?rev=90">tags/imagerotator-3.15</option><option value="/trac/browser/tags/imagerotator-3.16?rev=90">tags/imagerotator-3.16</option><option value="/trac/browser/tags/imagerotator-3.17?rev=90">tags/imagerotator-3.17</option><option value="/trac/browser/tags/jpgrotator-2.1?rev=90">tags/jpgrotator-2.1</option><option value="/trac/browser/tags/mediaplayer-3.2?rev=90">tags/mediaplayer-3.2</option><option value="/trac/browser/tags/mediaplayer-3.4?rev=90">tags/mediaplayer-3.4</option><option value="/trac/browser/tags/mediaplayer-3.6?rev=90">tags/mediaplayer-3.6</option><option value="/trac/browser/tags/mediaplayer-3.8?rev=90">tags/mediaplayer-3.8</option><option value="/trac/browser/tags/mediaplayer-3.10?rev=90">tags/mediaplayer-3.10</option><option value="/trac/browser/tags/mediaplayer-3.12?rev=90">tags/mediaplayer-3.12</option><option value="/trac/browser/tags/mediaplayer-3.14?rev=90">tags/mediaplayer-3.14</option><option value="/trac/browser/tags/mediaplayer-3.15?rev=90">tags/mediaplayer-3.15</option><option value="/trac/browser/tags/mediaplayer-3.16?rev=90">tags/mediaplayer-3.16</option><option value="/trac/browser/tags/mediaplayer-3.17?rev=92">tags/mediaplayer-3.17</option><option value="/trac/browser/tags/mediaplayer-4.0?rev=90">tags/mediaplayer-4.0</option><option value="/trac/browser/tags/mediaplayer-4.1?rev=210">tags/mediaplayer-4.1</option><option value="/trac/browser/tags/mediaplayer-4.2?rev=210">tags/mediaplayer-4.2</option><option value="/trac/browser/tags/mediaplayer-4.3?rev=210">tags/mediaplayer-4.3</option><option value="/trac/browser/tags/mediaplayer-4.4?rev=210">tags/mediaplayer-4.4</option><option value="/trac/browser/tags/mediaplayer-4.5?rev=233">tags/mediaplayer-4.5</option><option value="/trac/browser/tags/mp3player-2.3?rev=90">tags/mp3player-2.3</option><option value="/trac/browser/tags/wmvplayer-1.0?rev=90">tags/wmvplayer-1.0</option><option value="/trac/browser/tags/wmvplayer-1.1?rev=90">tags/wmvplayer-1.1</option>
              </optgroup>
            </select>
            <input type="submit" value="Go!" title="Jump to the chosen preselected path" />
          </div>
        </form>
      </div>
      <table id="info" summary="Revision info">
        <tr>
          <th scope="col">
            Revision <a href="/trac/changeset/90">90</a>, <span title="24010 bytes">23.4 kB</span>
            (checked in by jeroen, <a class="timeline" href="/trac/timeline?from=2008-10-20T06%3A12%3A59Z-0700&amp;precision=second" title="2008-10-20T06:12:59Z-0700 in Timeline">11 months</a> ago)
          </th>
        </tr>
        <tr>
          <td class="message searchable">
              <p>
tagged 4.2 mediaplayer and 1.0 desktopplayer and removed 4.2 branch <br />
</p>
          </td>
        </tr>
      </table>
      <div id="preview" class="searchable">
    <table class="code"><thead><tr><th class="lineno" title="Line numbers">Line</th><th class="content"> </th></tr></thead><tbody><tr><th id="L1"><a href="#L1">1</a></th><td>/****************************************************************************</td></tr><tr><th id="L2"><a href="#L2">2</a></th><td>* JW WMV Player version 1.1, created with M$ Silverlight 1.0</td></tr><tr><th id="L3"><a href="#L3">3</a></th><td>*</td></tr><tr><th id="L4"><a href="#L4">4</a></th><td>* This file contains all logic for the JW WMV Player. For a functional setup,</td></tr><tr><th id="L5"><a href="#L5">5</a></th><td>* the following two files are also needed:</td></tr><tr><th id="L6"><a href="#L6">6</a></th><td>* - silverlight.js (for instantiating the silverlight plugin)</td></tr><tr><th id="L7"><a href="#L7">7</a></th><td>* - wmvplayer.xaml (or another XAML skin describing the player graphics)</td></tr><tr><th id="L8"><a href="#L8">8</a></th><td>*</td></tr><tr><th id="L9"><a href="#L9">9</a></th><td>* More info: http://www.jeroenwijering.com/?item=JW_WMV_Player</td></tr><tr><th id="L10"><a href="#L10">10</a></th><td>****************************************************************************/</td></tr><tr><th id="L11"><a href="#L11">11</a></th><td>if(typeof jeroenwijering == "undefined") {</td></tr><tr><th id="L12"><a href="#L12">12</a></th><td>        var jeroenwijering = new Object();</td></tr><tr><th id="L13"><a href="#L13">13</a></th><td>        jeroenwijering.utils = new Object();</td></tr><tr><th id="L14"><a href="#L14">14</a></th><td>}</td></tr><tr><th id="L15"><a href="#L15">15</a></th><td></td></tr><tr><th id="L16"><a href="#L16">16</a></th><td></td></tr><tr><th id="L17"><a href="#L17">17</a></th><td></td></tr><tr><th id="L18"><a href="#L18">18</a></th><td></td></tr><tr><th id="L19"><a href="#L19">19</a></th><td></td></tr><tr><th id="L20"><a href="#L20">20</a></th><td></td></tr><tr><th id="L21"><a href="#L21">21</a></th><td></td></tr><tr><th id="L22"><a href="#L22">22</a></th><td></td></tr><tr><th id="L23"><a href="#L23">23</a></th><td></td></tr><tr><th id="L24"><a href="#L24">24</a></th><td></td></tr><tr><th id="L25"><a href="#L25">25</a></th><td>/****************************************************************************</td></tr><tr><th id="L26"><a href="#L26">26</a></th><td>* The player wrapper; loads config variables and starts MVC cycle.</td></tr><tr><th id="L27"><a href="#L27">27</a></th><td>****************************************************************************/</td></tr><tr><th id="L28"><a href="#L28">28</a></th><td>jeroenwijering.Player = function(cnt,src,cfg) {</td></tr><tr><th id="L29"><a href="#L29">29</a></th><td>        this.controller;</td></tr><tr><th id="L30"><a href="#L30">30</a></th><td>        this.model;</td></tr><tr><th id="L31"><a href="#L31">31</a></th><td>        this.view;</td></tr><tr><th id="L32"><a href="#L32">32</a></th><td>        this.configuration = {</td></tr><tr><th id="L33"><a href="#L33">33</a></th><td>                backgroundcolor:'FFFFFF',</td></tr><tr><th id="L34"><a href="#L34">34</a></th><td>                windowless:'false',</td></tr><tr><th id="L35"><a href="#L35">35</a></th><td>                file:'',</td></tr><tr><th id="L36"><a href="#L36">36</a></th><td>                height:'260',</td></tr><tr><th id="L37"><a href="#L37">37</a></th><td>                image:'',</td></tr><tr><th id="L38"><a href="#L38">38</a></th><td>                backcolor:'FFFFFF',</td></tr><tr><th id="L39"><a href="#L39">39</a></th><td>                frontcolor:'000000',</td></tr><tr><th id="L40"><a href="#L40">40</a></th><td>                lightcolor:'000000',</td></tr><tr><th id="L41"><a href="#L41">41</a></th><td>                screencolor:'000000',</td></tr><tr><th id="L42"><a href="#L42">42</a></th><td>                width:'320',</td></tr><tr><th id="L43"><a href="#L43">43</a></th><td>                logo:'',</td></tr><tr><th id="L44"><a href="#L44">44</a></th><td>                overstretch:'false',</td></tr><tr><th id="L45"><a href="#L45">45</a></th><td>                shownavigation:'true',</td></tr><tr><th id="L46"><a href="#L46">46</a></th><td>                showstop:'false',</td></tr><tr><th id="L47"><a href="#L47">47</a></th><td>                showdigits:'true',</td></tr><tr><th id="L48"><a href="#L48">48</a></th><td>                usefullscreen:'true',</td></tr><tr><th id="L49"><a href="#L49">49</a></th><td>                usemute:'false',</td></tr><tr><th id="L50"><a href="#L50">50</a></th><td>                autostart:'false',</td></tr><tr><th id="L51"><a href="#L51">51</a></th><td>                bufferlength:'3',</td></tr><tr><th id="L52"><a href="#L52">52</a></th><td>                duration:'0',</td></tr><tr><th id="L53"><a href="#L53">53</a></th><td>                repeat:'false',</td></tr><tr><th id="L54"><a href="#L54">54</a></th><td>                sender:'',</td></tr><tr><th id="L55"><a href="#L55">55</a></th><td>                start:'0',</td></tr><tr><th id="L56"><a href="#L56">56</a></th><td>                volume:'90',</td></tr><tr><th id="L57"><a href="#L57">57</a></th><td>                link:'',</td></tr><tr><th id="L58"><a href="#L58">58</a></th><td>                linkfromdisplay:'false',</td></tr><tr><th id="L59"><a href="#L59">59</a></th><td>                linktarget:'_self'</td></tr><tr><th id="L60"><a href="#L60">60</a></th><td>        };</td></tr><tr><th id="L61"><a href="#L61">61</a></th><td>        for(itm in this.configuration) {</td></tr><tr><th id="L62"><a href="#L62">62</a></th><td>                if(cfg[itm] != undefined) {</td></tr><tr><th id="L63"><a href="#L63">63</a></th><td>                        if (itm.indexOf('color') &gt; 0) { </td></tr><tr><th id="L64"><a href="#L64">64</a></th><td>                                this.configuration[itm] = cfg[itm].substr(cfg[itm].length-6);</td></tr><tr><th id="L65"><a href="#L65">65</a></th><td>                        } else {</td></tr><tr><th id="L66"><a href="#L66">66</a></th><td>                                this.configuration[itm] = cfg[itm];</td></tr><tr><th id="L67"><a href="#L67">67</a></th><td>                        }</td></tr><tr><th id="L68"><a href="#L68">68</a></th><td>                }</td></tr><tr><th id="L69"><a href="#L69">69</a></th><td>        }</td></tr><tr><th id="L70"><a href="#L70">70</a></th><td>        Silverlight.createObjectEx({</td></tr><tr><th id="L71"><a href="#L71">71</a></th><td>                source:src,</td></tr><tr><th id="L72"><a href="#L72">72</a></th><td>                parentElement:cnt,</td></tr><tr><th id="L73"><a href="#L73">73</a></th><td>                properties:{</td></tr><tr><th id="L74"><a href="#L74">74</a></th><td>                        width:this.configuration['width'],</td></tr><tr><th id="L75"><a href="#L75">75</a></th><td>                        height:this.configuration['height'],</td></tr><tr><th id="L76"><a href="#L76">76</a></th><td>                        version:'1.0',</td></tr><tr><th id="L77"><a href="#L77">77</a></th><td>                        inplaceInstallPrompt:true,</td></tr><tr><th id="L78"><a href="#L78">78</a></th><td>                        isWindowless:this.configuration['windowless'],</td></tr><tr><th id="L79"><a href="#L79">79</a></th><td>                        background:'#'+this.configuration['backgroundcolor']</td></tr><tr><th id="L80"><a href="#L80">80</a></th><td>                },</td></tr><tr><th id="L81"><a href="#L81">81</a></th><td>                events:{</td></tr><tr><th id="L82"><a href="#L82">82</a></th><td>                        onLoad:this.onLoadHandler,</td></tr><tr><th id="L83"><a href="#L83">83</a></th><td>                        onError:null</td></tr><tr><th id="L84"><a href="#L84">84</a></th><td>                },</td></tr><tr><th id="L85"><a href="#L85">85</a></th><td>                context:this</td></tr><tr><th id="L86"><a href="#L86">86</a></th><td>        });</td></tr><tr><th id="L87"><a href="#L87">87</a></th><td>}</td></tr><tr><th id="L88"><a href="#L88">88</a></th><td></td></tr><tr><th id="L89"><a href="#L89">89</a></th><td>jeroenwijering.Player.prototype = {</td></tr><tr><th id="L90"><a href="#L90">90</a></th><td>        addListener: function(typ,fcn) {</td></tr><tr><th id="L91"><a href="#L91">91</a></th><td>                this.view.listeners.push({type:typ,func:fcn});</td></tr><tr><th id="L92"><a href="#L92">92</a></th><td>        },</td></tr><tr><th id="L93"><a href="#L93">93</a></th><td></td></tr><tr><th id="L94"><a href="#L94">94</a></th><td>        getConfig: function() { </td></tr><tr><th id="L95"><a href="#L95">95</a></th><td>                return this.configuration;</td></tr><tr><th id="L96"><a href="#L96">96</a></th><td>        },</td></tr><tr><th id="L97"><a href="#L97">97</a></th><td></td></tr><tr><th id="L98"><a href="#L98">98</a></th><td>        onLoadHandler: function(pid,tgt,sdr) {</td></tr><tr><th id="L99"><a href="#L99">99</a></th><td>                tgt.configuration['sender'] = sdr;</td></tr><tr><th id="L100"><a href="#L100">100</a></th><td>                tgt.controller = new jeroenwijering.Controller(tgt.configuration);</td></tr><tr><th id="L101"><a href="#L101">101</a></th><td>                tgt.view = new jeroenwijering.View(tgt.configuration,tgt.controller);</td></tr><tr><th id="L102"><a href="#L102">102</a></th><td>                tgt.model = new jeroenwijering.Model(tgt.configuration,tgt.controller,tgt.view);</td></tr><tr><th id="L103"><a href="#L103">103</a></th><td>                tgt.controller.startMVC(tgt.view,tgt.model);</td></tr><tr><th id="L104"><a href="#L104">104</a></th><td>        },</td></tr><tr><th id="L105"><a href="#L105">105</a></th><td></td></tr><tr><th id="L106"><a href="#L106">106</a></th><td>        sendEvent: function(typ,prm) {</td></tr><tr><th id="L107"><a href="#L107">107</a></th><td>                switch(typ.toUpperCase()) {</td></tr><tr><th id="L108"><a href="#L108">108</a></th><td>                        case 'LINK':</td></tr><tr><th id="L109"><a href="#L109">109</a></th><td>                                this.controller.setLink();</td></tr><tr><th id="L110"><a href="#L110">110</a></th><td>                                break;</td></tr><tr><th id="L111"><a href="#L111">111</a></th><td>                        case 'LOAD':</td></tr><tr><th id="L112"><a href="#L112">112</a></th><td>                                this.controller.setLoad(prm);</td></tr><tr><th id="L113"><a href="#L113">113</a></th><td>                                break;</td></tr><tr><th id="L114"><a href="#L114">114</a></th><td>                        case 'MUTE':</td></tr><tr><th id="L115"><a href="#L115">115</a></th><td>                                this.controller.setMute();</td></tr><tr><th id="L116"><a href="#L116">116</a></th><td>                                break;</td></tr><tr><th id="L117"><a href="#L117">117</a></th><td>                        case 'PLAY':</td></tr><tr><th id="L118"><a href="#L118">118</a></th><td>                                this.controller.setPlay();</td></tr><tr><th id="L119"><a href="#L119">119</a></th><td>                                break;</td></tr><tr><th id="L120"><a href="#L120">120</a></th><td>                        case 'SCRUB':</td></tr><tr><th id="L121"><a href="#L121">121</a></th><td>                                this.controller.setScrub(prm);</td></tr><tr><th id="L122"><a href="#L122">122</a></th><td>                                break;</td></tr><tr><th id="L123"><a href="#L123">123</a></th><td>                        case 'STOP':</td></tr><tr><th id="L124"><a href="#L124">124</a></th><td>                                this.controller.setStop();</td></tr><tr><th id="L125"><a href="#L125">125</a></th><td>                                break;</td></tr><tr><th id="L126"><a href="#L126">126</a></th><td>                        case 'VOLUME':</td></tr><tr><th id="L127"><a href="#L127">127</a></th><td>                                this.controller.setVolume(prm);</td></tr><tr><th id="L128"><a href="#L128">128</a></th><td>                                break;</td></tr><tr><th id="L129"><a href="#L129">129</a></th><td>                }</td></tr><tr><th id="L130"><a href="#L130">130</a></th><td>        }</td></tr><tr><th id="L131"><a href="#L131">131</a></th><td>}</td></tr><tr><th id="L132"><a href="#L132">132</a></th><td></td></tr><tr><th id="L133"><a href="#L133">133</a></th><td></td></tr><tr><th id="L134"><a href="#L134">134</a></th><td></td></tr><tr><th id="L135"><a href="#L135">135</a></th><td></td></tr><tr><th id="L136"><a href="#L136">136</a></th><td></td></tr><tr><th id="L137"><a href="#L137">137</a></th><td></td></tr><tr><th id="L138"><a href="#L138">138</a></th><td></td></tr><tr><th id="L139"><a href="#L139">139</a></th><td></td></tr><tr><th id="L140"><a href="#L140">140</a></th><td></td></tr><tr><th id="L141"><a href="#L141">141</a></th><td></td></tr><tr><th id="L142"><a href="#L142">142</a></th><td>/****************************************************************************</td></tr><tr><th id="L143"><a href="#L143">143</a></th><td>* The controller of the player MVC triad, which processes all user input.</td></tr><tr><th id="L144"><a href="#L144">144</a></th><td>****************************************************************************/</td></tr><tr><th id="L145"><a href="#L145">145</a></th><td>jeroenwijering.Controller = function(cfg) {</td></tr><tr><th id="L146"><a href="#L146">146</a></th><td>        this.configuration = cfg;</td></tr><tr><th id="L147"><a href="#L147">147</a></th><td>}</td></tr><tr><th id="L148"><a href="#L148">148</a></th><td></td></tr><tr><th id="L149"><a href="#L149">149</a></th><td>jeroenwijering.Controller.prototype = {</td></tr><tr><th id="L150"><a href="#L150">150</a></th><td>        startMVC: function(vie,mdl) {</td></tr><tr><th id="L151"><a href="#L151">151</a></th><td>                this.view = vie;</td></tr><tr><th id="L152"><a href="#L152">152</a></th><td>                this.model = mdl;</td></tr><tr><th id="L153"><a href="#L153">153</a></th><td>                if(this.configuration['usemute'] == 'true') {</td></tr><tr><th id="L154"><a href="#L154">154</a></th><td>                        this.view.onVolume(0);</td></tr><tr><th id="L155"><a href="#L155">155</a></th><td>                        this.view.onMute(true);</td></tr><tr><th id="L156"><a href="#L156">156</a></th><td>                        this.model.goVolume(0);</td></tr><tr><th id="L157"><a href="#L157">157</a></th><td>                } else {</td></tr><tr><th id="L158"><a href="#L158">158</a></th><td>                        this.view.onVolume(this.configuration['volume']);</td></tr><tr><th id="L159"><a href="#L159">159</a></th><td>                        this.model.goVolume(this.configuration['volume']);</td></tr><tr><th id="L160"><a href="#L160">160</a></th><td>                }</td></tr><tr><th id="L161"><a href="#L161">161</a></th><td>                if(this.configuration['autostart'] == 'true') {</td></tr><tr><th id="L162"><a href="#L162">162</a></th><td>                        this.model.goStart();</td></tr><tr><th id="L163"><a href="#L163">163</a></th><td>                } else { </td></tr><tr><th id="L164"><a href="#L164">164</a></th><td>                        this.model.goPause();</td></tr><tr><th id="L165"><a href="#L165">165</a></th><td>                }</td></tr><tr><th id="L166"><a href="#L166">166</a></th><td>        },</td></tr><tr><th id="L167"><a href="#L167">167</a></th><td></td></tr><tr><th id="L168"><a href="#L168">168</a></th><td>        setState: function(old,stt) {</td></tr><tr><th id="L169"><a href="#L169">169</a></th><td>                this.state = stt;</td></tr><tr><th id="L170"><a href="#L170">170</a></th><td>                var pos = this.configuration['start'];</td></tr><tr><th id="L171"><a href="#L171">171</a></th><td>                if(old == 'Closed' &amp;&amp; pos &gt; 0) {</td></tr><tr><th id="L172"><a href="#L172">172</a></th><td>                        setTimeout(jeroenwijering.utils.delegate(this,this.setScrub),200,pos);</td></tr><tr><th id="L173"><a href="#L173">173</a></th><td>                } </td></tr><tr><th id="L174"><a href="#L174">174</a></th><td>        },</td></tr><tr><th id="L175"><a href="#L175">175</a></th><td></td></tr><tr><th id="L176"><a href="#L176">176</a></th><td>        setLink: function() {</td></tr><tr><th id="L177"><a href="#L177">177</a></th><td>                if (this.configuration['linktarget'].indexOf('javascript:') == 0) {</td></tr><tr><th id="L178"><a href="#L178">178</a></th><td>                        return Function(this.configuration['linktarget']).apply();</td></tr><tr><th id="L179"><a href="#L179">179</a></th><td>                } else if (this.configuration['linktarget'] == '_blank') {</td></tr><tr><th id="L180"><a href="#L180">180</a></th><td>                        window.open(this.configuration['link']);</td></tr><tr><th id="L181"><a href="#L181">181</a></th><td>                } else if (this.configuration['linktarget'] != '') {</td></tr><tr><th id="L182"><a href="#L182">182</a></th><td>                        window.location = this.configuration['link'];</td></tr><tr><th id="L183"><a href="#L183">183</a></th><td>                }</td></tr><tr><th id="L184"><a href="#L184">184</a></th><td>        },</td></tr><tr><th id="L185"><a href="#L185">185</a></th><td></td></tr><tr><th id="L186"><a href="#L186">186</a></th><td>        setLoad: function(fil) {</td></tr><tr><th id="L187"><a href="#L187">187</a></th><td>                if(this.model.state != "Closed") {</td></tr><tr><th id="L188"><a href="#L188">188</a></th><td>                        this.model.goStop(); </td></tr><tr><th id="L189"><a href="#L189">189</a></th><td>                }</td></tr><tr><th id="L190"><a href="#L190">190</a></th><td>                this.configuration['file'] = fil;</td></tr><tr><th id="L191"><a href="#L191">191</a></th><td>                if(this.configuration['autostart'] == 'true') {</td></tr><tr><th id="L192"><a href="#L192">192</a></th><td>                        setTimeout(jeroenwijering.utils.delegate(this.model,this.model.goStart),100);</td></tr><tr><th id="L193"><a href="#L193">193</a></th><td>                }</td></tr><tr><th id="L194"><a href="#L194">194</a></th><td>        },</td></tr><tr><th id="L195"><a href="#L195">195</a></th><td></td></tr><tr><th id="L196"><a href="#L196">196</a></th><td>        setMute: function() {</td></tr><tr><th id="L197"><a href="#L197">197</a></th><td>                if(this.configuration['usemute'] == 'true') {</td></tr><tr><th id="L198"><a href="#L198">198</a></th><td>                        this.configuration['usemute'] = 'false';</td></tr><tr><th id="L199"><a href="#L199">199</a></th><td>                        this.model.goVolume(this.configuration['volume']);</td></tr><tr><th id="L200"><a href="#L200">200</a></th><td>                        this.view.onMute(false);</td></tr><tr><th id="L201"><a href="#L201">201</a></th><td>                } else {</td></tr><tr><th id="L202"><a href="#L202">202</a></th><td>                        this.configuration['usemute'] = 'true';</td></tr><tr><th id="L203"><a href="#L203">203</a></th><td>                        this.model.goVolume(0);</td></tr><tr><th id="L204"><a href="#L204">204</a></th><td>                        this.view.onMute(true);</td></tr><tr><th id="L205"><a href="#L205">205</a></th><td>                }</td></tr><tr><th id="L206"><a href="#L206">206</a></th><td>        },</td></tr><tr><th id="L207"><a href="#L207">207</a></th><td></td></tr><tr><th id="L208"><a href="#L208">208</a></th><td>        setPlay: function() {</td></tr><tr><th id="L209"><a href="#L209">209</a></th><td>                if(this.state == 'Buffering' || this.state == 'Playing') {</td></tr><tr><th id="L210"><a href="#L210">210</a></th><td>                        if(this.configuration['duration'] == 0) { </td></tr><tr><th id="L211"><a href="#L211">211</a></th><td>                                this.model.goStop();</td></tr><tr><th id="L212"><a href="#L212">212</a></th><td>                        } else { </td></tr><tr><th id="L213"><a href="#L213">213</a></th><td>                                this.model.goPause();</td></tr><tr><th id="L214"><a href="#L214">214</a></th><td>                        }</td></tr><tr><th id="L215"><a href="#L215">215</a></th><td>                } else {</td></tr><tr><th id="L216"><a href="#L216">216</a></th><td>                        this.model.goStart();</td></tr><tr><th id="L217"><a href="#L217">217</a></th><td>                }</td></tr><tr><th id="L218"><a href="#L218">218</a></th><td>        },</td></tr><tr><th id="L219"><a href="#L219">219</a></th><td></td></tr><tr><th id="L220"><a href="#L220">220</a></th><td>        setScrub: function(sec) {</td></tr><tr><th id="L221"><a href="#L221">221</a></th><td>                if(sec &lt; 2) {</td></tr><tr><th id="L222"><a href="#L222">222</a></th><td>                        sec = 0;</td></tr><tr><th id="L223"><a href="#L223">223</a></th><td>                } else if (sec &gt; this.configuration['duration']-4) {</td></tr><tr><th id="L224"><a href="#L224">224</a></th><td>                        sec = this.configuration['duration']-4;</td></tr><tr><th id="L225"><a href="#L225">225</a></th><td>                }</td></tr><tr><th id="L226"><a href="#L226">226</a></th><td>                if(this.state == 'Buffering' || this.state == 'Playing') {</td></tr><tr><th id="L227"><a href="#L227">227</a></th><td>                        this.model.goStart(sec);</td></tr><tr><th id="L228"><a href="#L228">228</a></th><td>                } else {</td></tr><tr><th id="L229"><a href="#L229">229</a></th><td>                        this.model.goPause(sec);</td></tr><tr><th id="L230"><a href="#L230">230</a></th><td>                }</td></tr><tr><th id="L231"><a href="#L231">231</a></th><td>        },</td></tr><tr><th id="L232"><a href="#L232">232</a></th><td></td></tr><tr><th id="L233"><a href="#L233">233</a></th><td>        setStop: function() {</td></tr><tr><th id="L234"><a href="#L234">234</a></th><td>                this.model.goStop();</td></tr><tr><th id="L235"><a href="#L235">235</a></th><td>        },</td></tr><tr><th id="L236"><a href="#L236">236</a></th><td></td></tr><tr><th id="L237"><a href="#L237">237</a></th><td>        setVolume: function(pct) {</td></tr><tr><th id="L238"><a href="#L238">238</a></th><td>                if(pct &lt; 0) { pct = 0; } else if(pct &gt; 100) { pct = 100; }</td></tr><tr><th id="L239"><a href="#L239">239</a></th><td>                this.configuration['volume'] = Math.round(pct);</td></tr><tr><th id="L240"><a href="#L240">240</a></th><td>                this.model.goVolume(pct);</td></tr><tr><th id="L241"><a href="#L241">241</a></th><td>                this.view.onVolume(pct);</td></tr><tr><th id="L242"><a href="#L242">242</a></th><td>                if(this.configuration['usemute'] == 'true') {</td></tr><tr><th id="L243"><a href="#L243">243</a></th><td>                        this.configuration['usemute'] = 'false';</td></tr><tr><th id="L244"><a href="#L244">244</a></th><td>                        this.view.onMute(false);</td></tr><tr><th id="L245"><a href="#L245">245</a></th><td>                } </td></tr><tr><th id="L246"><a href="#L246">246</a></th><td>        },</td></tr><tr><th id="L247"><a href="#L247">247</a></th><td></td></tr><tr><th id="L248"><a href="#L248">248</a></th><td>        setFullscreen: function() {</td></tr><tr><th id="L249"><a href="#L249">249</a></th><td>                var fss = !this.configuration['sender'].getHost().content.FullScreen;</td></tr><tr><th id="L250"><a href="#L250">250</a></th><td>                this.configuration['sender'].getHost().content.FullScreen = fss;</td></tr><tr><th id="L251"><a href="#L251">251</a></th><td>                jeroenwijering.utils.delegate(this.view,this.view.onFullscreen);</td></tr><tr><th id="L252"><a href="#L252">252</a></th><td>        }</td></tr><tr><th id="L253"><a href="#L253">253</a></th><td>}</td></tr><tr><th id="L254"><a href="#L254">254</a></th><td></td></tr><tr><th id="L255"><a href="#L255">255</a></th><td></td></tr><tr><th id="L256"><a href="#L256">256</a></th><td></td></tr><tr><th id="L257"><a href="#L257">257</a></th><td></td></tr><tr><th id="L258"><a href="#L258">258</a></th><td></td></tr><tr><th id="L259"><a href="#L259">259</a></th><td></td></tr><tr><th id="L260"><a href="#L260">260</a></th><td></td></tr><tr><th id="L261"><a href="#L261">261</a></th><td></td></tr><tr><th id="L262"><a href="#L262">262</a></th><td></td></tr><tr><th id="L263"><a href="#L263">263</a></th><td></td></tr><tr><th id="L264"><a href="#L264">264</a></th><td>/****************************************************************************</td></tr><tr><th id="L265"><a href="#L265">265</a></th><td>* The view of the player MVC triad, which manages the graphics.</td></tr><tr><th id="L266"><a href="#L266">266</a></th><td>****************************************************************************/</td></tr><tr><th id="L267"><a href="#L267">267</a></th><td>jeroenwijering.View = function(cfg,ctr) {</td></tr><tr><th id="L268"><a href="#L268">268</a></th><td>        this.configuration = cfg;</td></tr><tr><th id="L269"><a href="#L269">269</a></th><td>        this.listeners = Array();</td></tr><tr><th id="L270"><a href="#L270">270</a></th><td>        this.controller = ctr;</td></tr><tr><th id="L271"><a href="#L271">271</a></th><td>        this.fstimeout;</td></tr><tr><th id="L272"><a href="#L272">272</a></th><td>        this.fslistener;</td></tr><tr><th id="L273"><a href="#L273">273</a></th><td>        this.display = this.configuration['sender'].findName("PlayerDisplay");</td></tr><tr><th id="L274"><a href="#L274">274</a></th><td>        this.controlbar = this.configuration['sender'].findName("PlayerControls");</td></tr><tr><th id="L275"><a href="#L275">275</a></th><td>        this.configuration['sender'].getHost().content.onResize = </td></tr><tr><th id="L276"><a href="#L276">276</a></th><td>                jeroenwijering.utils.delegate(this,this.resizePlayer);</td></tr><tr><th id="L277"><a href="#L277">277</a></th><td>        this.configuration['sender'].getHost().content.onFullScreenChange = </td></tr><tr><th id="L278"><a href="#L278">278</a></th><td>                jeroenwijering.utils.delegate(this,this.onFullscreen);</td></tr><tr><th id="L279"><a href="#L279">279</a></th><td>        this.assignColorsClicks();</td></tr><tr><th id="L280"><a href="#L280">280</a></th><td>        this.resizePlayer();</td></tr><tr><th id="L281"><a href="#L281">281</a></th><td>}</td></tr><tr><th id="L282"><a href="#L282">282</a></th><td></td></tr><tr><th id="L283"><a href="#L283">283</a></th><td>jeroenwijering.View.prototype = {</td></tr><tr><th id="L284"><a href="#L284">284</a></th><td>        onBuffer: function(pct) {</td></tr><tr><th id="L285"><a href="#L285">285</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L286"><a href="#L286">286</a></th><td>                if(pct == 0) { </td></tr><tr><th id="L287"><a href="#L287">287</a></th><td>                        snd.findName("BufferText").Text = null;</td></tr><tr><th id="L288"><a href="#L288">288</a></th><td>                } else { </td></tr><tr><th id="L289"><a href="#L289">289</a></th><td>                        pct &lt; 10 ? pct = "0"+pct: pct = ""+pct;</td></tr><tr><th id="L290"><a href="#L290">290</a></th><td>                        snd.findName("BufferText").Text = pct;</td></tr><tr><th id="L291"><a href="#L291">291</a></th><td>                }</td></tr><tr><th id="L292"><a href="#L292">292</a></th><td>                this.delegate('BUFFER',[pct]);</td></tr><tr><th id="L293"><a href="#L293">293</a></th><td>        },</td></tr><tr><th id="L294"><a href="#L294">294</a></th><td></td></tr><tr><th id="L295"><a href="#L295">295</a></th><td>        onFullscreen: function(fss) {</td></tr><tr><th id="L296"><a href="#L296">296</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L297"><a href="#L297">297</a></th><td>                var fst = snd.getHost().content.FullScreen;</td></tr><tr><th id="L298"><a href="#L298">298</a></th><td>                if(fst) { </td></tr><tr><th id="L299"><a href="#L299">299</a></th><td>                        this.fstimeout = setTimeout(jeroenwijering.utils.delegate(this,</td></tr><tr><th id="L300"><a href="#L300">300</a></th><td>                                this.hideFSControls),2000);</td></tr><tr><th id="L301"><a href="#L301">301</a></th><td>                        this.fslistener = this.display.addEventListener('MouseMove',</td></tr><tr><th id="L302"><a href="#L302">302</a></th><td>                                jeroenwijering.utils.delegate(this,this.showFSControls));</td></tr><tr><th id="L303"><a href="#L303">303</a></th><td>                        snd.findName("FullscreenSymbol").Visibility = "Collapsed";</td></tr><tr><th id="L304"><a href="#L304">304</a></th><td>                        snd.findName("FullscreenOffSymbol").Visibility = "Visible";</td></tr><tr><th id="L305"><a href="#L305">305</a></th><td>                } else {</td></tr><tr><th id="L306"><a href="#L306">306</a></th><td>                        clearTimeout(this.fstimeout);</td></tr><tr><th id="L307"><a href="#L307">307</a></th><td>                        this.display.removeEventListener("MouseMove",this.fslistener);</td></tr><tr><th id="L308"><a href="#L308">308</a></th><td>                        this.controlbar.Visibility = "Visible";</td></tr><tr><th id="L309"><a href="#L309">309</a></th><td>                        this.display.Cursor = "Hand";</td></tr><tr><th id="L310"><a href="#L310">310</a></th><td>                        snd.findName("FullscreenSymbol").Visibility = "Visible";</td></tr><tr><th id="L311"><a href="#L311">311</a></th><td>                        snd.findName("FullscreenOffSymbol").Visibility = "Collapsed";</td></tr><tr><th id="L312"><a href="#L312">312</a></th><td>                }</td></tr><tr><th id="L313"><a href="#L313">313</a></th><td>                this.resizePlayer();</td></tr><tr><th id="L314"><a href="#L314">314</a></th><td>                this.delegate('FULLSCREEN');</td></tr><tr><th id="L315"><a href="#L315">315</a></th><td>        },</td></tr><tr><th id="L316"><a href="#L316">316</a></th><td></td></tr><tr><th id="L317"><a href="#L317">317</a></th><td>        showFSControls: function(sdr,arg) {</td></tr><tr><th id="L318"><a href="#L318">318</a></th><td>                var vbt = sdr.findName('PlayerControls');</td></tr><tr><th id="L319"><a href="#L319">319</a></th><td>                var yps = arg.GetPosition(vbt).Y;</td></tr><tr><th id="L320"><a href="#L320">320</a></th><td>                clearTimeout(this.fstimeout);</td></tr><tr><th id="L321"><a href="#L321">321</a></th><td>                this.controlbar.Visibility = "Visible";</td></tr><tr><th id="L322"><a href="#L322">322</a></th><td>                this.display.Cursor = "Hand";</td></tr><tr><th id="L323"><a href="#L323">323</a></th><td>                if(yps &lt; 0) { </td></tr><tr><th id="L324"><a href="#L324">324</a></th><td>                        this.fstimeout = setTimeout(jeroenwijering.utils.delegate(this,</td></tr><tr><th id="L325"><a href="#L325">325</a></th><td>                                this.hideFSControls),2000);</td></tr><tr><th id="L326"><a href="#L326">326</a></th><td>                }</td></tr><tr><th id="L327"><a href="#L327">327</a></th><td>        },</td></tr><tr><th id="L328"><a href="#L328">328</a></th><td></td></tr><tr><th id="L329"><a href="#L329">329</a></th><td>        hideFSControls: function() {</td></tr><tr><th id="L330"><a href="#L330">330</a></th><td>                this.controlbar.Visibility = "Collapsed";</td></tr><tr><th id="L331"><a href="#L331">331</a></th><td>                this.display.Cursor = "None";</td></tr><tr><th id="L332"><a href="#L332">332</a></th><td>        },</td></tr><tr><th id="L333"><a href="#L333">333</a></th><td></td></tr><tr><th id="L334"><a href="#L334">334</a></th><td>        onLoad: function(pct) {</td></tr><tr><th id="L335"><a href="#L335">335</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L336"><a href="#L336">336</a></th><td>                var max = snd.findName("TimeSlider").Width;</td></tr><tr><th id="L337"><a href="#L337">337</a></th><td>                snd.findName("DownloadProgress").Width = Math.round(max*pct/100);</td></tr><tr><th id="L338"><a href="#L338">338</a></th><td>                this.delegate('LOAD',[pct]);</td></tr><tr><th id="L339"><a href="#L339">339</a></th><td>        },</td></tr><tr><th id="L340"><a href="#L340">340</a></th><td></td></tr><tr><th id="L341"><a href="#L341">341</a></th><td>        onMute: function(mut) {</td></tr><tr><th id="L342"><a href="#L342">342</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L343"><a href="#L343">343</a></th><td>                this.configuration['usemute'] = ''+mut;</td></tr><tr><th id="L344"><a href="#L344">344</a></th><td>                if(mut) {</td></tr><tr><th id="L345"><a href="#L345">345</a></th><td>                        snd.findName("VolumeHighlight").Visibility = "Collapsed";</td></tr><tr><th id="L346"><a href="#L346">346</a></th><td>                        snd.findName("MuteSymbol").Visibility = "Visible";</td></tr><tr><th id="L347"><a href="#L347">347</a></th><td>                        snd.findName("MuteOffSymbol").Visibility = "Collapsed";</td></tr><tr><th id="L348"><a href="#L348">348</a></th><td>                        if(this.state == 'Playing') {</td></tr><tr><th id="L349"><a href="#L349">349</a></th><td>                                snd.findName("MuteIcon").Visibility = "Visible";</td></tr><tr><th id="L350"><a href="#L350">350</a></th><td>                        }</td></tr><tr><th id="L351"><a href="#L351">351</a></th><td>                } else {</td></tr><tr><th id="L352"><a href="#L352">352</a></th><td>                        snd.findName("VolumeHighlight").Visibility = "Visible";</td></tr><tr><th id="L353"><a href="#L353">353</a></th><td>                        snd.findName("MuteSymbol").Visibility = "Collapsed";</td></tr><tr><th id="L354"><a href="#L354">354</a></th><td>                        snd.findName("MuteOffSymbol").Visibility = "Visible";</td></tr><tr><th id="L355"><a href="#L355">355</a></th><td>                        snd.findName("MuteIcon").Visibility = "Collapsed";</td></tr><tr><th id="L356"><a href="#L356">356</a></th><td>                }</td></tr><tr><th id="L357"><a href="#L357">357</a></th><td>                this.delegate('MUTE');</td></tr><tr><th id="L358"><a href="#L358">358</a></th><td>        },</td></tr><tr><th id="L359"><a href="#L359">359</a></th><td></td></tr><tr><th id="L360"><a href="#L360">360</a></th><td>        onState: function(old,stt) {</td></tr><tr><th id="L361"><a href="#L361">361</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L362"><a href="#L362">362</a></th><td>                this.state = stt;</td></tr><tr><th id="L363"><a href="#L363">363</a></th><td>                if(stt == 'Buffering' || stt == 'Playing' || stt == 'Opening') {</td></tr><tr><th id="L364"><a href="#L364">364</a></th><td>                        snd.findName("PlayIcon").Visibility = "Collapsed";</td></tr><tr><th id="L365"><a href="#L365">365</a></th><td>                        snd.findName("PlaySymbol").Visibility = "Collapsed";</td></tr><tr><th id="L366"><a href="#L366">366</a></th><td>                        snd.findName("PlayOffSymbol").Visibility = "Visible";</td></tr><tr><th id="L367"><a href="#L367">367</a></th><td>                        if (stt=='Playing') {</td></tr><tr><th id="L368"><a href="#L368">368</a></th><td>                                snd.findName("BufferIcon").Visibility = "Collapsed";</td></tr><tr><th id="L369"><a href="#L369">369</a></th><td>                                snd.findName("BufferText").Visibility = "Collapsed";</td></tr><tr><th id="L370"><a href="#L370">370</a></th><td>                                if(this.configuration['usemute'] == 'true') {</td></tr><tr><th id="L371"><a href="#L371">371</a></th><td>                                        snd.findName("MuteIcon").Visibility = "Visible";</td></tr><tr><th id="L372"><a href="#L372">372</a></th><td>                                }</td></tr><tr><th id="L373"><a href="#L373">373</a></th><td>                        } else{</td></tr><tr><th id="L374"><a href="#L374">374</a></th><td>                                snd.findName("BufferIcon").Visibility = "Visible";</td></tr><tr><th id="L375"><a href="#L375">375</a></th><td>                                snd.findName("BufferText").Visibility = "Visible";</td></tr><tr><th id="L376"><a href="#L376">376</a></th><td>                        }</td></tr><tr><th id="L377"><a href="#L377">377</a></th><td>                } else { </td></tr><tr><th id="L378"><a href="#L378">378</a></th><td>                        snd.findName("MuteIcon").Visibility = "Collapsed";</td></tr><tr><th id="L379"><a href="#L379">379</a></th><td>                        snd.findName("BufferIcon").Visibility = "Collapsed";</td></tr><tr><th id="L380"><a href="#L380">380</a></th><td>                        snd.findName("BufferText").Visibility = "Collapsed";</td></tr><tr><th id="L381"><a href="#L381">381</a></th><td>                        snd.findName("PlayOffSymbol").Visibility = "Collapsed";</td></tr><tr><th id="L382"><a href="#L382">382</a></th><td>                        snd.findName("PlaySymbol").Visibility = "Visible";</td></tr><tr><th id="L383"><a href="#L383">383</a></th><td>                        if(this.configuration['linkfromdisplay'] == 'true') {</td></tr><tr><th id="L384"><a href="#L384">384</a></th><td>                                snd.findName("PlayIcon").Visibility = "Collapsed";</td></tr><tr><th id="L385"><a href="#L385">385</a></th><td>                        } else { </td></tr><tr><th id="L386"><a href="#L386">386</a></th><td>                                snd.findName("PlayIcon").Visibility = "Visible";</td></tr><tr><th id="L387"><a href="#L387">387</a></th><td>                        }</td></tr><tr><th id="L388"><a href="#L388">388</a></th><td>                }</td></tr><tr><th id="L389"><a href="#L389">389</a></th><td>                try {</td></tr><tr><th id="L390"><a href="#L390">390</a></th><td>                        if(!(old == 'Completed' &amp;&amp; stt == 'Buffering') &amp;&amp;</td></tr><tr><th id="L391"><a href="#L391">391</a></th><td>                                !(old == 'Buffering' &amp;&amp; stt == 'Paused')) {</td></tr><tr><th id="L392"><a href="#L392">392</a></th><td>                                playerStatusChange(old.toUpperCase(),stt.toUpperCase());</td></tr><tr><th id="L393"><a href="#L393">393</a></th><td>                        }</td></tr><tr><th id="L394"><a href="#L394">394</a></th><td>                } catch (err) {}</td></tr><tr><th id="L395"><a href="#L395">395</a></th><td>                this.delegate('STATE',[old,stt]);</td></tr><tr><th id="L396"><a href="#L396">396</a></th><td>        },</td></tr><tr><th id="L397"><a href="#L397">397</a></th><td></td></tr><tr><th id="L398"><a href="#L398">398</a></th><td>        onTime: function(elp,dur) {</td></tr><tr><th id="L399"><a href="#L399">399</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L400"><a href="#L400">400</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L401"><a href="#L401">401</a></th><td>                var max = snd.findName("TimeSlider").Width;</td></tr><tr><th id="L402"><a href="#L402">402</a></th><td>                if(dur &gt; 0) {</td></tr><tr><th id="L403"><a href="#L403">403</a></th><td>                        var pos = Math.round(max*elp/dur);</td></tr><tr><th id="L404"><a href="#L404">404</a></th><td>                        this.configuration['duration'] = dur;</td></tr><tr><th id="L405"><a href="#L405">405</a></th><td>                        snd.findName("ElapsedText").Text = jeroenwijering.utils.timestring(elp);</td></tr><tr><th id="L406"><a href="#L406">406</a></th><td>                        snd.findName("RemainingText").Text = jeroenwijering.utils.timestring(dur-elp);</td></tr><tr><th id="L407"><a href="#L407">407</a></th><td>                        snd.findName("TimeSymbol").Visibility = "Visible";</td></tr><tr><th id="L408"><a href="#L408">408</a></th><td>                        snd.findName("TimeSymbol")['Canvas.Left'] = pos+4;</td></tr><tr><th id="L409"><a href="#L409">409</a></th><td>                        snd.findName("TimeHighlight").Width = pos-2;</td></tr><tr><th id="L410"><a href="#L410">410</a></th><td>                } else  { </td></tr><tr><th id="L411"><a href="#L411">411</a></th><td>                        snd.findName("TimeSymbol").Visibility = "Collapsed";</td></tr><tr><th id="L412"><a href="#L412">412</a></th><td>                }</td></tr><tr><th id="L413"><a href="#L413">413</a></th><td>                this.delegate('TIME',[elp,dur]);</td></tr><tr><th id="L414"><a href="#L414">414</a></th><td>        },</td></tr><tr><th id="L415"><a href="#L415">415</a></th><td></td></tr><tr><th id="L416"><a href="#L416">416</a></th><td>        onVolume: function(pct) {</td></tr><tr><th id="L417"><a href="#L417">417</a></th><td>                var snd = this.configuration['sender'];</td></tr><tr><th id="L418"><a href="#L418">418</a></th><td>                snd.findName("VolumeHighlight").Width = Math.round(pct/5);</td></tr><tr><th id="L419"><a href="#L419">419</a></th><td>                this.delegate('VOLUME',[pct]);</td></tr><tr><th id="L420"><a href="#L420">420</a></th><td>        },</td></tr><tr><th id="L421"><a href="#L421">421</a></th><td></td></tr><tr><th id="L422"><a href="#L422">422</a></th><td>        assignColorsClicks: function() {</td></tr><tr><th id="L423"><a href="#L423">423</a></th><td>                this.display.Cursor = "Hand";</td></tr><tr><th id="L424"><a href="#L424">424</a></th><td>                this.display.Background = "#FF"+this.configuration['screencolor'];</td></tr><tr><th id="L425"><a href="#L425">425</a></th><td>                if(this.configuration['linkfromdisplay'] == 'false') { </td></tr><tr><th id="L426"><a href="#L426">426</a></th><td>                        this.display.addEventListener('MouseLeftButtonUp',</td></tr><tr><th id="L427"><a href="#L427">427</a></th><td>                                jeroenwijering.utils.delegate(this.controller,</td></tr><tr><th id="L428"><a href="#L428">428</a></th><td>                                this.controller.setPlay));</td></tr><tr><th id="L429"><a href="#L429">429</a></th><td>                } else { </td></tr><tr><th id="L430"><a href="#L430">430</a></th><td>                        this.display.addEventListener('MouseLeftButtonUp',</td></tr><tr><th id="L431"><a href="#L431">431</a></th><td>                                jeroenwijering.utils.delegate(this.controller,</td></tr><tr><th id="L432"><a href="#L432">432</a></th><td>                                this.controller.setLink));</td></tr><tr><th id="L433"><a href="#L433">433</a></th><td>                        this.display.findName("PlayIcon").Visibility = "Collapsed";</td></tr><tr><th id="L434"><a href="#L434">434</a></th><td>                }</td></tr><tr><th id="L435"><a href="#L435">435</a></th><td>                if(this.configuration['logo'] != '') {</td></tr><tr><th id="L436"><a href="#L436">436</a></th><td>                        this.display.findName('OverlayCanvas').Visibility = "Visible";</td></tr><tr><th id="L437"><a href="#L437">437</a></th><td>                        this.display.findName('OverlayLogo').ImageSource = </td></tr><tr><th id="L438"><a href="#L438">438</a></th><td>                                this.configuration['logo'];</td></tr><tr><th id="L439"><a href="#L439">439</a></th><td>                }</td></tr><tr><th id="L440"><a href="#L440">440</a></th><td>                this.controlbar.findName("ControlbarBack").Fill = </td></tr><tr><th id="L441"><a href="#L441">441</a></th><td>                        "#FF"+this.configuration['backcolor'];</td></tr><tr><th id="L442"><a href="#L442">442</a></th><td>                this.assignButton('Play',this.controller.setPlay);</td></tr><tr><th id="L443"><a href="#L443">443</a></th><td>                this.assignButton('Stop',this.controller.setStop);</td></tr><tr><th id="L444"><a href="#L444">444</a></th><td>                this.configuration['sender'].findName('ElapsedText').Foreground = </td></tr><tr><th id="L445"><a href="#L445">445</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L446"><a href="#L446">446</a></th><td>                this.assignSlider('Time',this.changeTime);</td></tr><tr><th id="L447"><a href="#L447">447</a></th><td>                this.configuration['sender'].findName('DownloadProgress').Fill = </td></tr><tr><th id="L448"><a href="#L448">448</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L449"><a href="#L449">449</a></th><td>                this.configuration['sender'].findName('RemainingText').Foreground = </td></tr><tr><th id="L450"><a href="#L450">450</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L451"><a href="#L451">451</a></th><td>                this.assignButton('Link',this.controller.setLink);</td></tr><tr><th id="L452"><a href="#L452">452</a></th><td>                this.assignButton('Fullscreen',this.controller.setFullscreen);</td></tr><tr><th id="L453"><a href="#L453">453</a></th><td>                this.assignButton('Mute',this.controller.setMute);</td></tr><tr><th id="L454"><a href="#L454">454</a></th><td>                this.assignSlider('Volume',this.changeVolume);</td></tr><tr><th id="L455"><a href="#L455">455</a></th><td>        },</td></tr><tr><th id="L456"><a href="#L456">456</a></th><td></td></tr><tr><th id="L457"><a href="#L457">457</a></th><td>        assignButton: function(btn,act) {</td></tr><tr><th id="L458"><a href="#L458">458</a></th><td>                var el1 = this.configuration['sender'].findName(btn+'Button');</td></tr><tr><th id="L459"><a href="#L459">459</a></th><td>                el1.Cursor = "Hand";</td></tr><tr><th id="L460"><a href="#L460">460</a></th><td>                el1.addEventListener('MouseLeftButtonUp',</td></tr><tr><th id="L461"><a href="#L461">461</a></th><td>                        jeroenwijering.utils.delegate(this.controller,act));</td></tr><tr><th id="L462"><a href="#L462">462</a></th><td>                el1.addEventListener('MouseEnter',</td></tr><tr><th id="L463"><a href="#L463">463</a></th><td>                        jeroenwijering.utils.delegate(this,this.rollOver));</td></tr><tr><th id="L464"><a href="#L464">464</a></th><td>                el1.addEventListener('MouseLeave',</td></tr><tr><th id="L465"><a href="#L465">465</a></th><td>                        jeroenwijering.utils.delegate(this,this.rollOut));</td></tr><tr><th id="L466"><a href="#L466">466</a></th><td>                this.configuration['sender'].findName(btn+'Symbol').Fill = </td></tr><tr><th id="L467"><a href="#L467">467</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L468"><a href="#L468">468</a></th><td>                try {</td></tr><tr><th id="L469"><a href="#L469">469</a></th><td>                        this.configuration['sender'].findName(btn+'OffSymbol').Fill = </td></tr><tr><th id="L470"><a href="#L470">470</a></th><td>                                "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L471"><a href="#L471">471</a></th><td>                } catch(e) {}</td></tr><tr><th id="L472"><a href="#L472">472</a></th><td>        },</td></tr><tr><th id="L473"><a href="#L473">473</a></th><td></td></tr><tr><th id="L474"><a href="#L474">474</a></th><td>        assignSlider: function(sld,act) {</td></tr><tr><th id="L475"><a href="#L475">475</a></th><td>                var el1 = this.configuration['sender'].findName(sld+'Button');</td></tr><tr><th id="L476"><a href="#L476">476</a></th><td>                el1.Cursor = "Hand";</td></tr><tr><th id="L477"><a href="#L477">477</a></th><td>                el1.addEventListener('MouseLeftButtonUp',</td></tr><tr><th id="L478"><a href="#L478">478</a></th><td>                        jeroenwijering.utils.delegate(this,act));</td></tr><tr><th id="L479"><a href="#L479">479</a></th><td>                el1.addEventListener('MouseEnter',</td></tr><tr><th id="L480"><a href="#L480">480</a></th><td>                        jeroenwijering.utils.delegate(this,this.rollOver));</td></tr><tr><th id="L481"><a href="#L481">481</a></th><td>                el1.addEventListener('MouseLeave',</td></tr><tr><th id="L482"><a href="#L482">482</a></th><td>                        jeroenwijering.utils.delegate(this,this.rollOut));</td></tr><tr><th id="L483"><a href="#L483">483</a></th><td>                this.configuration['sender'].findName(sld+'Slider').Fill = </td></tr><tr><th id="L484"><a href="#L484">484</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L485"><a href="#L485">485</a></th><td>                this.configuration['sender'].findName(sld+'Highlight').Fill = </td></tr><tr><th id="L486"><a href="#L486">486</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L487"><a href="#L487">487</a></th><td>                this.configuration['sender'].findName(sld+'Symbol').Fill = </td></tr><tr><th id="L488"><a href="#L488">488</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L489"><a href="#L489">489</a></th><td>        },</td></tr><tr><th id="L490"><a href="#L490">490</a></th><td></td></tr><tr><th id="L491"><a href="#L491">491</a></th><td>        delegate: function(typ,arg) {</td></tr><tr><th id="L492"><a href="#L492">492</a></th><td>                for(var i=0; i&lt;this.listeners.length; i++) {</td></tr><tr><th id="L493"><a href="#L493">493</a></th><td>                        if(this.listeners[i]['type'].toUpperCase() == typ) {</td></tr><tr><th id="L494"><a href="#L494">494</a></th><td>                                this.listeners[i]['func'].apply(null,arg);</td></tr><tr><th id="L495"><a href="#L495">495</a></th><td>                        }</td></tr><tr><th id="L496"><a href="#L496">496</a></th><td>                }</td></tr><tr><th id="L497"><a href="#L497">497</a></th><td>        },</td></tr><tr><th id="L498"><a href="#L498">498</a></th><td></td></tr><tr><th id="L499"><a href="#L499">499</a></th><td>        rollOver: function(sdr) {</td></tr><tr><th id="L500"><a href="#L500">500</a></th><td>                var str = sdr.Name.substr(0,sdr.Name.length-6);</td></tr><tr><th id="L501"><a href="#L501">501</a></th><td>                this.configuration['sender'].findName(str+'Symbol').Fill = </td></tr><tr><th id="L502"><a href="#L502">502</a></th><td>                        "#FF"+this.configuration['lightcolor'];</td></tr><tr><th id="L503"><a href="#L503">503</a></th><td>                try {</td></tr><tr><th id="L504"><a href="#L504">504</a></th><td>                        this.configuration['sender'].findName(str+'OffSymbol').Fill = </td></tr><tr><th id="L505"><a href="#L505">505</a></th><td>                                "#FF"+this.configuration['lightcolor'];</td></tr><tr><th id="L506"><a href="#L506">506</a></th><td>                } catch(e) {}</td></tr><tr><th id="L507"><a href="#L507">507</a></th><td>        },</td></tr><tr><th id="L508"><a href="#L508">508</a></th><td></td></tr><tr><th id="L509"><a href="#L509">509</a></th><td>        rollOut: function(sdr) {</td></tr><tr><th id="L510"><a href="#L510">510</a></th><td>                var str = sdr.Name.substr(0,sdr.Name.length-6);</td></tr><tr><th id="L511"><a href="#L511">511</a></th><td>                this.configuration['sender'].findName(str+'Symbol').Fill = </td></tr><tr><th id="L512"><a href="#L512">512</a></th><td>                        "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L513"><a href="#L513">513</a></th><td>                try {</td></tr><tr><th id="L514"><a href="#L514">514</a></th><td>                        this.configuration['sender'].findName(str+'OffSymbol').Fill = </td></tr><tr><th id="L515"><a href="#L515">515</a></th><td>                                "#FF"+this.configuration['frontcolor'];</td></tr><tr><th id="L516"><a href="#L516">516</a></th><td>                } catch(e) {}</td></tr><tr><th id="L517"><a href="#L517">517</a></th><td>        },</td></tr><tr><th id="L518"><a href="#L518">518</a></th><td></td></tr><tr><th id="L519"><a href="#L519">519</a></th><td>        changeTime: function(sdr,arg) {</td></tr><tr><th id="L520"><a href="#L520">520</a></th><td>                var tbt = sdr.findName('TimeSlider');</td></tr><tr><th id="L521"><a href="#L521">521</a></th><td>                var xps = arg.GetPosition(tbt).X;</td></tr><tr><th id="L522"><a href="#L522">522</a></th><td>                var sec = Math.floor(xps/tbt.Width*this.configuration['duration']);</td></tr><tr><th id="L523"><a href="#L523">523</a></th><td>                this.controller.setScrub(sec);</td></tr><tr><th id="L524"><a href="#L524">524</a></th><td>        },</td></tr><tr><th id="L525"><a href="#L525">525</a></th><td></td></tr><tr><th id="L526"><a href="#L526">526</a></th><td>        changeVolume: function(sdr,arg) {</td></tr><tr><th id="L527"><a href="#L527">527</a></th><td>                var vbt = sdr.findName('VolumeButton');</td></tr><tr><th id="L528"><a href="#L528">528</a></th><td>                var xps = arg.GetPosition(vbt).X;</td></tr><tr><th id="L529"><a href="#L529">529</a></th><td>                this.controller.setVolume(xps*5);</td></tr><tr><th id="L530"><a href="#L530">530</a></th><td>        },</td></tr><tr><th id="L531"><a href="#L531">531</a></th><td></td></tr><tr><th id="L532"><a href="#L532">532</a></th><td>        resizePlayer: function() {</td></tr><tr><th id="L533"><a href="#L533">533</a></th><td>                var wid = this.configuration['sender'].getHost().content.actualWidth;</td></tr><tr><th id="L534"><a href="#L534">534</a></th><td>                var hei = this.configuration['sender'].getHost().content.actualHeight;</td></tr><tr><th id="L535"><a href="#L535">535</a></th><td>                var fss = this.configuration['sender'].getHost().content.FullScreen;</td></tr><tr><th id="L536"><a href="#L536">536</a></th><td>                if(this.configuration['shownavigation'] == 'true') {</td></tr><tr><th id="L537"><a href="#L537">537</a></th><td>                        if(fss == true) {</td></tr><tr><th id="L538"><a href="#L538">538</a></th><td>                                this.resizeDisplay(wid,hei);</td></tr><tr><th id="L539"><a href="#L539">539</a></th><td>                                this.controlbar['Canvas.Left'] = Math.round(wid/2-250);</td></tr><tr><th id="L540"><a href="#L540">540</a></th><td>                                this.resizeControlbar(500,hei-this.controlbar.Height-16);</td></tr><tr><th id="L541"><a href="#L541">541</a></th><td>                                this.controlbar.findName('ControlbarBack')['Opacity'] = 0.5;</td></tr><tr><th id="L542"><a href="#L542">542</a></th><td>                        } else { </td></tr><tr><th id="L543"><a href="#L543">543</a></th><td>                                this.resizeDisplay(wid,hei-20);</td></tr><tr><th id="L544"><a href="#L544">544</a></th><td>                                this.controlbar['Canvas.Left'] = 0;</td></tr><tr><th id="L545"><a href="#L545">545</a></th><td>                                this.resizeControlbar(wid,hei-this.controlbar.Height);</td></tr><tr><th id="L546"><a href="#L546">546</a></th><td>                                this.controlbar.findName('ControlbarBack')['Opacity'] = 1;</td></tr><tr><th id="L547"><a href="#L547">547</a></th><td>                        }</td></tr><tr><th id="L548"><a href="#L548">548</a></th><td>                } else {</td></tr><tr><th id="L549"><a href="#L549">549</a></th><td>                        this.resizeDisplay(wid,hei);</td></tr><tr><th id="L550"><a href="#L550">550</a></th><td>                }</td></tr><tr><th id="L551"><a href="#L551">551</a></th><td>        },</td></tr><tr><th id="L552"><a href="#L552">552</a></th><td></td></tr><tr><th id="L553"><a href="#L553">553</a></th><td>        resizeDisplay: function(wid,hei) {</td></tr><tr><th id="L554"><a href="#L554">554</a></th><td>                this.stretchElement('PlayerDisplay',wid,hei);</td></tr><tr><th id="L555"><a href="#L555">555</a></th><td>                this.stretchElement('VideoWindow',wid,hei);</td></tr><tr><th id="L556"><a href="#L556">556</a></th><td>                this.stretchElement('PlaceholderImage',wid,hei);</td></tr><tr><th id="L557"><a href="#L557">557</a></th><td>                this.centerElement('PlayIcon',wid,hei);</td></tr><tr><th id="L558"><a href="#L558">558</a></th><td>                this.centerElement('MuteIcon',wid,hei);</td></tr><tr><th id="L559"><a href="#L559">559</a></th><td>                this.centerElement('BufferIcon',wid,hei);</td></tr><tr><th id="L560"><a href="#L560">560</a></th><td>                this.centerElement('BufferText',wid,hei);</td></tr><tr><th id="L561"><a href="#L561">561</a></th><td>                this.display.findName('OverlayCanvas')['Canvas.Left'] = wid -</td></tr><tr><th id="L562"><a href="#L562">562</a></th><td>                        this.display.findName('OverlayCanvas').Width - 10;</td></tr><tr><th id="L563"><a href="#L563">563</a></th><td>                this.display.Visibility = "Visible";</td></tr><tr><th id="L564"><a href="#L564">564</a></th><td>        },</td></tr><tr><th id="L565"><a href="#L565">565</a></th><td></td></tr><tr><th id="L566"><a href="#L566">566</a></th><td>        resizeControlbar: function(wid,yps,alp) {</td></tr><tr><th id="L567"><a href="#L567">567</a></th><td>                this.controlbar['Canvas.Top'] = yps;</td></tr><tr><th id="L568"><a href="#L568">568</a></th><td>                this.stretchElement('PlayerControls',wid);</td></tr><tr><th id="L569"><a href="#L569">569</a></th><td>                this.stretchElement('ControlbarBack',wid);</td></tr><tr><th id="L570"><a href="#L570">570</a></th><td>                this.placeElement('PlayButton',0);</td></tr><tr><th id="L571"><a href="#L571">571</a></th><td>                var lft = 17;</td></tr><tr><th id="L572"><a href="#L572">572</a></th><td>                this.placeElement('VolumeButton',wid-24);</td></tr><tr><th id="L573"><a href="#L573">573</a></th><td>                this.placeElement('MuteButton',wid-37);</td></tr><tr><th id="L574"><a href="#L574">574</a></th><td>                var rgt = 37;</td></tr><tr><th id="L575"><a href="#L575">575</a></th><td>                if(this.configuration['showstop'] == 'true') {</td></tr><tr><th id="L576"><a href="#L576">576</a></th><td>                        this.placeElement('StopButton',lft);</td></tr><tr><th id="L577"><a href="#L577">577</a></th><td>                        lft += 17;</td></tr><tr><th id="L578"><a href="#L578">578</a></th><td>                } else {</td></tr><tr><th id="L579"><a href="#L579">579</a></th><td>                        this.controlbar.findName('StopButton').Visibility="Collapsed";</td></tr><tr><th id="L580"><a href="#L580">580</a></th><td>                }</td></tr><tr><th id="L581"><a href="#L581">581</a></th><td>                if(this.configuration['usefullscreen'] == 'true') {</td></tr><tr><th id="L582"><a href="#L582">582</a></th><td>                        rgt += 18;</td></tr><tr><th id="L583"><a href="#L583">583</a></th><td>                        this.placeElement('FullscreenButton',wid-rgt);</td></tr><tr><th id="L584"><a href="#L584">584</a></th><td>                } else {</td></tr><tr><th id="L585"><a href="#L585">585</a></th><td>                        this.controlbar.findName('FullscreenButton').Visibility = </td></tr><tr><th id="L586"><a href="#L586">586</a></th><td>                                "Collapsed";</td></tr><tr><th id="L587"><a href="#L587">587</a></th><td>                }</td></tr><tr><th id="L588"><a href="#L588">588</a></th><td>                if(this.configuration['link'] != '') {</td></tr><tr><th id="L589"><a href="#L589">589</a></th><td>                        rgt += 18;</td></tr><tr><th id="L590"><a href="#L590">590</a></th><td>                        this.placeElement('LinkButton',wid-rgt);</td></tr><tr><th id="L591"><a href="#L591">591</a></th><td>                } else {</td></tr><tr><th id="L592"><a href="#L592">592</a></th><td>                        this.controlbar.findName('LinkButton').Visibility="Collapsed";</td></tr><tr><th id="L593"><a href="#L593">593</a></th><td>                }</td></tr><tr><th id="L594"><a href="#L594">594</a></th><td>                if(this.configuration['showdigits'] == 'true' &amp;&amp; wid-rgt-lft&gt; 160) {</td></tr><tr><th id="L595"><a href="#L595">595</a></th><td>                        rgt += 35;</td></tr><tr><th id="L596"><a href="#L596">596</a></th><td>                        this.controlbar.findName('RemainingButton').Visibility="Visible";</td></tr><tr><th id="L597"><a href="#L597">597</a></th><td>                        this.controlbar.findName('ElapsedButton').Visibility="Visible";</td></tr><tr><th id="L598"><a href="#L598">598</a></th><td>                        this.placeElement('RemainingButton',wid-rgt);</td></tr><tr><th id="L599"><a href="#L599">599</a></th><td>                        this.placeElement('ElapsedButton',lft);</td></tr><tr><th id="L600"><a href="#L600">600</a></th><td>                        lft +=35;</td></tr><tr><th id="L601"><a href="#L601">601</a></th><td>                } else {</td></tr><tr><th id="L602"><a href="#L602">602</a></th><td>                        this.controlbar.findName('RemainingButton').Visibility = </td></tr><tr><th id="L603"><a href="#L603">603</a></th><td>                                "Collapsed";</td></tr><tr><th id="L604"><a href="#L604">604</a></th><td>                        this.controlbar.findName('ElapsedButton').Visibility="Collapsed";</td></tr><tr><th id="L605"><a href="#L605">605</a></th><td>                }</td></tr><tr><th id="L606"><a href="#L606">606</a></th><td>                this.placeElement('TimeButton',lft);</td></tr><tr><th id="L607"><a href="#L607">607</a></th><td>                this.stretchElement('TimeButton',wid-lft-rgt);</td></tr><tr><th id="L608"><a href="#L608">608</a></th><td>                this.stretchElement('TimeShadow',wid-lft-rgt);</td></tr><tr><th id="L609"><a href="#L609">609</a></th><td>                this.stretchElement('TimeStroke',wid-lft-rgt);</td></tr><tr><th id="L610"><a href="#L610">610</a></th><td>                this.stretchElement('TimeFill',wid-lft-rgt);</td></tr><tr><th id="L611"><a href="#L611">611</a></th><td>                this.stretchElement('TimeSlider',wid-lft-rgt-10);</td></tr><tr><th id="L612"><a href="#L612">612</a></th><td>                this.stretchElement('DownloadProgress',wid-lft-rgt-10);</td></tr><tr><th id="L613"><a href="#L613">613</a></th><td>                var tsb = this.configuration['sender'].findName('TimeSymbol');</td></tr><tr><th id="L614"><a href="#L614">614</a></th><td>                this.stretchElement('TimeHighlight',tsb['Canvas.Left']-5);</td></tr><tr><th id="L615"><a href="#L615">615</a></th><td>                this.controlbar.Visibility = "Visible";</td></tr><tr><th id="L616"><a href="#L616">616</a></th><td>        },</td></tr><tr><th id="L617"><a href="#L617">617</a></th><td></td></tr><tr><th id="L618"><a href="#L618">618</a></th><td>        centerElement: function(nam,wid,hei) {</td></tr><tr><th id="L619"><a href="#L619">619</a></th><td>                var elm = this.configuration['sender'].findName(nam);</td></tr><tr><th id="L620"><a href="#L620">620</a></th><td>                elm['Canvas.Left'] = Math.round(wid/2 - elm.Width/2);</td></tr><tr><th id="L621"><a href="#L621">621</a></th><td>                elm['Canvas.Top'] = Math.round(hei/2 - elm.Height/2);</td></tr><tr><th id="L622"><a href="#L622">622</a></th><td>        },</td></tr><tr><th id="L623"><a href="#L623">623</a></th><td></td></tr><tr><th id="L624"><a href="#L624">624</a></th><td>        stretchElement: function(nam,wid,hei) {</td></tr><tr><th id="L625"><a href="#L625">625</a></th><td>                var elm = this.configuration['sender'].findName(nam);</td></tr><tr><th id="L626"><a href="#L626">626</a></th><td>                elm.Width = wid;</td></tr><tr><th id="L627"><a href="#L627">627</a></th><td>                if (hei != undefined) { elm.Height = hei; }</td></tr><tr><th id="L628"><a href="#L628">628</a></th><td>        },</td></tr><tr><th id="L629"><a href="#L629">629</a></th><td></td></tr><tr><th id="L630"><a href="#L630">630</a></th><td>        placeElement: function(nam,xps,yps) {</td></tr><tr><th id="L631"><a href="#L631">631</a></th><td>                var elm = this.configuration['sender'].findName(nam);</td></tr><tr><th id="L632"><a href="#L632">632</a></th><td>                elm['Canvas.Left'] = xps;</td></tr><tr><th id="L633"><a href="#L633">633</a></th><td>                if(yps) { elm['Canvas.Top'] = yps; }</td></tr><tr><th id="L634"><a href="#L634">634</a></th><td>        }</td></tr><tr><th id="L635"><a href="#L635">635</a></th><td>}</td></tr><tr><th id="L636"><a href="#L636">636</a></th><td></td></tr><tr><th id="L637"><a href="#L637">637</a></th><td></td></tr><tr><th id="L638"><a href="#L638">638</a></th><td></td></tr><tr><th id="L639"><a href="#L639">639</a></th><td></td></tr><tr><th id="L640"><a href="#L640">640</a></th><td></td></tr><tr><th id="L641"><a href="#L641">641</a></th><td></td></tr><tr><th id="L642"><a href="#L642">642</a></th><td></td></tr><tr><th id="L643"><a href="#L643">643</a></th><td></td></tr><tr><th id="L644"><a href="#L644">644</a></th><td></td></tr><tr><th id="L645"><a href="#L645">645</a></th><td></td></tr><tr><th id="L646"><a href="#L646">646</a></th><td>/****************************************************************************</td></tr><tr><th id="L647"><a href="#L647">647</a></th><td>* The model of the player MVC triad, which stores all playback logic.</td></tr><tr><th id="L648"><a href="#L648">648</a></th><td>****************************************************************************/</td></tr><tr><th id="L649"><a href="#L649">649</a></th><td>jeroenwijering.Model = function(cfg,ctr,vie) {</td></tr><tr><th id="L650"><a href="#L650">650</a></th><td>        this.configuration = cfg;</td></tr><tr><th id="L651"><a href="#L651">651</a></th><td>        this.controller = ctr;</td></tr><tr><th id="L652"><a href="#L652">652</a></th><td>        this.view = vie;</td></tr><tr><th id="L653"><a href="#L653">653</a></th><td>        this.video = this.configuration['sender'].findName("VideoWindow");</td></tr><tr><th id="L654"><a href="#L654">654</a></th><td>        this.preview = this.configuration['sender'].findName("PlaceholderImage");</td></tr><tr><th id="L655"><a href="#L655">655</a></th><td>        var str = {</td></tr><tr><th id="L656"><a href="#L656">656</a></th><td>                'true':'UniformToFill',</td></tr><tr><th id="L657"><a href="#L657">657</a></th><td>                'false':'Uniform',</td></tr><tr><th id="L658"><a href="#L658">658</a></th><td>                'fit':'Fill',</td></tr><tr><th id="L659"><a href="#L659">659</a></th><td>                'none':'None'</td></tr><tr><th id="L660"><a href="#L660">660</a></th><td>        }</td></tr><tr><th id="L661"><a href="#L661">661</a></th><td>        this.state = this.video.CurrentState;</td></tr><tr><th id="L662"><a href="#L662">662</a></th><td>        this.timeint;</td></tr><tr><th id="L663"><a href="#L663">663</a></th><td>        this.video.Stretch = str[this.configuration['overstretch']];</td></tr><tr><th id="L664"><a href="#L664">664</a></th><td>        this.preview.Stretch = str[this.configuration['overstretch']];</td></tr><tr><th id="L665"><a href="#L665">665</a></th><td>        this.video.BufferingTime = </td></tr><tr><th id="L666"><a href="#L666">666</a></th><td>                jeroenwijering.utils.spanstring(this.configuration['bufferlength']);</td></tr><tr><th id="L667"><a href="#L667">667</a></th><td>        this.video.AutoPlay = true;</td></tr><tr><th id="L668"><a href="#L668">668</a></th><td>        this.video.AddEventListener("CurrentStateChanged",</td></tr><tr><th id="L669"><a href="#L669">669</a></th><td>                jeroenwijering.utils.delegate(this,this.stateChanged));</td></tr><tr><th id="L670"><a href="#L670">670</a></th><td>        this.video.AddEventListener("MediaEnded",</td></tr><tr><th id="L671"><a href="#L671">671</a></th><td>                jeroenwijering.utils.delegate(this,this.mediaEnded));</td></tr><tr><th id="L672"><a href="#L672">672</a></th><td>        this.video.AddEventListener("BufferingProgressChanged",</td></tr><tr><th id="L673"><a href="#L673">673</a></th><td>                jeroenwijering.utils.delegate(this,this.bufferChanged));</td></tr><tr><th id="L674"><a href="#L674">674</a></th><td>        this.video.AddEventListener("DownloadProgressChanged",</td></tr><tr><th id="L675"><a href="#L675">675</a></th><td>                jeroenwijering.utils.delegate(this,this.downloadChanged));</td></tr><tr><th id="L676"><a href="#L676">676</a></th><td>        if(this.configuration['image'] != '') {</td></tr><tr><th id="L677"><a href="#L677">677</a></th><td>                this.preview.Source = this.configuration['image'];</td></tr><tr><th id="L678"><a href="#L678">678</a></th><td>        }</td></tr><tr><th id="L679"><a href="#L679">679</a></th><td>}</td></tr><tr><th id="L680"><a href="#L680">680</a></th><td></td></tr><tr><th id="L681"><a href="#L681">681</a></th><td>jeroenwijering.Model.prototype = {</td></tr><tr><th id="L682"><a href="#L682">682</a></th><td>        goPause: function(sec) {</td></tr><tr><th id="L683"><a href="#L683">683</a></th><td>                this.video.pause();</td></tr><tr><th id="L684"><a href="#L684">684</a></th><td>                if(!isNaN(sec)) {</td></tr><tr><th id="L685"><a href="#L685">685</a></th><td>                        this.video.Position = jeroenwijering.utils.spanstring(sec);</td></tr><tr><th id="L686"><a href="#L686">686</a></th><td>                }</td></tr><tr><th id="L687"><a href="#L687">687</a></th><td>                this.timeChanged();</td></tr><tr><th id="L688"><a href="#L688">688</a></th><td>        },</td></tr><tr><th id="L689"><a href="#L689">689</a></th><td></td></tr><tr><th id="L690"><a href="#L690">690</a></th><td>        goStart: function(sec) {</td></tr><tr><th id="L691"><a href="#L691">691</a></th><td>                this.video.Visibility = 'Visible';</td></tr><tr><th id="L692"><a href="#L692">692</a></th><td>                this.preview.Visibility = 'Collapsed';</td></tr><tr><th id="L693"><a href="#L693">693</a></th><td>                if(this.state == "Closed") {</td></tr><tr><th id="L694"><a href="#L694">694</a></th><td>                        this.video.Source = this.configuration['file'];</td></tr><tr><th id="L695"><a href="#L695">695</a></th><td>                } else {</td></tr><tr><th id="L696"><a href="#L696">696</a></th><td>                        this.video.play();</td></tr><tr><th id="L697"><a href="#L697">697</a></th><td>                }</td></tr><tr><th id="L698"><a href="#L698">698</a></th><td>                if(!isNaN(sec)) {</td></tr><tr><th id="L699"><a href="#L699">699</a></th><td>                        this.video.Position = jeroenwijering.utils.spanstring(sec);</td></tr><tr><th id="L700"><a href="#L700">700</a></th><td>                }</td></tr><tr><th id="L701"><a href="#L701">701</a></th><td>        },</td></tr><tr><th id="L702"><a href="#L702">702</a></th><td></td></tr><tr><th id="L703"><a href="#L703">703</a></th><td>        goStop: function() {</td></tr><tr><th id="L704"><a href="#L704">704</a></th><td>                this.video.Visibility = 'Collapsed';</td></tr><tr><th id="L705"><a href="#L705">705</a></th><td>                this.preview.Visibility = 'Visible';</td></tr><tr><th id="L706"><a href="#L706">706</a></th><td>                this.goPause(0);</td></tr><tr><th id="L707"><a href="#L707">707</a></th><td>                this.video.Source = 'null';</td></tr><tr><th id="L708"><a href="#L708">708</a></th><td>                this.view.onBuffer(0);</td></tr><tr><th id="L709"><a href="#L709">709</a></th><td>                clearInterval(this.timeint);</td></tr><tr><th id="L710"><a href="#L710">710</a></th><td>        },</td></tr><tr><th id="L711"><a href="#L711">711</a></th><td></td></tr><tr><th id="L712"><a href="#L712">712</a></th><td>        goVolume: function(pct) {</td></tr><tr><th id="L713"><a href="#L713">713</a></th><td>                this.video.Volume = pct/100;</td></tr><tr><th id="L714"><a href="#L714">714</a></th><td>        },</td></tr><tr><th id="L715"><a href="#L715">715</a></th><td></td></tr><tr><th id="L716"><a href="#L716">716</a></th><td>        stateChanged: function() {</td></tr><tr><th id="L717"><a href="#L717">717</a></th><td>                var stt = this.video.CurrentState;</td></tr><tr><th id="L718"><a href="#L718">718</a></th><td>                if(stt != this.state) {</td></tr><tr><th id="L719"><a href="#L719">719</a></th><td>                        this.controller.setState(this.state,stt);</td></tr><tr><th id="L720"><a href="#L720">720</a></th><td>                        this.view.onState(this.state,stt);</td></tr><tr><th id="L721"><a href="#L721">721</a></th><td>                        this.state = stt;</td></tr><tr><th id="L722"><a href="#L722">722</a></th><td>                        this.configuration['duration'] = </td></tr><tr><th id="L723"><a href="#L723">723</a></th><td>                                Math.round(this.video.NaturalDuration.Seconds*10)/10;</td></tr><tr><th id="L724"><a href="#L724">724</a></th><td>                        if(stt != "Playing" &amp;&amp; stt != "Buffering" &amp;&amp; stt != "Opening") {</td></tr><tr><th id="L725"><a href="#L725">725</a></th><td>                                clearInterval(this.timeint);</td></tr><tr><th id="L726"><a href="#L726">726</a></th><td>                        } else {</td></tr><tr><th id="L727"><a href="#L727">727</a></th><td>                                this.timeint = setInterval(jeroenwijering.utils.delegate(</td></tr><tr><th id="L728"><a href="#L728">728</a></th><td>                                        this,this.timeChanged),100);</td></tr><tr><th id="L729"><a href="#L729">729</a></th><td>                        }</td></tr><tr><th id="L730"><a href="#L730">730</a></th><td>                }</td></tr><tr><th id="L731"><a href="#L731">731</a></th><td>        },</td></tr><tr><th id="L732"><a href="#L732">732</a></th><td></td></tr><tr><th id="L733"><a href="#L733">733</a></th><td>        mediaEnded: function() {</td></tr><tr><th id="L734"><a href="#L734">734</a></th><td>                if(this.configuration['repeat'] == 'true') {</td></tr><tr><th id="L735"><a href="#L735">735</a></th><td>                        this.goStart(0);</td></tr><tr><th id="L736"><a href="#L736">736</a></th><td>                } else {</td></tr><tr><th id="L737"><a href="#L737">737</a></th><td>                        this.state = 'Completed';</td></tr><tr><th id="L738"><a href="#L738">738</a></th><td>                        this.view.onState(this.state,'Completed');</td></tr><tr><th id="L739"><a href="#L739">739</a></th><td>                        this.video.Visibility = 'Collapsed';</td></tr><tr><th id="L740"><a href="#L740">740</a></th><td>                        this.preview.Visibility = 'Visible';</td></tr><tr><th id="L741"><a href="#L741">741</a></th><td>                        this.goPause(0);</td></tr><tr><th id="L742"><a href="#L742">742</a></th><td>                }</td></tr><tr><th id="L743"><a href="#L743">743</a></th><td>        },</td></tr><tr><th id="L744"><a href="#L744">744</a></th><td></td></tr><tr><th id="L745"><a href="#L745">745</a></th><td>        bufferChanged: function() {</td></tr><tr><th id="L746"><a href="#L746">746</a></th><td>                var bfr = Math.round(this.video.BufferingProgress*100);</td></tr><tr><th id="L747"><a href="#L747">747</a></th><td>                this.view.onBuffer(bfr);</td></tr><tr><th id="L748"><a href="#L748">748</a></th><td>        },</td></tr><tr><th id="L749"><a href="#L749">749</a></th><td></td></tr><tr><th id="L750"><a href="#L750">750</a></th><td>        downloadChanged: function() {</td></tr><tr><th id="L751"><a href="#L751">751</a></th><td>                var dld = Math.round(this.video.DownloadProgress*100);</td></tr><tr><th id="L752"><a href="#L752">752</a></th><td>                this.view.onLoad(dld);</td></tr><tr><th id="L753"><a href="#L753">753</a></th><td>        },</td></tr><tr><th id="L754"><a href="#L754">754</a></th><td></td></tr><tr><th id="L755"><a href="#L755">755</a></th><td>        timeChanged: function() {</td></tr><tr><th id="L756"><a href="#L756">756</a></th><td>                var pos = Math.round(this.video.Position.Seconds*10)/10;</td></tr><tr><th id="L757"><a href="#L757">757</a></th><td>                this.view.onTime(pos,this.configuration['duration']);</td></tr><tr><th id="L758"><a href="#L758">758</a></th><td>        }</td></tr><tr><th id="L759"><a href="#L759">759</a></th><td>}</td></tr><tr><th id="L760"><a href="#L760">760</a></th><td></td></tr><tr><th id="L761"><a href="#L761">761</a></th><td></td></tr><tr><th id="L762"><a href="#L762">762</a></th><td></td></tr><tr><th id="L763"><a href="#L763">763</a></th><td></td></tr><tr><th id="L764"><a href="#L764">764</a></th><td></td></tr><tr><th id="L765"><a href="#L765">765</a></th><td></td></tr><tr><th id="L766"><a href="#L766">766</a></th><td></td></tr><tr><th id="L767"><a href="#L767">767</a></th><td></td></tr><tr><th id="L768"><a href="#L768">768</a></th><td></td></tr><tr><th id="L769"><a href="#L769">769</a></th><td></td></tr><tr><th id="L770"><a href="#L770">770</a></th><td>/****************************************************************************</td></tr><tr><th id="L771"><a href="#L771">771</a></th><td>* Some utility functions.</td></tr><tr><th id="L772"><a href="#L772">772</a></th><td>****************************************************************************/</td></tr><tr><th id="L773"><a href="#L773">773</a></th><td>jeroenwijering.utils.delegate = function(obj,fcn) {</td></tr><tr><th id="L774"><a href="#L774">774</a></th><td>        return function() {</td></tr><tr><th id="L775"><a href="#L775">775</a></th><td>                return fcn.apply(obj,arguments);</td></tr><tr><th id="L776"><a href="#L776">776</a></th><td>        }</td></tr><tr><th id="L777"><a href="#L777">777</a></th><td>}</td></tr><tr><th id="L778"><a href="#L778">778</a></th><td>jeroenwijering.utils.timestring = function(stp) {</td></tr><tr><th id="L779"><a href="#L779">779</a></th><td>        var hrs = Math.floor(stp/3600);</td></tr><tr><th id="L780"><a href="#L780">780</a></th><td>        var min = Math.floor(stp%3600/60);</td></tr><tr><th id="L781"><a href="#L781">781</a></th><td>        var sec = Math.round(stp%60);</td></tr><tr><th id="L782"><a href="#L782">782</a></th><td>        var str = "";</td></tr><tr><th id="L783"><a href="#L783">783</a></th><td>        sec &gt; 9 ? str += sec: str +='0'+sec;</td></tr><tr><th id="L784"><a href="#L784">784</a></th><td>        min &gt; 9 ? str = min+":"+str: str='0'+min+":"+str;</td></tr><tr><th id="L785"><a href="#L785">785</a></th><td>        hrs &gt; 0 ? str = hrs+":"+str: null;</td></tr><tr><th id="L786"><a href="#L786">786</a></th><td>        return str;</td></tr><tr><th id="L787"><a href="#L787">787</a></th><td>}</td></tr><tr><th id="L788"><a href="#L788">788</a></th><td>jeroenwijering.utils.spanstring = function(stp) {</td></tr><tr><th id="L789"><a href="#L789">789</a></th><td>        var hrs = Math.floor(stp/3600);</td></tr><tr><th id="L790"><a href="#L790">790</a></th><td>        var min = Math.floor(stp%3600/60);</td></tr><tr><th id="L791"><a href="#L791">791</a></th><td>        var sec = Math.round(stp%60*10)/10;</td></tr><tr><th id="L792"><a href="#L792">792</a></th><td>        var str = hrs+':'+min+':'+sec;</td></tr><tr><th id="L793"><a href="#L793">793</a></th><td>        return str;</td></tr><tr><th id="L794"><a href="#L794">794</a></th><td>}</td></tr></tbody></table>
      </div>
      <div id="help">
        <strong>Note:</strong> See <a href="/trac/wiki/TracBrowser">TracBrowser</a>
        for help on using the browser.
      </div>
      <div id="anydiff">
        <form action="/trac/diff" method="get">
          <div class="buttons">
            <input type="hidden" name="new_path" value="/tags/wmvplayer-1.1/wmvplayer.js" />
            <input type="hidden" name="old_path" value="/tags/wmvplayer-1.1/wmvplayer.js" />
            <input type="hidden" name="new_rev" value="90" />
            <input type="hidden" name="old_rev" value="90" />
            <input type="submit" value="View changes..." title="Select paths and revs for Diff" />
          </div>
        </form>
      </div>
    </div>
    <div id="altlinks">
      <h3>Download in other formats:</h3>
      <ul>
        <li class="first">
          <a rel="nofollow" href="/trac/browser/tags/wmvplayer-1.1/wmvplayer.js?format=txt">Plain Text</a>
        </li><li class="last">
          <a rel="nofollow" href="/trac/export/330/tags/wmvplayer-1.1/wmvplayer.js">Original Format</a>
        </li>
      </ul>
    </div>
    </div>
    <div id="footer" lang="en" xml:lang="en"><hr />
      <a id="tracpowered" href="http://trac.edgewall.org/"><img src="/trac/chrome/common/trac_logo_mini.png" height="30" width="107" alt="Trac Powered" /></a>
      <p class="left">
        Powered by <a href="/trac/about"><strong>Trac 0.11</strong></a><br />
        By <a href="http://www.edgewall.org/">Edgewall Software</a>.
      </p>
      <p class="right">Visit the Trac open source project at<br /><a href="http://trac.edgewall.org/">http://trac.edgewall.org/</a></p>
    </div>
<script type="text/javascript">
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
</script>
<script type="text/javascript">
try {
var pageTracker = _gat._getTracker("UA-4011032-5");
pageTracker._trackPageview();
} catch(err) {}</script>
  </body>
</html>