python实现媒体播放器功能


Posted in Python onFebruary 11, 2018

本文实例为大家分享了python实现媒体播放器功能的具体代码,供大家参考,具体内容如下

playMP3.py

# -*- coding: utf-8 -*- 
import wx; 
import wx.media; 
import os; 
import SPrint; 
import mediaStateBar; 
import mediaList; 
import SaveLog; 
import MediaItem; 
woldcart = "media files|*.*|avi|*.avi|rmvb|*.rmvb|rm|*.rm|wma|*.wma|mp3|*.mp3"; 
class MediaFrame(wx.Frame): 
 def __init__(self): 
  wx.Frame.__init__(self,None,wx.NewId(),u"媒体播放器",pos=wx.DefaultPosition,size=(500,500)); 
  self.media = ''; 
  try: 
   self.media = wx.media.MediaCtrl(self,style=wx.SIMPLE_BORDER, 
            #szBackend=wx.media.MEDIABACKEND_DIRECTSHOW 
            #szBackend=wx.media.MEDIABACKEND_QUICKTIME 
            #szBackend=wx.media.MEDIABACKEND_WMP10 
            ); 
   self.media.Bind(wx.media.EVT_MEDIA_LOADED,self.mediaLoaded); 
   self.media.Bind(wx.media.EVT_MEDIA_STATECHANGED,self.mediaStateChange) 
  except NotImplementedError: 
   self.Destroy() 
   raise; 
  self.listView = ''; 
  self.item = MediaItem.MediaItem(); 
  self.sb = mediaStateBar.MediaStateBar(self); 
  self.SetStatusBar(self.sb); 
  self.log = SaveLog.SaveLog(); 
  #self.log.test(); 
  self.menu = wx.Menu() 
  self.openMenu = self.menu.Append(wx.NewId(),u"打开文件"); 
  self.Bind(wx.EVT_MENU,self._openFile,self.openMenu); 
  self.quitMenu = self.menu.Append(wx.NewId(),u"退出"); 
  self.Bind(wx.EVT_MENU,self.quit,self.quitMenu); 
  self.viewMenu = wx.Menu(); 
  self.listMenu = self.viewMenu.Append(wx.NewId(),u"打开播放列表"); 
  self.Bind(wx.EVT_MENU,self.openList,self.listMenu); 
  self.loadListMenu = self.viewMenu.Append(wx.NewId(),u"加载播放列表"); 
  self.Bind(wx.EVT_MENU,self.loadMediaList,self.loadListMenu); 
  self.saveListMenu = self.viewMenu.Append(wx.NewId(),u"保存播放列表") 
  self.Bind(wx.EVT_MENU,self.saveMediaList,self.saveListMenu); 
  menuBar = wx.MenuBar(); 
  menuBar.Append(self.menu,u"文件") 
  menuBar.Append(self.viewMenu,u"播放列表") 
  self.SetMenuBar(menuBar); 
  self.slider = wx.Slider(self,wx.NewId(), 0,0,100); 
  self.Bind(wx.EVT_SLIDER,self.onSeek,self.slider); 
  self.btnGroupSizer = wx.BoxSizer(wx.HORIZONTAL); 
  self.btnGroupSizer.Add((5,5),0) 
  self.playBtn = self.createButton("./pic/play.png",self.playMp3,u"播放"); 
  self.playBtn.Disable() 
  self.btnGroupSizer.Add(self.playBtn); 
  self.btnGroupSizer.Add((5,5),0) 
  self.pauseBtn = self.createButton("./pic/pause.png",self.pauseMp3,u"暂停"); 
  self.pauseBtn.Disable() 
  self.btnGroupSizer.Add(self.pauseBtn); 
  self.btnGroupSizer.Add((5,5),0) 
  self.stopBtn = self.createButton("./pic/stop.png",self.stopMp3,u"停止"); 
  self.stopBtn.Disable() 
  self.btnGroupSizer.Add(self.stopBtn); 
  self.btnGroupSizer.Add((5,5),0) 
  self.preBtn = self.createButton("./pic/pre.png",self.preMp3,u"前一个"); 
  self.preBtn.Disable() 
  self.btnGroupSizer.Add(self.preBtn); 
  self.btnGroupSizer.Add((5,5),0) 
  self.nextBtn = self.createButton("./pic/next.png",self.nextMp3,u"下一个"); 
  self.nextBtn.Disable() 
  self.btnGroupSizer.Add(self.nextBtn); 
  self.btnGroupSizer.Add((5,5),0) 
  self.openBtn = self.createButton("./pic/media.png",self._openFile,u"打开文件"); 
  #self.openBtn.Disable() 
  self.btnGroupSizer.Add(self.openBtn); 
  self.btnGroupSizer.Add((5,5),0) 
  self.listBtn = self.createButton("./pic/list.png",self.openList,u"打开列表"); 
  #self.listBtn.Disable() 
  self.btnGroupSizer.Add(self.listBtn) 
  self.btnGroupSizer.Add((5,5),0) 
  self.volSlider = wx.Slider(self,wx.NewId(), 0,0,100); 
  self.Bind(wx.EVT_SLIDER,self.volumeSeek,self.volSlider); 
  self.btnGroupSizer.Add(self.volSlider) 
  self.btnGroupSizer.Add((5,5),0) 
  self.volTxt = wx.StaticText(self,wx.NewId(),"") 
  self.btnGroupSizer.Add(self.volTxt) 
  self.btnGroupSizer.Add((5,5),0) 
  mainSizer = wx.BoxSizer(wx.VERTICAL); 
  mainSizer.Add(self.media,1,wx.EXPAND|wx.ALL,5); 
  #mainSizer.Add((5,5),0) 
  mainSizer.Add(self.slider,0,wx.EXPAND|wx.ALL,5); 
  #mainSizer.Add((2,2),0) 
  mainSizer.Add(self.btnGroupSizer,0,wx.EXPAND|wx.ALL,5); 
  #mainSizer.Add((2,2),0) 
  self.SetSizer(mainSizer); 
  self.Layout(); 
  self.timer = wx.Timer(self) 
  self.Bind(wx.EVT_TIMER,self.onTimer); 
  self.timer.Start(200); 
 def createButton(self,img,clickFun,tip=""): 
  bmp = wx.Bitmap(img, wx.BITMAP_TYPE_PNG); 
  btn = wx.BitmapButton(self,wx.NewId(),bmp); 
  if tip != '' : btn.SetToolTipString(tip); 
  btn.Bind(wx.EVT_BUTTON,clickFun); 
  return btn; 
 def quit(self,event): 
  self.Destroy(); 
 def playMp3(self,e): 
  if self.item != '': 
   self.media.Play() 
  # self.media.SetInitialSize() 
 def pauseMp3(self,e=''): 
  self.media.Pause() 
 def stopMp3(self,e=''): 
  self.media.Stop() 
 def preMp3(self,e): 
  if self.item!='': 
   self.item = self.log.getPreItem(self.item.index) 
   if self.item != '': 
    self.playMedia(self.item.url,self.item.fileName); 
 def nextMp3(self,e): 
  if self.item!='': 
   self.item = self.log.getNextItem(self.item.index) 
   if self.item != '': 
    self.playMedia(self.item.url,self.item.fileName); 
 def onSeek(self,event): 
  self.media.Seek(self.slider.GetValue()) 
 def callAfterPlayMedia(self,url): 
  #self.media.SetInitialSize(); 
  self.media.Play(); 
 def playMedia(self,url,filename): 
  #print SPrint.encodeFromSystem( u"播放文件: " ) , SPrint.encodeFromSystem(url) ; 
  if self.media.Load(url) != True: 
   return ; 
  self.item = MediaItem.MediaItem(); 
  self.item.fileName = filename; 
  self.item.url = url; 
  self.SetTitle(filename) 
  self.SetStatusText(filename,1) 
  #wx.FutureCall(2000,self.callAfterPlayMedia,url); 
 def _openFile(self,event): 
  dialog = wx.FileDialog(self,u"打开文件",'F://movie//',"",woldcart,style=wx.OPEN|wx.CHANGE_DIR) 
  if dialog.ShowModal() == wx.ID_OK: 
   self.playMedia(dialog.GetPath(),dialog.GetFilename()) 
  dialog.Destroy(); 
 def cellRemove(self,url,all=False): 
  if all == True: 
   self.stopMp3() 
   self.item = ''; 
   return ; 
  if self.item.url == url: 
   self.stopMp3(); 
   self.item = ''; 
 def volumeSeek(self,evt): 
  #print float(self.volSlider.GetValue()/100); 
  self.media.SetVolume(self.volSlider.GetValue()/100.0) 
  self.volTxt.SetLabel(str(self.volSlider.GetValue())+'%') 
 def mediaLoaded(self,e): 
  print "media loaded!" 
  self.media.Play(); 
  self.slider.SetRange(0,self.media.Length()); 
  self.item.length = self.getAccurateTime(self.media.Length()/1000); 
  if self.log.addItem(self.item): 
   if self.listView != '': 
    self.listView.reflash(self.log); 
  if self.log.haveNextItem(self.item.index): 
   self.nextBtn.Enable(); 
  else: 
   self.nextBtn.Disable() 
  if self.log.havePreItem(self.item.index): 
   self.preBtn.Enable() 
  else: 
   self.preBtn.Disable(); 
  self.volSlider.SetValue(self.media.GetVolume()*100); 
  self.volTxt.SetLabel(str(self.volSlider.GetValue())+'%') 
 def mediaStateChange(self,evt): 
  if self.media.GetState() == wx.media.MEDIASTATE_PAUSED: 
   self.playBtn.Enable() 
   self.pauseBtn.Disable() 
   self.stopBtn.Enable(); 
   self.SetStatusText(u"暂停") 
  elif self.media.GetState() == wx.media.MEDIASTATE_PLAYING: 
   self.playBtn.Disable() 
   self.pauseBtn.Enable() 
   self.stopBtn.Enable(); 
   self.SetStatusText(u"播放") 
  elif self.media.GetState() == wx.media.MEDIASTATE_STOPPED: 
   self.playBtn.Enable() 
   self.pauseBtn.Enable() 
   self.stopBtn.Disable(); 
   self.SetStatusText(u"停止") 
 def onTimer(self,evt): 
  self.slider.SetValue(self.media.Tell()); 
  self.SetStatusText(self.creatTimeStatusTEXT(),1) 
 def creatTimeStatusTEXT(self): 
  current = self.getAccurateTime(self.media.Tell()/1000); 
  total = self.getAccurateTime(self.media.Length()/1000); 
  return ' ' + current + '/' + total; 
 def openList(self,evt): 
  if self.listView == '': 
   self.listView = mediaList.MediaListView(self,self.log); 
   self.listView.CenterOnParent(wx.BOTH); 
   self.listView.Show(); 
   self.listView.Bind(wx.EVT_CLOSE,self.closeOpenList); 
  else: 
   self.closeOpenList(evt); 
 def closeOpenList(self,evt): 
  self.listView.Destroy(); 
  self.listView = ''; 
 def loadMediaList(self,evt): 
  woldcart1 = "txt|*.txt"; 
  dialog = wx.FileDialog(self,u"加载播放列表",'C:',"",woldcart1,style=wx.OPEN|wx.CHANGE_DIR) 
  if dialog.ShowModal() == wx.ID_OK: 
   self._loadMediaList(dialog.GetPath()) 
  dialog.Destroy(); 
 def _loadMediaList(self,url): 
  f = file(url) 
  lines = f.readlines() 
  for line in lines: 
   if line: 
    self.log.loadLog(line); 
 def saveMediaList(self,evt): 
  woldcart1 = "txt|*.txt"; 
  dialog = wx.FileDialog(self,u"保存播放列表",'C:',"",woldcart1,style=wx.SAVE|wx.CHANGE_DIR) 
  if dialog.ShowModal() == wx.ID_OK: 
   self._saveMediaList(dialog.GetPath()) 
  dialog.Destroy(); 
 def _saveMediaList(self,url): 
  f = file(url,"w+") 
  f.writelines(self.log.createLog()); 
  f.close(); 
  self.showMessage(u"保存成功!"); 
 def showMessage(self,str): 
  dlg = wx.MessageDialog(self, str,u"消息", wx.OK | wx.ICON_INFORMATION) 
  dlg.ShowModal() 
  dlg.Destroy() 
 def getAccurateTime(self,s): 
  h = 0 
  m = 0 
  if s/60 !=0: 
   m = s/60 
   s = s%60 
  if m/60 !=0: 
   h = m/60 
   m = m%60 
  return str(h)+':'+str(m)+':'+str(s) 
 
if __name__ == "__main__": 
 app = wx.PySimpleApp() 
 frame = MediaFrame(); 
 bmp = wx.Icon("./pic/media.png",wx.BITMAP_TYPE_PNG) 
 frame.SetIcon(bmp) 
 frame.Show(); 
 app.MainLoop();

mediaList.py

# -*- coding: utf-8 -*- 
import wx; 
import sys; 
import os; 
import SaveLog; 
import subprocess; 
class MediaListView(wx.MiniFrame): 
 def __init__(self,parent,log): 
  wx.MiniFrame.__init__(self,parent,wx.NewId(),u"文件列表",style=wx.DEFAULT_FRAME_STYLE); 
  self.SetAutoLayout(True) 
  self.mediaMain = parent; 
  self.menu = ''; 
  self.selectIndex = -1 
  self.listDataLog = SaveLog.SaveLog(); 
  self.listDataLog = log; 
  self.listct = wx.ListCtrl(self,wx.NewId(),style=wx.LC_REPORT| 
               wx.LC_VRULES| 
               wx.LC_SORT_ASCENDING); 
  self.listct.InsertColumn(0,u"编号") 
  self.listct.SetColumnWidth(0,38) 
  self.listct.InsertColumn(1,u"名字") 
  self.listct.SetColumnWidth(1,235) 
  self.listct.InsertColumn(2,u"时间"); 
  self.listct.SetColumnWidth(2,105) 
  frSizer = wx.BoxSizer(wx.VERTICAL) 
  frSizer.Add(self.listct,1,wx.EXPAND|wx.ALL,5) 
  self.listct.Bind(wx.EVT_CONTEXT_MENU,self.onRightClick) 
  self.listct.Bind(wx.EVT_LEFT_DCLICK,self.doubleClick) 
  self.listct.Bind(wx.EVT_LIST_ITEM_SELECTED,self.itemSelected) 
  self.SetSizer(frSizer) 
  self.Layout(); 
  wx.CallAfter(self.reflash,self.listDataLog) 
 def reflash(self,log=''): 
  self.listct.DeleteAllItems(); 
  if log != '': 
   self.listDataLog = log; 
  i = 0; 
  ls = log.getList(); 
  for it in ls: 
   if it: 
    index = self.listct.InsertStringItem(i,str(it.index)); 
    self.listct.SetStringItem(index,0,str(it.index)) 
    self.listct.SetStringItem(index,1,it.fileName) 
    self.listct.SetStringItem(index,2,it.length) 
    i = i+1; 
 def onRightClick(self,evt): 
  self.menu = wx.Menu(); 
  self.playMenu = self.menu.Append(wx.NewId(),u"播放") 
  self.Bind(wx.EVT_MENU,self.cellPlay,self.playMenu) 
  self.delMenu = self.menu.Append(wx.NewId(),u"删除") 
  self.Bind(wx.EVT_MENU,self.cellRomve,self.delMenu); 
  self.dirMenu = self.menu.Append(wx.NewId(),u"打开文件目录") 
  self.Bind(wx.EVT_MENU,self.openDir,self.dirMenu); 
  self.delAllMenu = self.menu.Append(wx.NewId(),u"清除播放列表") 
  self.Bind(wx.EVT_MENU,self.clearAll,self.delAllMenu); 
  self.PopupMenu(self.menu); 
  self.menu.Destroy(); 
 def cellPlay(self,evt): 
  self.selectIndex = self.listct.GetFirstSelected(); 
  item = self.listDataLog.getItemByIndex(self.selectIndex); 
  self.mediaMain.playMedia(item.url,item.fileName); 
 def cellRomve(self,evt): 
  #self.selectIndex = self.listct.GetFirstSelected(); 
  url = self.listDataLog.delItemByIndex(self.listct.GetFirstSelected()); 
  self.listDataLog.reflashDataByIndex(); 
  self.reflash(self.listDataLog); 
  self.mediaMain.cellRemove(url) 
 def doubleClick(self,evt): 
  item = self.listDataLog.getItemByIndex(self.selectIndex); 
  self.mediaMain.playMedia(item.url,item.fileName); 
  evt.Skip(); 
 def itemSelected(self,evt): 
  self.selectIndex = evt.GetIndex(); 
  evt.Skip(); 
 def openDir(self,evt): 
  self.selectIndex = self.listct.GetFirstSelected(); 
  item = self.listDataLog.getItemByIndex(self.selectIndex); 
  subprocess.Popen("explorer " + os.path.split(item.url)[0]); 
 def clearAll(self,evt): 
  self.listDataLog.clearAll(); 
  self.reflash(self.listDataLog); 
  self.mediaMain.cellRemove('',True)

SaveLog.py

import MediaItem; 
class SaveLog(): 
 list = []; 
 def addItem(self,it=MediaItem.MediaItem): 
  if self.getItemByURL(it.url) == '' : 
   it.index = len(self.list) + 1; 
   self.list.append(it); 
   return True; 
  return False; 
 def clearAll(self): 
  self.list = []; 
 def getItemByURL(self,url): 
  for it in self.list: 
   if it and it.url == url: 
    return it; 
  return ''; 
 def getItemByIndex(self,ind): 
  return self.list[ind]; 
 def delItemByIndex(self,ind): 
  it = self.getItemByIndex(ind); 
  if it : 
   url = it.url; 
   self.list.remove(it); 
   return url; 
  return ''; 
 def reflashDataByIndex(self): 
  i = 1; 
  for it in self.list: 
   if it: 
    it.index = i; 
    i = i+ 1; 
 def havePreItem(self,ind): 
  if ind-1>0: 
   return True; 
  return False; 
 def haveNextItem(self,ind): 
  if ind < len(self.list)-1: 
   return True; 
  return False; 
 def getPreItem(self,ind): 
  if ind>0: 
   ind = ind -1; 
   return self.list[ind]; 
  return ''; 
 def getNextItem(self,ind): 
  if ind < len(self.list)-1: 
   ind = ind + 1; 
   return self.list[ind]; 
  return ''; 
 def getList(self): 
  return self.list; 
 def createLog(self): 
  out = []; 
  for it in self.list: 
   if it: 
    out.append(it.createLog()) 
  return out; 
 def loadLog(self,s=''): 
  ls = s.split("|"); 
  item = MediaItem.MediaItem(); 
  item.index = ls[0] 
  item.fileName = ls[1] 
  item.url = ls[2] 
  item.length = ls[3]; 
  self.addItem(item); 
 
 def test(self): 
  item = MediaItem.MediaItem(); 
  item.index = 0; 
  item.fileName = '123' 
  item.length = '123' 
  item.url = '123' 
  self.list.append(item) 
  item2 = MediaItem.MediaItem(); 
  item2.index = 1; 
  item2.fileName = '1234' 
  item2.length = '1234' 
  item2.url = '1234' 
  self.list.append(item2) 
  item3 = MediaItem.MediaItem(); 
  item3.index = 2; 
  item3.fileName = '12345' 
  item3.length = '12345' 
  item3.url = '12345' 
  self.list.append(item3)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python标准库urllib2的一些使用细节总结
Mar 16 Python
简单谈谈Python中的反转字符串问题
Oct 24 Python
Scrapy的简单使用教程
Oct 24 Python
Python基于更相减损术实现求解最大公约数的方法
Apr 04 Python
Python3实现的字典遍历操作详解
Apr 18 Python
使用Python处理BAM的方法
Sep 28 Python
Python远程视频监控程序的实例代码
May 05 Python
详解python websocket获取实时数据的几种常见链接方式
Jul 01 Python
Python开发之身份证验证库id_validator验证身份证号合法性及根据身份证号返回住址年龄等信息
Mar 20 Python
Python pymsql模块的使用
Sep 07 Python
python 基于wx实现音乐播放
Nov 24 Python
Elasticsearch 批量操作
Apr 19 Python
python使用pycharm环境调用opencv库
Feb 11 #Python
Python元组及文件核心对象类型详解
Feb 11 #Python
详解Python核心对象类型字符串
Feb 11 #Python
python使用json序列化datetime类型实例解析
Feb 11 #Python
Python中pow()和math.pow()函数用法示例
Feb 11 #Python
Python反射的用法实例分析
Feb 11 #Python
python互斥锁、加锁、同步机制、异步通信知识总结
Feb 11 #Python
You might like
php在页面中调用fckeditor编辑器的方法
2011/06/10 PHP
php无限极分类实现的两种解决方法
2013/04/28 PHP
PHP开发注意事项总结
2015/02/04 PHP
PHP实现的线索二叉树及二叉树遍历方法详解
2016/04/25 PHP
php实现支持中文的文件下载功能示例
2017/08/30 PHP
PHP读取XML文件的方法实例总结【DOMDocument及simplexml方法】
2019/09/10 PHP
火狐浏览器(firefox)下获得Event对象以及keyCode
2008/11/13 Javascript
web 页面分页打印的实现
2009/06/22 Javascript
真正的JQuery.ajax传递中文参数的解决方法
2011/05/28 Javascript
js中数组Array的一些常用方法总结
2013/08/12 Javascript
jQuery遍历Table应用示例
2014/04/09 Javascript
javascript实现很浪漫的气泡冒出特效
2020/09/05 Javascript
jQuery插件之jQuery.Form.js用法实例分析(附demo示例源码)
2016/01/04 Javascript
JS动态加载脚本并执行回调操作
2016/08/24 Javascript
JavaScript随机生成颜色的方法
2016/10/15 Javascript
详谈Node.js之操作文件系统
2017/08/29 Javascript
前端把html表格生成为excel表格的实例
2017/09/19 Javascript
基于vue和react的spa进行按需加载的实现方法
2018/09/29 Javascript
小程序选项卡以及swiper套用(跨页面)
2020/06/19 Javascript
详解js创建对象的几种方式和对象方法
2021/03/01 Javascript
Python采集腾讯新闻实例
2014/07/10 Python
基于python生成器封装的协程类
2019/03/20 Python
关于不懂Chromedriver如何配置环境变量问题解决方法
2019/06/12 Python
Python如何输出整数
2020/06/07 Python
美国知名的家庭连锁百货商店:Boscov’s
2017/07/27 全球购物
一道写SQL的面试题和答案
2013/11/19 面试题
劳动模范事迹材料
2014/01/19 职场文书
个人校本研修方案
2014/05/26 职场文书
关于成绩下滑的自我检讨书
2014/09/20 职场文书
2014年教师业务工作总结
2014/12/19 职场文书
表扬稿范文
2015/01/17 职场文书
2015社区精神文明建设工作总结
2015/04/21 职场文书
2015年人事专员工作总结
2015/04/29 职场文书
成功的商业计划书这样写才最靠谱
2019/07/12 职场文书
Windows Server 2012 R2 磁盘分区教程
2022/04/29 Servers
Go Grpc Gateway兼容HTTP协议文档自动生成网关
2022/06/16 Golang