我们在内部网站上使用WMV个视频,我们正在将它们嵌入到网站中。这在Internet Explorer上运行良好,但在Firefox上运行不正常。我已经找到了让它在Firefox中运行的方法,但它在Internet Explorer中停止工作。
我们还不想使用Silverlight,特别是因为我们无法确定所有客户端都将运行安装了Windows Media Player的Windows XP。
是否有某种通用代码将WMP嵌入到Internet Explorer和Firefox中,或者我们是否需要实现一些用户代理检测并为不同的浏览器提供不同的HTML?
答案 0 :(得分:45)
以下适用于Firefox和Internet Explorer:
<object id="mediaplayer" classid="clsid:22d6f312-b0f6-11d0-94ab-0080c74c7e95" codebase="http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#version=5,1,52,701" standby="loading microsoft windows media player components..." type="application/x-oleobject" width="320" height="310">
<param name="filename" value="./test.wmv">
<param name="animationatstart" value="true">
<param name="transparentatstart" value="true">
<param name="autostart" value="true">
<param name="showcontrols" value="true">
<param name="ShowStatusBar" value="true">
<param name="windowlessvideo" value="true">
<embed src="./test.wmv" autostart="true" showcontrols="true" showstatusbar="1" bgcolor="white" width="320" height="310">
</object>
答案 1 :(得分:20)
我可以建议jQuery Media Plugin吗?为各种视频提供嵌入代码,而不仅仅是WMV,并进行浏览器检测,将所有混乱的开关/案例陈述保留在模板之外。
答案 2 :(得分:9)
使用以下内容。它适用于Firefox和Internet Explorer。
<object id="MediaPlayer1" width="690" height="500" classid="CLSID:22D6F312-B0F6-11D0-94AB-0080C74C7E95"
codebase="http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701"
standby="Loading Microsoft® Windows® Media Player components..." type="application/x-oleobject"
>
<param name="FileName" value='<%= GetSource() %>' />
<param name="AutoStart" value="True" />
<param name="DefaultFrame" value="mainFrame" />
<param name="ShowStatusBar" value="0" />
<param name="ShowPositionControls" value="0" />
<param name="showcontrols" value="0" />
<param name="ShowAudioControls" value="0" />
<param name="ShowTracker" value="0" />
<param name="EnablePositionControls" value="0" />
<!-- BEGIN PLUG-IN HTML FOR FIREFOX-->
<embed type="application/x-mplayer2" pluginspage="http://www.microsoft.com/Windows/MediaPlayer/"
src='<%= GetSource() %>' align="middle" width="600" height="500" defaultframe="rightFrame"
id="MediaPlayer2" />
在JavaScript中,
function playVideo() {
try{
if(-1 != navigator.userAgent.indexOf("MSIE"))
{
var obj = document.getElementById("MediaPlayer1");
obj.Play();
}
else
{
var player = document.getElementById("MediaPlayer2");
player.controls.play();
}
}
catch(error) {
alert(error)
}
}
答案 3 :(得分:7)
Elizabeth Castro有一篇关于这个问题的有趣文章:Bye Bye Embed。值得一读的是她如何攻击这个问题,以及处理QuickTime内容。
答案 4 :(得分:6)
你可以使用条件评论让IE和Firefox做不同的事情
<![if !IE]>
<p> Firefox only code</p>
<![endif]>
<!--[if IE]>
<p>Internet Explorer only code</p>
<![endif]-->
浏览器本身将忽略不适合他们阅读的代码。
答案 5 :(得分:6)
在网络上部署视频的最佳方式是使用Flash - 将其干净地嵌入到网页中会更容易,并且可以或多或少地在任何浏览器和平台组合上播放。使用Windows Media Player的唯一原因是,如果您正在流式传输内容,并且需要非常强大的数字版权管理,即使这样,提供商现在也开始使用Flash。有关一个极好的例子,请参阅BBC的iPlayer。
我建议您切换到Flash,即使是内部使用。您永远不知道将来需要访问它的人,这将为您提供最佳的兼容性。
编辑 - 2013年3月20日。 有趣的是这些旧问题不时重现!今天的世界有多么不同,这一切看起来多么过时。我今天不建议以任何方式使用Flash专用路线 - 这些天的最佳做法可能是使用HTML 5嵌入H264编码视频,如下所述使用Flash后备:http://diveintohtml5.info/video.html
答案 6 :(得分:4)
使用ffmpeg编码flash视频实际上非常简单。您可以使用一个命令从几乎任何视频格式进行转换,ffmpeg非常智能,可以完成其余部分,并且它将使用您机器上的每个处理器。调用它很容易:
ffmpeg -i input.avi output.flv
ffmpeg会猜测你想要的比特率,但是如果你想指定一个,你可以使用-b选项,所以-b 500000
例如是500kbps。当然有很多选择,但我通常会在没有太多修修补补的情况下取得好成绩。如果您正在寻找更多选项,这是一个很好的起点:video options。
您不需要特殊的网络服务器来显示Flash视频。我只是简单地将.flv文件推送到标准的Web服务器,然后用一个好的swf播放器链接到它们,例如flowplayer。
如果您确定所有用户将始终使用[最近的,最新版本] Windows,那么WMV就可以了,但即使这样,Flash通常也更适合网络。该播放器甚至可以非常换肤,可以通过javascript控制。
答案 7 :(得分:4)
我在MSDN上发现了一篇关于using the WMP with Firefox的好文章。
基于MSDN的文章,在做了一些试验和错误之后,我发现使用JavaScript比使用条件注释或嵌套的“EMBED / OBJECT”标签更好。
我创建了一个基于给定参数生成WMP对象的JS函数:
<script type="text/javascript">
function generateWindowsMediaPlayer(
holderId, // String
height, // Number
width, // Number
videoUrl // String
// you can declare more arguments for more flexibility
) {
var holder = document.getElementById(holderId);
var player = '<object ';
player += 'height="' + height.toString() + '" ';
player += 'width="' + width.toString() + '" ';
videoUrl = encodeURI(videoUrl); // Encode for special characters
if (navigator.userAgent.indexOf("MSIE") < 0) {
// Chrome, Firefox, Opera, Safari
//player += 'type="application/x-ms-wmp" '; //Old Edition
player += 'type="video/x-ms-wmp" '; //New Edition, suggested by MNRSullivan (Read Comments)
player += 'data="' + videoUrl + '" >';
}
else {
// Internet Explorer
player += 'classid="clsid:6BF52A52-394A-11d3-B153-00C04F79FAA6" >';
player += '<param name="url" value="' + videoUrl + '" />';
}
player += '<param name="autoStart" value="false" />';
player += '<param name="playCount" value="1" />';
player += '</object>';
holder.innerHTML = player;
}
</script>
然后我通过编写一些标记和内联JS来使用该函数:
<div id='wmpHolder'></div>
<script type="text/javascript">
window.addEventListener('load', generateWindowsMediaPlayer('wmpHolder', 240, 320, 'http://mysite.com/path/video.ext'));
</script>
您可以使用 jQuery.ready 代替 窗口加载事件 ,使代码更向后兼容和跨浏览器。
我在Windows 7/8上测试了IE 9-10,Chrome 27,Firefox 21,Opera 12和Safari 5上的代码。
答案 8 :(得分:3)
我在Elizabeth Castro的网站上发现了一些实际可用于FireFox和IE的内容(感谢此网站上的链接) - 我在这里尝试了所有其他版本,但无法使它们在两个浏览器中都能正常工作
<object classid="CLSID:6BF52A52-394A-11d3-B153-00C04F79FAA6"
id="player" width="320" height="260">
<param name="url"
value="http://www.sarahsnotecards.com/catalunyalive/fishstore.wmv" />
<param name="src"
value="http://www.sarahsnotecards.com/catalunyalive/fishstore.wmv" />
<param name="showcontrols" value="true" />
<param name="autostart" value="true" />
<!--[if !IE]>-->
<object type="video/x-ms-wmv"
data="http://www.sarahsnotecards.com/catalunyalive/fishstore.wmv"
width="320" height="260">
<param name="src"
value="http://www.sarahsnotecards.com/catalunyalive/fishstore.wmv" />
<param name="autostart" value="true" />
<param name="controller" value="true" />
</object>
<!--<![endif]-->
</object>
检查她的网站:http://www.alistapart.com/articles/byebyeembed/以及初始对象标记中带有classid的版本
答案 9 :(得分:1)
2020年12月:
回答问题:
<video>
element将其嵌入到您的页面中。我认为这个问题应该解决。