* SilverlLight5 ie6&7(ietester,winxp), ie8(winxp) で動作確認。firefox32 では動作しない。(4以下の方がよい?)\r
*/\r
\r
-var X_Audio_SLAudio, X_Audio_SLAudioWrapper,\r
- X_Audio_SLAudio_uid = 0,\r
- X_Audio_SLAudio_LIVE_LIST = [],\r
- X_Audio_SLAudio_POOL_LIST = [];\r
+var X_SLAudio,\r
+ X_SLAudio_uid = 0;\r
\r
-if( X.Pulgin.SilverlightEnabled ){\r
+if( X[ 'Pulgin' ][ 'Silverlight' ] ){\r
\r
- function getSLAudioWrapper( proxy ){\r
- var i = X_Audio_SLAudio_LIVE_LIST.length;\r
- for( ; i; ){\r
- if( X_Audio_SLAudio_LIVE_LIST[ --i ].proxy === proxy ) return X_Audio_SLAudio_LIVE_LIST[ i ];\r
+ X_TEMP.slaudioInit = function(){\r
+ //\r
+ // http://blog.yuhiisk.com/archive/2014/12/20/dynamic-loading-and-complete-processing-of-script.html\r
+ var s;\r
+ \r
+ if( X_UA[ 'IE' ] < 9 ){\r
+ s = document.createElement( '<script id="silverlightaudio" type="text/xaml"></script>' );\r
+ } else {\r
+ s = document.createElement( 'script' );\r
+ s.id = 'silverlightaudio';\r
+ s.type = 'text/xaml';\r
};\r
+ \r
+ document.getElementsByTagName( 'head' )[ 0 ].appendChild( s );\r
+ s.text = '<Canvas xmlns="http://schemas.microsoft.com/client/2007" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"></Canvas>';\r
+ \r
+ delete X_TEMP.slaudioInit;\r
};\r
\r
- X_Audio_SLAudio = X_Class_override(\r
- new X.EventDispatcher(),\r
+ // X.Node.inherits はできない。_rawObject は <object> でなく silverlight\r
+ X_SLAudio = X_AudioBase[ 'inherits' ](\r
+ 'X.SilverlightAudio',\r
+ X_Class.POOL_OBJECT,\r
{\r
- backendName : 'Silverlight Audio',\r
+ '_rawType' : X_EventDispatcher_EVENT_TARGET_SILVER_LIGHT,\r
\r
- detect : function( source, ext ){\r
- var ok = ext === 'mp3' || ext === 'wma';\r
- \r
- this.asyncDispatch( ok ? 'support' : 'nosupport' );\r
- \r
- return this;\r
- },\r
- \r
- register : function( proxy, source, option ){\r
- X_Audio_SLAudio_LIVE_LIST.push( new X_Audio_SLAudioWrapper( proxy, source, option ) );\r
- },\r
- \r
- close : function(){\r
- return getSLAudioWrapper( this ).close();\r
- },\r
- \r
- play : function( position ){\r
- return getSLAudioWrapper( this ).play( position );\r
- },\r
- \r
- pause : function(){\r
- return getSLAudioWrapper( this ).pause();\r
- },\r
- \r
- stop : function(){\r
- return getSLAudioWrapper( this ).stop();\r
- },\r
- \r
- loop : function( v ){\r
- return getSLAudioWrapper( this ).loop( v );\r
- },\r
- \r
- state : function(){\r
- return getSLAudioWrapper( this ).state();\r
- },\r
- \r
- volume : function( v ){\r
- return getSLAudioWrapper( this ).volume( v );\r
- },\r
- \r
- startTime : function( time ){\r
- return getSLAudioWrapper( this ).startTime( time );\r
- },\r
- \r
- currentTime : function( time ){\r
- return getSLAudioWrapper( this ).currentTime( time );\r
- },\r
- \r
- isPlaying : function(){\r
- return getSLAudioWrapper( this ).isPlaying();\r
- }\r
- }\r
- );\r
- \r
- X_Audio_BACKENDS.push( X_Audio_SLAudio );\r
- \r
- function slerror(){\r
- alert( 'slerror' );\r
- };\r
- \r
- X_Audio_SLAudioWrapper = X.EventDispatcher.inherits(\r
- 'X.AV.SilverlightAudioWrapper',\r
- X.Class.POOL_OBJECT,\r
- {\r
- _isSilverlight : true, // for X.EventDispatcher.listen\r
- proxy : null,\r
_onload : '',\r
_callback : null, \r
xnodeObject : null,\r
- \r
- _loop : false,\r
_source : '',\r
- _error : 0,\r
_ended : true,\r
_paused : false,\r
- _volume : 0.5,\r
- _startTime : 0,\r
_lastUserAction : '',\r
_lastState : '',\r
- _duration : 0,\r
_interval : 0, // setInterval timer id\r
\r
- Constructor : function( proxy, source, option ){\r
+ 'Constructor' : function( disatcher, source, option ){\r
+ !X_SLAudio_uid && X_TEMP.slaudioInit();\r
\r
- if( !X_Audio_SLAudio_uid ){\r
- // source\r
- //X.X_Node_systemNode.create( 'script', { type : 'text/xaml', id : 'silverlightaudio' } )\r
- // .text( '<Canvas xmlns="http://schemas.microsoft.com/client/2007" ' +\r
- // 'xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"></Canvas>');\r
- \r
- // html に以下を書いた \r
- // <script id="silverlightaudio" type="text/xaml"><Canvas xmlns="http://schemas.microsoft.com/client/2007" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"></Canvas></script>\r
- };\r
/*\r
* [Silverlight 2]JavaScriptコードからSilverlightのオブジェクトを利用するには?[C#、VB]\r
* http://www.atmarkit.co.jp/fdotnet/dotnettips/902slobjcallfromjs/slobjcallfromjs.html\r
* このページのサンプルは sl5+firefox32 環境で動いている。xaml を js から利用する形ではなく、.xap を sl4 以下で作るのがよさそう.\r
*/\r
+ this.disatcher = disatcher || this;\r
+ this._source = source;\r
+ // X.Audio._slOnload_ は不可\r
+ this._onload = 'XAudioSilverlightOnLoad' + ( ++X_SLAudio_uid );\r
+ this._callback = window[ this._onload ] = X_Closure_create( this, this.onSLReady );\r
\r
// TODO embed\r
- this.proxy = proxy;\r
- this._onload = 'XAudioSilverlightOnLoad' + ( ++X_Audio_SLAudio_uid );\r
- this._callback = window[ this._onload ] = X_Callback_create( this, this.onSLReady, [ option.autoplay ] );\r
this.xnodeObject = X_Node_body\r
- .create( 'object', {\r
+ [ 'create' ]( 'object', {\r
type : 'application/x-silverlight-2',\r
data : 'data:application/x-silverlight-2,',\r
width : 1,\r
height : 1\r
})\r
- .html(\r
+ [ 'html' ](\r
'<param name="background" value="#00000000">' + // transparent\r
'<param name="windowless" value="true">' +\r
'<param name="source" value="#silverlightaudio">' + // XAML ID\r
- '<param name="onload" value="' + this._onload + '">'// + // bond to global\r
+ '<param name="onload" value="' + this._onload + '">' // + // bond to global\r
//'<param value="2.0.31005.0" name="minRuntimeVersion">' +\r
//'<param value="true" name="autoUpgrade">' +\r
//'<param name="onerror" value="slerror">' // bond to global\r
);\r
- \r
- this._loop = option.loop;\r
- this._source = source;\r
- if( option.volume ) this._volume = option.volume;\r
- if( option.startTime ) this._startTime = option.startTime;\r
+ this.setState( option );\r
\r
- this.listenOnce( X.Event.KILL_INSTANCE );\r
+ this[ 'listenOnce' ]( X_EVENT_KILL_INSTANCE );\r
},\r
\r
- onSLReady : function( sender, autoplay ){\r
- if( !this._onload ) return;\r
- \r
- window[ this._onload ] = null;\r
- delete this._onload;\r
- X_Callback_correct( this._callback );\r
- delete this._callback;\r
-\r
- //if( sender.findName('media') ) alert( 'exist' );\r
-\r
- sender.children.add(\r
- sender.GetHost().\r
- content.\r
- CreateFromXaml(\r
- '<Canvas xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">' +\r
- '<MediaElement x:Name="media" Source="' + this._source + '" Volume="' + this._volume + '" AutoPlay="false" />' +\r
- '</Canvas>'));\r
- \r
- this._rawObject = sender.findName('media'); // x:Name='media'\r
- \r
- this.listen( [ 'MediaFailed', 'MediaOpened', 'MediaEnded', 'CurrentStateChanged' ] );\r
- \r
- autoplay && X.Timer.once( 100, this, this.play );\r
- },\r
+ onSLReady : function( sender ){\r
+ if( !this._onload ) return;\r
+ \r
+ window[ this._onload ] = null;\r
+ delete this._onload;\r
+ X_Closure_correct( this._callback );\r
+ delete this._callback;\r
+ \r
+ sender[ 'children' ][ 'add' ](\r
+ sender[ 'GetHost' ]()[ 'content' ][ 'CreateFromXaml' ](\r
+ '<Canvas xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">' +\r
+ '<MediaElement x:Name="media" Source="' + this._source + '" Volume="' + this.gain + '" AutoPlay="false" />' +\r
+ '</Canvas>'));\r
+ \r
+ this[ '_rawObject' ] = sender[ 'findName' ]( 'media' ); // x:Name='media'\r
+ \r
+ this[ 'listen' ]( [ 'MediaFailed', 'MediaOpened', 'MediaEnded', 'CurrentStateChanged' ] );\r
+ },\r
\r
handleEvent : function( e ){\r
var lastState, currentState;\r
\r
+ console.log( e.type );\r
switch( e.type ){\r
\r
case 'MediaFailed' :\r
- this._error = 4;\r
- this._ended = true;\r
+ this.error = 4;\r
+ this.playing = false;\r
+ this._ended = true;\r
this._paused = false;\r
- \r
- this.proxy.dispatch( 'error' ); // open failed\r
+ if( this.playing ){\r
+ //X_Timer_once( 16, this, this.actualPlay );\r
+ } else {\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_ERROR ); // open failed\r
+ this[ 'kill' ](); \r
+ };\r
break;\r
+\r
case 'MediaOpened' :\r
// http://msdn.microsoft.com/ja-jp/library/bb979710(VS.95).aspx\r
- this._duration = this._rawObject.NaturalDuration.Seconds;\r
- // TODO 'canplaythrough'\r
- this.proxy.dispatch( 'canplay' );\r
+ this.duration = this[ '_rawObject' ][ 'NaturalDuration' ][ 'Seconds' ] * 1000;\r
+ this.disatcher[ 'asyncDispatch' ]( X_EVENT_READY );\r
+ \r
+ this.autoplay && X_Timer_once( 16, this, this.actualPlay );\r
break;\r
+\r
case 'MediaEnded' :\r
- this.currentTime(this._startTime);\r
- \r
- if (this._loop) {\r
- this._rawObject.play();\r
- }\r
+ //console.log( ' > ' + this.autoLoop + ' error:' + this.error );\r
+ //this.autoLoop && /* this.playing && */ this.actualPlay();\r
+ this._ended = true;\r
break;\r
+\r
case 'CurrentStateChanged' :\r
- lastState = this._lastState,\r
- currentState = this._rawObject.CurrentState;\r
+ lastState = this._lastState,\r
+ currentState = this[ '_rawObject' ][ 'CurrentState' ];\r
\r
// ignore consecutive events or 'Closed' == 'Error'\r
if( lastState === currentState\r
};\r
this._lastState = currentState; // update last state\r
\r
- switch (currentState) {\r
- case 'Buffering':\r
- case 'Opening':\r
- break;\r
- \r
+ console.log( ' > ' + currentState + ' - ' + this._lastUserAction );\r
+ \r
+ switch( currentState ){\r
+ case 'Buffering' :\r
+ case 'Opening' :\r
+ switch( this._lastUserAction ){\r
+ case 'play' :\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_WAITING );\r
+ break;\r
+ case 'seek' :\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_SEEKING );\r
+ break;\r
+ case 'pause' :\r
+ break;\r
+ };\r
+ break;\r
+\r
// media.play(none supported file) -> 'Error'\r
// media.play(file not found) -> 'Closed'\r
// media.load -> 'Error'\r
case 'Error':\r
+ this.error = 4;\r
case 'Closed':\r
- this._error = 4;\r
- this._ended = true;\r
- this._paused = false;\r
- this.proxy.dispatch( 'error' );\r
- break;\r
- \r
+ this.error = this.error || 2;\r
+ this.playing = false;\r
+ this._ended = true;\r
+ this._paused = false;\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_ERROR );\r
+ this[ 'kill' ]();\r
+ break;\r
+\r
// userAction.pause() -> MediaState('Paused') -> x\r
// userAction.stop() -> MediaState('Paused') -> x\r
// userAction.play() + file end -> MediaState('Paused') -> uueventfire('ended')\r
case 'Paused':\r
- switch (this._lastUserAction) {\r
- case 'play': // play() -> file end -> event('ended')\r
- this._ended = true;\r
- this._paused = false;\r
- this.proxy.dispatch( 'ended' );\r
- this.currentTime(this._startTime);\r
- break;\r
- case 'pause':\r
- this._ended = false;\r
- this._paused = true;\r
- break;\r
- case 'stop':\r
- this._ended = true;\r
- this._paused = false;\r
- }\r
- break;\r
- \r
+ \r
+ this.playing && X_Timer_once( 16, this, this.actualPlay );\r
+ //this.playing = false;\r
+ \r
+ switch( this._lastUserAction ){\r
+ case 'play': // play() -> file end -> event('ended')\r
+ case 'seek':\r
+ //this.seekTime = 0;\r
+ this._ended = true;\r
+ this._paused = false;\r
+ //this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_ENDED );\r
+ //this.setCurrentTime( this.startTime );\r
+ break;\r
+ case 'pause':\r
+ this._ended = false;\r
+ this._paused = true;\r
+ break;\r
+ case 'stop':\r
+ this._ended = true;\r
+ this._paused = false;\r
+ };\r
+ break;\r
+\r
// media.play -> 'Playing'\r
case 'Playing':\r
- this._error = 0;\r
- this._ended = false;\r
- this._paused = false;\r
- this.proxy.dispatch( 'playing' );\r
- break;\r
- \r
+ this.error = 0;\r
+ //this.playing = true;\r
+ this._ended = false;\r
+ this._paused = false;\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_PLAYING );\r
+ break;\r
+\r
// stop()\r
case 'Stopped':\r
- this._ended = true;\r
- this._paused = false;\r
- this.currentTime(this._startTime);\r
- }\r
+ this.playing && X_Timer_once( 16, this, this.actualPlay );\r
+ \r
+ //this.playing = false;\r
+ //this._ended = true;\r
+ //this._paused = false;\r
+ //this.setCurrentTime( this.startTime );\r
+ break;\r
+ };\r
break;\r
+\r
+ case X_EVENT_KILL_INSTANCE :\r
+ this.playing && this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_ENDED );\r
+ this.playing && this.actualPause();\r
\r
- case X.Event.KILL_INSTANCE :\r
if( this._onload ){\r
+ // window への delete に ie5 は対応しないが、そもそも ie5 は Silverlight に非対応\r
window[ this._onload ] = null;\r
- this._callback.kill();\r
+ delete this._onload;\r
+ X_Closure_correct( this._callback );\r
};\r
- this.xnodeObject.destroy();\r
+ this.xnodeObject[ 'kill' ]();\r
break;\r
};\r
},\r
\r
- close : function(){\r
- if (this._interval) {\r
- X.Timer.remove( this._interval );\r
- delete this._interval;\r
- };\r
- this.proxy.dispatch( 'ended' );\r
- this.kill();\r
- },\r
- \r
// SilverlightAudio.play\r
- play : function(){\r
- if (!this._error) {\r
- this._lastUserAction = 'play';\r
- if (this._ended) {\r
- this.currentTime(this._startTime);\r
- }\r
- \r
- this._rawObject.play();\r
- this.proxy.dispatch( 'play' );\r
- \r
- if (!this._interval) {\r
- this._interval = X.Timer.add( 1000, 0, this, this._onInterval );\r
- }\r
- }\r
- },\r
- \r
- _onInterval : function(){\r
- this.isPlaying() && this.proxy.dispatch( 'timeupdate' );\r
+ actualPlay : function(){\r
+ var begin, offset, end;\r
+\r
+ // もし kill 後に autoplayTimer で呼ばれても、_closed==true なので平気\r
+ if( this.error ) return;\r
+ if( !this.duration ){\r
+ this.autoplay = true;\r
+ return;\r
+ };\r
+ \r
+ this._lastUserAction = 0 <= this.seekTime ? 'seek' : 'play';\r
+ \r
+ end = X_Audio_getEndTime( this );\r
+ begin = X_Audio_getStartTime( this, end, true ) | 0;\r
+\r
+ // 1 秒以下は指定できないため四捨五入\r
+ begin = ( begin / 1000 | 0 ) * 1000 + ( 500 < begin % 1000 ? 1000 : 0 ); \r
+\r
+ this[ '_rawObject' ][ 'Volume' ] = this.gain;\r
+ \r
+ this.setCurrentTime( this._beginTime = begin );\r
+ \r
+ console.log( '[play] ' + begin + ' -> ' + end );\r
+ \r
+ /*\r
+ if( offset = begin - this.getActualCurrentTime() ){\r
+ this.setCurrentTime( begin + offset );\r
+ console.log( ' [差補正] ' + offset + ' ct:' + this.getActualCurrentTime() + ' begin:' + begin );\r
+ this._beginTime = begin = this.getActualCurrentTime();\r
+ };*/\r
+ \r
+ if( !this.playing || this._ended ){\r
+ console.log( '[play] play()' + begin + ' -> ' + end );\r
+ this[ '_rawObject' ].play();\r
+ this.playing = true;\r
+ this._ended = false;\r
+ };\r
+ \r
+ this._timerID && X_Timer_remove( this._timerID );\r
+ \r
+ this._timerID = X_Timer_once( end - begin, this, this._onEnded );\r
+ \r
+ if( !this._interval ){\r
+ this._interval = X_Timer_add( 1000, 0, this, this._onInterval );\r
+ };\r
},\r
+ \r
+ _onInterval : function(){\r
+ if( !this.playing ){\r
+ delete this._interval;\r
+ return X_CALLBACK_UN_LISTEN;\r
+ };\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_PLAYING );\r
+ },\r
+ \r
+ _onEnded : function(){\r
+ var time, end;\r
+ delete this._timerID;\r
+ \r
+ if( this.playing ){\r
+ //console.log( '> end ' + X_Audio_getEndTime( this ) + ' current:' + ( this.getActualCurrentTime() ) );\r
+ time = this.getActualCurrentTime();\r
+ \r
+ if( time < this._beginTime ){\r
+ console.log( '== waiting ' + time + ' < begin:' + this._beginTime );\r
+ this.setCurrentTime( this._beginTime );\r
+ time = this.getActualCurrentTime();\r
+ console.log( ' > ' + time );\r
+ this._ended && this[ '_rawObject' ].play();\r
+ this._ended = false;\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_WAITING );\r
+ this._timerID = X_Timer_once( X_Audio_getEndTime( this ) - time, this, this._onEnded );\r
+ return;\r
+ };\r
+ \r
+ time -= X_Audio_getEndTime( this );\r
+ if( time < 0 ){\r
+ console.log( ' > まだ終わらない ' + time );\r
+ this._ended && this[ '_rawObject' ].play();\r
+ this._ended = false;\r
+ this._timerID = X_Timer_once( -time, this, this._onEnded );\r
+ return;\r
+ };\r
+ \r
+ if( this.autoLoop ){\r
+ console.log( '========= loop?' );\r
+ if( !( this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_BEFORE_LOOP ) & X_CALLBACK_PREVENT_DEFAULT ) ){\r
+ console.log( '========== loopした' );\r
+ this.looped = true;\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_LOOPED );\r
+ this.actualPlay();\r
+ };\r
+ } else {\r
+ console.log( '========= pause' );\r
+ this.actualPause();\r
+ this.disatcher[ 'dispatch' ]( X_EVENT_MEDIA_ENDED );\r
+ };\r
+ };\r
+ },\r
\r
// SilverlightAudio.pause\r
- pause : function(){\r
- if (!this._error) {\r
- this._lastUserAction = 'pause';\r
- this._paused = true;\r
- this._ended = false;\r
- this._rawObject.pause();\r
- this.proxy.dispatch( 'pause' );\r
- }\r
- },\r
- \r
- // SilverlightAudio.stop\r
- stop : function(){\r
- if (!this._error) {\r
- this._lastUserAction = 'stop';\r
- this._rawObject.stop();\r
- this._ended = true;\r
- }\r
- },\r
- \r
- // SilverlightAudio.loop\r
- loop : function(value){ // @param Boolean: true is loop\r
- // @return Boolean/void: true is loop\r
- if (value === undefined) {\r
- return this._loop;\r
- }\r
- this._loop = value;\r
- },\r
- \r
- // SilverlightAudio.state\r
- state : function(){ // @return Hash: { loop, error, paused, ended, source, duration }\r
- return {\r
- loop : this._loop,\r
- error : this._error,\r
- paused : this._paused,\r
- ended : this._ended,\r
- source : this._source,\r
- duration : this._duration\r
- };\r
+ actualPause : function(){\r
+ if( this.error /* || !this.playing */ ) return;\r
+ \r
+ this._lastUserAction = 'pause';\r
+ this.seekTime = this.getActualCurrentTime();\r
+ this.playing = false;\r
+ this._paused = true;\r
+ this._ended = false;\r
+ \r
+ this[ '_rawObject' ].pause();\r
+ //this.disatcher[ 'dispatch' ]( 'pause' );\r
},\r
- \r
- // SilverlightAudio.volume\r
- volume : function(value){ // @param Number: 0.0 ~ 1.0\r
- // @return Number/void:\r
- if (value === undefined) {\r
- return this._volume;\r
- }\r
- this._volume = value;\r
- this._rawObject.Volume = value;\r
+\r
+ getActualCurrentTime : function(){\r
+ return this[ '_rawObject' ][ 'Position' ][ 'Seconds' ] * 1000 | 0;\r
},\r
\r
- // SilverlightAudio.startTime\r
- startTime : function(time){ // @param Number: time\r
- // @return Number/void:\r
- if (time === undefined) {\r
- return this._startTime;\r
- }\r
- this._startTime = time;\r
+ afterUpdateState : function( result ){\r
+ if( result & 3 ){ // seek\r
+ this.actualPlay();\r
+ } else\r
+ if( result & 1 ){\r
+ end = X_Audio_getEndTime( this );\r
+ halfway = end < this.duration;\r
+ this._timerID && X_Timer_remove( this._timerID );\r
+ \r
+ if( halfway ){\r
+ this._timerID = X_Timer_once( end - this.getActualCurrentTime(), this, this._onEnded );\r
+ } else {\r
+ delete this._timerID;\r
+ };\r
+ } else\r
+ if( result & 4 ){\r
+ this[ '_rawObject' ][ 'Volume' ] = this.gain;\r
+ }; \r
},\r
\r
- // SilverlightAudio.currentTime\r
- currentTime : function(time){ // @param Number: time\r
- // @return Number/void:\r
- var position = this._rawObject.Position; // [!] create instance\r
+ // SilverlightAudio.currentTime\r
+ setCurrentTime : function( time ){ // @param Number: time\r
+ var position = this[ '_rawObject' ][ 'Position' ]; // [!] create instance\r
+ \r
+ position[ 'Seconds' ] = time / 1000 | 0; // set current time\r
\r
- if (time === undefined) {\r
- return position.Seconds;\r
- };\r
-\r
- position.Seconds = time; // set current time\r
- \r
- this._rawObject.Position = position; // [!] reattach instance\r
- },\r
- \r
- // SilverlightAudio.isPlaying\r
- isPlaying : function(){ // @return Boolean:\r
- if (!this._error && !this._paused && !this._ended) {\r
- return true;\r
+ this[ '_rawObject' ][ 'Position' ] = position; // [!] reattach instance\r
}\r
- return false;\r
- }\r
\r
}\r
);\r
- \r
-};\r
\r
+ /*\r
+ function slerror(){\r
+ alert( 'slerror' );\r
+ }; */\r
+\r
+ X_Audio_BACKENDS.push( {\r
+ backendID : 8,\r
+ \r
+ backendName : 'Silverlight',\r
\r
+ canPlay : {\r
+ 'mp3' : true,\r
+ 'wma' : true,\r
+ 'wav' : true\r
+ },\r
+\r
+ detect : function( proxy, source, ext ){\r
+ proxy[ 'asyncDispatch' ]( { type : X_EVENT_COMPLETE, canPlay : ext === 'mp3' || ext === 'wma' || ext === 'wav' } ); \r
+ },\r
+ \r
+ klass : X_SLAudio\r
+ \r
+ } );\r
\r
+};
\ No newline at end of file