devolución de llamada de Flashembed de jQuery Tools
-
26-10-2019 - |
Pregunta
JQuery Tools incluye una API de embarcación flash que acepta muchos parámetros. ¿Hay alguien que acepte la función de devolución de llamada y los incendios después del estado de éxito del Flash Player Load?
playerdiv.flashembed(url+'/VIPlayer.swf','knds_player',300,250,'8.0.0',false,flashVars);
Información: página web oficial.
Nota: Esto es posible en Biblioteca de Google SWFObject como a continuación:
swfobject.embedSWF(url+'/VIPlayer.swf','knds_player',300,250,'8.0.0',false,flashVars,callBack);
function callBack(event){
event after successful display of code
}
Pero necesito usar solo flashbed. ¿Puedes ayudarme aquí?
Gracias de antemano :)
Solución
El método de emparejamiento de flash tiene un onFail
argumento que toma una devolución de llamada como un valor:
$("#flash").flashembed({
src: flashSWF,
version:[10,0],
id:"flashObj",
width: 500,
height: 300,
wmode: "opaque",
cachebusting: "false",
allowscriptaccess: "always",
api: "false",
scale: "noscale",
menu: "false",
onFail: flasherror("#flash")
})
Inadvertidamente dispara tanto por éxito como por fracaso. Buscar el ,
carácter para distinguir entre los dos estados. En error, se muestra como delimitador en la cadena de la versión, como 11,0
más bien que 11.0
:
function flashError(domnode, newtext){
function failState()
{
if ($(domnode).html().search(/,/) !== -1) //player failed to load
{
newtext = $(domnode).html(); // store default error string
$(domnode).empty();
$(domnode).append(newtext.replace(/,/g,".")); // replace comma with period
if ($(domnode).hasClass("flashmsg") === false)
{
$(domnode).addClass("flashmsg"); // add class to custom error element
}
}
else
{
//success logic
}
}
// observer constructor
var cursor =
typeof window.hasOwnProperty === "function" ?
window.hasOwnProperty("WebKitMutationObserver")
? new WebKitMutationObserver(startValidation)
: window.hasOwnProperty("MutationObserver")
? new MutationObserver(startValidation)
: false
: false
;
//Use observer event if it exists
if (cursor)
{
//Bind observer event to text child of the dom node
cursor.observe($(domnode).get(0), { childList: true } );
return;
}
//Use mutation event as a fallback
else if (!!document.addEventListener)
{
$(domnode).get(0).addEventListener("DOMNodeInserted", failState, false);
}
//Use readystatechange event for legacy IE
else
{
$(domnode).get(0).addBehavior("foo.htc");
$(domnode).get(0).attachEvent("onreadystatechange", failState);
}
Referencias