使用VLC及live555实现网页播放视频或mp3

1、VLC版本使用0.94在我的资源里面可以下载

2、live555使用最新的版本,在官网下载编译。具体windows下编译可参考前面的章节


html代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" > 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 
<script> 
var itemId = 0; 
function getVLC(name) 
{ 
        if (window.document[name])    
        { 
                return window.document[name]; 
        } 
        if (navigator.appName.indexOf("Microsoft Internet")==-1) 
        { 
                if (document.embeds && document.embeds[name]) 
                        return document.embeds[name];    
        } 
        else 
        { 
                return document.getElementById(name); 
        } 
} 

function doGo(mrl) 
{ 
        var vlc = getVLC("vlc"); 
        itemId=vlc.playlist.add(mrl); 
        vlc.playlist.playItem(itemId); 
        document.getElementById("btn_stop").disabled = false; 
} 

function updateVolume(deltaVol) 
{ 
        var vlc = getVLC("vlc"); 
        vlc.audio.volume += deltaVol; 
} 

function doPlay() 
{ 
        vlc.playlist.playItem(itemId); 
         
        document.getElementById("btn_stop").disabled = false; 
        document.getElementById("btn_play").disabled = true; 
} 

function doStop() 
{ 
        getVLC("vlc").playlist.stop(); 
        document.getElementById("btn_stop").disabled = true; 
        document.getElementById("btn_play").disabled = false; 
} 
</script> 
</head> 
<body> 
<div style="margin: 50px"> 
        <a title="rtsp://10.1.1.33/1.mp3" href="#" οnclick="doGo(this.title);return false;">01.ts</a> 
        <span style="margin: 20px;" /> 
        <a title="rtsp://10.1.1.33/test.264" href="#" οnclick="doGo(this.title);return false;">02.mp3</a> 
        <span style="margin: 20px;" /> 
</div> 
<div> 
        <object classid="clsid:9be31822-fdad-461b-ad51-be1d1c159921" 
                width="640" 
                height="480" 
                id="vlc" 
                events="true"> 
        <param name="mrl" value="" /> 
        <param name="showdisplay" value="true" /> 
        <param name="autoloop" value="false" /> 
        <param name="autoplay" value="false" /> 
        <param name="volume" value="50" /> 
        <param name="starttime" value="0" /> 
        <embed pluginspage="http://www.videolan.org" 
                     type="application/x-vlc-plugin" 
                     version="videolan.vlcplugin.2" 
                     width="640" 
                     height="480" 
                     name="vlc"> 
        </embed> 
        </object> 
</div> 
<div> 
<input type=button id="btn_play" value=" 播放 " onClick='doPlay();' disabled="true"> 
<input type=button id="btn_stop" value="停止" onClick='doStop();' disabled="true"> 
<input type=button value="静音切换" οnclick='getVLC("vlc").audio.togglemute();'> 
<input type=button value="减小音量" οnclick='updateVolume(-10)'> 
<input type=button value="增加音量" οnclick='updateVolume(+10)'> 
</div> 
</body> 
</html>



参考资料:

1、http://jeremiah.blog.51cto.com/539865/161433/

2、http://jeremiah.blog.51cto.com/539865/115943

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt是一个跨平台的C++应用程序开发框架,它提供了丰富的功能和工具来开发各种类型的应用程序,包括图形界面应用程序。如果你想使用Qt来播放RTMP视频,你可以使用第三方库来实现。 一个常用的第三方库是libVLCVideoLAN Client),它是一个开源的多媒体框架,支持各种音频和视频格式,包括RTMP。你可以在Qt项目中集成libVLC实现RTMP视频播放功能。 以下是一些步骤来使用Qt和libVLC来播放RTMP视频: 1. 首先,你需要下载并安装libVLC库。你可以从官方网站(https://www.videolan.org/vlc/libvlc.html)下载适合你操作系统的版本。 2. 在Qt项目中添加libVLC库的头文件和库文件路径。你可以在.pro文件中添加以下行: ``` INCLUDEPATH += /path/to/libvlc/include LIBS += -L/path/to/libvlc/lib -lvlc ``` 3. 在Qt代码中创建一个libVLC实例,并设置RTMP视频的URL。你可以使用libVLC提供的API来控制视频的播放、暂停、停止等操作。 以下是一个简单的示例代码: ```cpp #include <QApplication> #include <QVBoxLayout> #include <QFrame> #include <vlc/vlc.h> int main(int argc, char *argv[]) { QApplication app(argc, argv); // 初始化libVLC libvlc_instance_t *vlcInstance = libvlc_new(0, nullptr); // 创建一个视频播放窗口 QFrame *videoFrame = new QFrame; QVBoxLayout *layout = new QVBoxLayout; layout->addWidget(videoFrame); QWidget window; window.setLayout(layout); window.show(); // 创建一个libVLC媒体播放器 libvlc_media_player_t *mediaPlayer = libvlc_media_player_new(vlcInstance); // 设置RTMP视频的URL const char *rtmpUrl = "rtmp://example.com/live/stream"; libvlc_media_t *media = libvlc_media_new_location(vlcInstance, rtmpUrl); libvlc_media_player_set_media(mediaPlayer, media); libvlc_media_release(media); // 设置视频输出窗口 libvlc_media_player_set_hwnd(mediaPlayer, (void *)videoFrame->winId()); // 播放视频 libvlc_media_player_play(mediaPlayer); // 运行Qt事件循环 return app.exec(); } ``` 这只是一个简单的示例代码,你可以根据你的需求进行更多的定制和功能扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值