Встраивание Windows Media Player для всех браузеров
Изменить: этот вопрос был написан в 2008 году, что было примерно 3 года назад в Интернете. Если этот вопрос по-прежнему актуален для вашего окружения, примите мои соболезнования. Все остальные должны преобразовать в формат, поддерживаемый вашими браузерами (это будет H.264, если требуется Internet Explorer, и, вероятно, AV1, VP8 / VP9, если нет) и использовать <video>
элемент .
Мы используем видео WMV на внутреннем сайте и встраиваем их в веб-сайты. Это хорошо работает в Internet Explorer, но не в Firefox. Я нашел способы заставить его работать в Firefox, но потом он перестает работать в Internet Explorer.
Мы пока не хотим использовать Silverlight, тем более что мы не можем быть уверены, что все клиенты будут работать под Windows XP с установленным проигрывателем Windows Media.
Существует ли какой-то универсальный код, который встраивает WMP как в Internet Explorer, так и в Firefox, или нам нужно реализовать обнаружение пользовательского агента и доставлять разные HTML для разных браузеров?
Ответов (10)10
В 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>
Могу я предложить подключаемый модуль jQuery Media ? Предоставляет встраиваемый код для всех видов видео, а не только для WMV, и выполняет обнаружение браузером, исключая из ваших шаблонов все эти беспорядочные операторы switch / case.
У Элизабет Кастро есть интересная статья по этой проблеме: Bye Bye Embed . Стоит прочитать о том, как она решила эту проблему, а также о работе с содержимым QuickTime.
Я нашел хорошую статью об использовании WMP с Firefox в MSDN.
Основываясь на статье MSDN и после некоторых проб и ошибок, я обнаружил, что использование JavaScript лучше, чем использование условных комментариев или вложенных тегов «EMBED / OBJECT».
Я сделал функцию JS, которая генерирует объект WMP на основе заданных аргументов:
<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 вместо события загрузки окна, чтобы сделать коды более обратно совместимыми и кроссбраузерными.
Я тестировал коды в IE 9-10, Chrome 27, Firefox 21, Opera 12 и Safari 5 в Windows 7/8.
Декабрь 2020 г .:
- Теперь у нас есть Firefox 83.0 и Chrome 87.0.
- Internet Explorer мертв, его заменил новый Edge 87.0 на базе Chromium.
- Silverlight мертв
- Windows XP мертва
- WMV не является стандартом: https://www.w3schools.com/html/html_media.asp
Чтобы ответить на вопрос:
- Вам необходимо преобразовать ваш WMV-файл в другой формат: MP4, WebM или Ogg video.
- Затем вставьте его на свою страницу с помощью
<video>
элемента HTML 5 .
Думаю, этот вопрос следует закрыть.
Лучший способ развернуть видео в Интернете - это использовать Flash - его намного проще встроить в веб-страницу, и он будет воспроизводиться более или менее в любой комбинации браузера и платформы. Единственная причина использовать Windows Media Player - если вы транслируете контент и вам нужно чрезвычайно надежное управление цифровыми правами, и даже тогда провайдеры начинают использовать Flash даже для них. См. Превосходный пример в iPlayer BBC.
Я бы посоветовал вам переключиться на Flash даже для внутреннего использования. Вы никогда не знаете, кому понадобится доступ к нему в будущем, и это обеспечит вам наилучшую совместимость в будущем.
РЕДАКТИРОВАТЬ - 20 марта 2013 г. Интересно, как время от времени всплывают эти старые вопросы! Насколько изменился мир сегодня и насколько все это кажется устаревшим. Я бы ни в коем случае не рекомендовал сегодня маршрут только для Flash - в наши дни лучше всего было бы использовать HTML 5 для встраивания видео в кодировке H264 с резервным вариантом Flash, как описано здесь: http://diveintohtml5.info/video.html
Кодировать flash-видео с помощью ffmpeg очень просто. Вы можете использовать одну команду для преобразования практически из любого видеоформата, ffmpeg достаточно умен, чтобы понять все остальное, и он будет использовать каждый процессор на вашем компьютере. Вызвать это легко:
ffmpeg -i input.avi output.flv
ffmpeg угадает, какой битрейт вы хотите, но если вы хотите указать его, вы можете использовать параметр -b, -b 500000
например, 500 кбит / с. Конечно, есть масса вариантов, но в целом я получаю хорошие результаты без особых усилий. Это хорошее место для начала, если вам нужны дополнительные возможности: параметры видео .
Вам не нужен специальный веб-сервер для показа флеш-видео. Я отлично справился, просто отправив файлы .flv на стандартный веб-сервер и связав их с помощью хорошего SWF-плеера, такого как flowplayer .
WMV хороши, если вы можете быть уверены, что все ваши пользователи всегда будут использовать только [последнюю актуальную версию] только Windows, но даже в этом случае Flash часто лучше подходит для Интернета. У плеера даже очень много скинов, и им можно управлять с помощью javascript.
Используйте следующее. Работает в 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)
}
}
Я нашел что-то, что действительно работает как в 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 в начальном теге объекта.