使用jQuery跟踪flash电影(对象/嵌入)的单击

时间:2009-11-24 10:37:27

标签: jquery flash click capture

我正在创建一个动态横幅系统,可以处理img横幅,以及使用object / embed完成的flash横幅。整个网站大量使用jQuery,包括处理“点击”事件。

当谈到跟踪图像本身的点击时,这显然不是问题(我跟踪父DIV标签上的点击。但是,当广告是SWF时,它会失败,因为我怀疑它会。) / p>

是否有一个jQuery解决方法可以让我捕获带有DOM的Flash元素的点击?

3 个答案:

答案 0 :(得分:10)

我知道这是很久以前发布的,已经回答了,但我只想为未来的网站访问者添加更简单的解决方案。虽然嵌入的SWF文件将吞下onclick事件,但它不会吞下onmousedown事件。诀窍是在param标签和embed标签中将wmode设置为透明。

<div id="layer1" onmousedown="alert('mouse down')"> 
<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
codebase="http://fpdownload.adobe.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0" 
width="799" height="741" id="myMovieName">
<param name="movie" value="_data.swf" /> 
<param name="quality" value="high" />
<param name="play" value="true" />
<param name="loop" value="true" />
<param name="wmode" value="transparent" />
<embed src="_data.swf" quality=high bgcolor=#FFFFFF width="799" height="741" 
name="myMovieName" type="application/x-shockwave-flash" 
play="true" loop="true" wmode="transparent"
pluginspage="http://www.adobe.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash">
</embed>
</object>
</div>

您可以使用jQuery绑定到mousedown事件,如下所示:

$('#layer1').mousedown(function() {
  alert('mouse down');
});

答案 1 :(得分:3)

如果您有权访问SWF源,则可以使用ExternalInterface与包含的html页面进行通信。

//inside the flash movie:
stage.addEventListener(MouseEvent.CLICK, onClick);
function onClick(e:MouseEvent):void
{
   ExternalInterface.call("handleFlashClick", [parameters to the method]);
}

//javascript in the containing html page
function handleFlashClick()
{
  //call the jQuery method here.
}

答案 2 :(得分:2)

我能够使用以下内容获取网络回答并获得对象点击工作。

// Podcast player GA event tracking
var podcast_player = $('object.podcast-player');
if( podcast_player.length > 0 )
{
    podcast_player.live('mousedown',function(){
        _gaq.push(['_trackEvent', 'Podcast', 'Play']);
    });
}

我希望这可以帮助其他人,感谢 webwires