Accueil > > > [PYGTK] LECTEUR MULTI-VIDÉO EMBARQUANT MPLAYER GRÂCE À L'ID WINDOW D'UNE SOCKET.
[PYGTK] LECTEUR MULTI-VIDÉO EMBARQUANT MPLAYER GRÂCE À L'ID WINDOW D'UNE SOCKET.
Information sur la source
Description
Ce lecteur multi-vidéo embarque Mplayer, à travers l'utilisation de la classe GtkSocket de Pygtk, qui permet d'intégrer n'importe quelle interface, grâce à son identification(id Window). Écrit en python, ce lecteur permet de lire jusqu'à 4 vidéos simultanément. Mplayer est utilisé en mode slave(cf documentation mplayer) pour permettre un contrôle par commande au travers d'un tube. A noter également son option '-wid' qui spécifie l'id sur laquelle il s'accrochera. Globalement il y a 3classes. La première est l'interface avec mplayer, elle crée le tube, et propose quelque commande. La seconde définit un player complet(vidéo, + widget de controle : play, rewind, forward, ouvrir un fichier) et utilise la 1ere classe pour interargir avec les widgets. La troisième et dernière classe, est la classe de base de l'application. Elle s'occupe des routines habituelles avec pygtk, et crée les 4 players(En instanciant donc 4fois la seconde classe). Pourquoi ? Parceque tout simplement j'ai essayé une tonne de librairie pour "manipuler" de la vidéo dans mon application, ce qui fut un échec total. Notamment pymedia, salement documenté(des exemples très peu explicite, une gui utilisant pygame...etc). Ou pygst, qui dispose d'une bonne documentation(pas complète mais interressante), mais pas stable lorsque j'ai essayé différents formats, ou lorsqu'on essaye de se déplacer dans la vidéo, le programme plante... La meilleure solution était donc d'intégrer directement un player et d'intérargir avec. D'autant plus que si vous cliquez sur la vidéo, vous pouvez utiliser les touches supportés par mplayer!(Exemple : 'p' pour pause...etc). En espérant que cette modeste contribution aide certains d'entres-vous! Environnement de développement : x86, Ubuntu, noyau 2.6 Python 2.5 Pygtk 2.0
Source
- # -*- Encoding: Latin-1 -*-
-
- import pygtk
- pygtk.require('2.0')
- import gtk
- import os
- import psyco
- psyco.full()
-
- twindow = gtk.EXPAND | gtk.FILL | gtk.SHRINK
-
- PATH_mkfifo = '/tmp/mplayer'
-
- class Pymplayer(gtk.Socket):
- """Classe d'interface entre mplayer et le programme"""
- def __init__(self, id):
- gtk.Socket.__init__(self)
- self.tube = PATH_mkfifo + str(id)
- try:
- #Supprimer le fichier tube si présent.
- os.unlink(self.tube)
- except:
- pass
- #On crée le tube, son nom est mplayer+id
- os.mkfifo(self.tube)
- os.chmod(self.tube, 0666)
-
- #On écrit dans le tube la commande en mode slave
- def execmplayer(self, cmd):
- open(self.tube,'w').write(cmd+"\n")
-
- #On lance mplayer en lui précisant l'id de la widget à utiliser(cf mplayer doc pour le reste)
- def setwid(self, wid):
- os.system("mplayer -nojoystick -nolirc -slave -vo x11 -wid %s -vf scale=400:200 -idle -input file=%s &"%(wid, self.tube))
-
- def loadfile(self, filename):
- self.execmplayer("loadfile %s"%(filename))
- self.execmplayer("change_rectangle w=100:h=100")
-
- def pause(self, parent):
- self.execmplayer("pause")
-
- def forward(self, parent):
- self.execmplayer("seek +10 0")
-
- def backward(self, parent):
- self.execmplayer("seek -10 0")
-
- def quit(self):
- self.execmplayer("quit")
-
-
-
- class Panel(gtk.Table):
- """ Elle definie le player, càd l'écran, et ses widgets(play, forward, backward...)"""
-
- def __init__(self, id):
- gtk.Table.__init__(self, 4, 2)
- #self.resize(4, 2)
- self.set_col_spacings(10)
- self.set_row_spacings(10)
-
- self.Ecran = Pymplayer(id)
- self.Ecran.set_size_request(100, 200)
- self.attach(self.Ecran, 0, 4, 0, 1, twindow, twindow, 5, 5)
-
- #Bouton Open file
- Bopenfile = gtk.Button(stock="gtk-open")
- Bopenfile.connect("clicked", self.openfile)
- self.attach(Bopenfile, 0, 1, 1, 2, twindow, twindow, 5, 5)
-
- #Bouton previous
- Brewind = gtk.Button(stock="gtk-media-rewind")
- Brewind.connect("clicked", self.Ecran.backward)
- self.attach(Brewind, 1, 2, 1, 2, twindow, twindow, 5, 5)
-
- #Bouton play
- Bplay = gtk.Button(stock="gtk-media-play")
- Bplay.connect("clicked", self.Ecran.pause)
- self.attach(Bplay, 2, 3, 1, 2, twindow, twindow, 5, 5)
-
- #Bouton next
- Bforward = gtk.Button(stock="gtk-media-forward")
- Bforward.connect("clicked", self.Ecran.forward)
- self.attach(Bforward, 3, 4, 1, 2, twindow, twindow, 5, 5)
-
-
- #Boite de dialogue qui permet à l'utilisateur de choisir un fichire
- def openfile(self, parent):
- dialog = gtk.FileChooserDialog("Select file", gtk.Window(), gtk.FILE_CHOOSER_ACTION_OPEN,
- (gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
- gtk.STOCK_OPEN, gtk.RESPONSE_OK))
- dialog.connect("destroy",lambda w:dialog.destroy())
- dialog.set_default_response(gtk.RESPONSE_OK)
-
- statut = dialog.run()
- if statut == gtk.RESPONSE_OK:
- #Ok nous avons le fichier, ouvrons le avec mplayer!
- self.Ecran.loadfile(dialog.get_filename())
- dialog.destroy()
-
-
- class guiPymplayer:
- """ Classe maitre, qui inclut toutes les autres classes"""
-
- def __init__(self):
- self.gui = gtk.Window(gtk.WINDOW_TOPLEVEL)
- self.gui.set_title("Using plug and socket : mplayer in python, by loupmagic")
- self.gui.set_default_size(550, 400)
- self.gui.set_position(gtk.WIN_POS_CENTER)
-
- self.global_panel()
-
- self.gui.connect("destroy", self.do_quit)
- self.gui.show_all()
-
- #Envoie des id seulement après l'affichage des widgets à l'aide de show_all()
- self.Panel1.Ecran.setwid(long(self.Panel1.Ecran.get_id()))
- self.Panel2.Ecran.setwid(long(self.Panel2.Ecran.get_id()))
- self.Panel3.Ecran.setwid(long(self.Panel3.Ecran.get_id()))
- self.Panel4.Ecran.setwid(long(self.Panel4.Ecran.get_id()))
-
-
- def global_panel(self):
- #Table d'organisation des widgets
- table = gtk.Table(3, 3, False)
-
- self.Panel1 = Panel(1)
- table.attach(self.Panel1, 0, 1, 0, 1, twindow, twindow, 5, 5)
-
- self.Panel2 = Panel(2)
- table.attach(self.Panel2, 2, 3, 0, 1, twindow, twindow, 5, 5)
-
- self.Panel3 = Panel(3)
- table.attach(self.Panel3, 0, 1, 2, 3, twindow, twindow, 5, 5)
-
- self.Panel4 = Panel(4)
- table.attach(self.Panel4, 2, 3, 2, 3, twindow, twindow, 5, 5)
-
- ligneH = gtk.HSeparator()
- table.attach(ligneH, 0, 3, 1, 2)
- ligneV = gtk.VSeparator()
- table.attach(ligneV, 1, 2, 0, 3)
-
- self.gui.add(table)
-
- def do_quit(self, widget):
- if __name__ == '__main__':
- #Fermer les processus mplayer!
- self.Panel1.Ecran.quit()
- self.Panel2.Ecran.quit()
- self.Panel3.Ecran.quit()
- self.Panel4.Ecran.quit()
- gtk.main_quit()
-
- def loop(self):
- gtk.main()
-
- multivideos = guiPymplayer()
- multivideos.loop()
# -*- Encoding: Latin-1 -*-
import pygtk
pygtk.require('2.0')
import gtk
import os
import psyco
psyco.full()
twindow = gtk.EXPAND | gtk.FILL | gtk.SHRINK
PATH_mkfifo = '/tmp/mplayer'
class Pymplayer(gtk.Socket):
"""Classe d'interface entre mplayer et le programme"""
def __init__(self, id):
gtk.Socket.__init__(self)
self.tube = PATH_mkfifo + str(id)
try:
#Supprimer le fichier tube si présent.
os.unlink(self.tube)
except:
pass
#On crée le tube, son nom est mplayer+id
os.mkfifo(self.tube)
os.chmod(self.tube, 0666)
#On écrit dans le tube la commande en mode slave
def execmplayer(self, cmd):
open(self.tube,'w').write(cmd+"\n")
#On lance mplayer en lui précisant l'id de la widget à utiliser(cf mplayer doc pour le reste)
def setwid(self, wid):
os.system("mplayer -nojoystick -nolirc -slave -vo x11 -wid %s -vf scale=400:200 -idle -input file=%s &"%(wid, self.tube))
def loadfile(self, filename):
self.execmplayer("loadfile %s"%(filename))
self.execmplayer("change_rectangle w=100:h=100")
def pause(self, parent):
self.execmplayer("pause")
def forward(self, parent):
self.execmplayer("seek +10 0")
def backward(self, parent):
self.execmplayer("seek -10 0")
def quit(self):
self.execmplayer("quit")
class Panel(gtk.Table):
""" Elle definie le player, càd l'écran, et ses widgets(play, forward, backward...)"""
def __init__(self, id):
gtk.Table.__init__(self, 4, 2)
#self.resize(4, 2)
self.set_col_spacings(10)
self.set_row_spacings(10)
self.Ecran = Pymplayer(id)
self.Ecran.set_size_request(100, 200)
self.attach(self.Ecran, 0, 4, 0, 1, twindow, twindow, 5, 5)
#Bouton Open file
Bopenfile = gtk.Button(stock="gtk-open")
Bopenfile.connect("clicked", self.openfile)
self.attach(Bopenfile, 0, 1, 1, 2, twindow, twindow, 5, 5)
#Bouton previous
Brewind = gtk.Button(stock="gtk-media-rewind")
Brewind.connect("clicked", self.Ecran.backward)
self.attach(Brewind, 1, 2, 1, 2, twindow, twindow, 5, 5)
#Bouton play
Bplay = gtk.Button(stock="gtk-media-play")
Bplay.connect("clicked", self.Ecran.pause)
self.attach(Bplay, 2, 3, 1, 2, twindow, twindow, 5, 5)
#Bouton next
Bforward = gtk.Button(stock="gtk-media-forward")
Bforward.connect("clicked", self.Ecran.forward)
self.attach(Bforward, 3, 4, 1, 2, twindow, twindow, 5, 5)
#Boite de dialogue qui permet à l'utilisateur de choisir un fichire
def openfile(self, parent):
dialog = gtk.FileChooserDialog("Select file", gtk.Window(), gtk.FILE_CHOOSER_ACTION_OPEN,
(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
gtk.STOCK_OPEN, gtk.RESPONSE_OK))
dialog.connect("destroy",lambda w:dialog.destroy())
dialog.set_default_response(gtk.RESPONSE_OK)
statut = dialog.run()
if statut == gtk.RESPONSE_OK:
#Ok nous avons le fichier, ouvrons le avec mplayer!
self.Ecran.loadfile(dialog.get_filename())
dialog.destroy()
class guiPymplayer:
""" Classe maitre, qui inclut toutes les autres classes"""
def __init__(self):
self.gui = gtk.Window(gtk.WINDOW_TOPLEVEL)
self.gui.set_title("Using plug and socket : mplayer in python, by loupmagic")
self.gui.set_default_size(550, 400)
self.gui.set_position(gtk.WIN_POS_CENTER)
self.global_panel()
self.gui.connect("destroy", self.do_quit)
self.gui.show_all()
#Envoie des id seulement après l'affichage des widgets à l'aide de show_all()
self.Panel1.Ecran.setwid(long(self.Panel1.Ecran.get_id()))
self.Panel2.Ecran.setwid(long(self.Panel2.Ecran.get_id()))
self.Panel3.Ecran.setwid(long(self.Panel3.Ecran.get_id()))
self.Panel4.Ecran.setwid(long(self.Panel4.Ecran.get_id()))
def global_panel(self):
#Table d'organisation des widgets
table = gtk.Table(3, 3, False)
self.Panel1 = Panel(1)
table.attach(self.Panel1, 0, 1, 0, 1, twindow, twindow, 5, 5)
self.Panel2 = Panel(2)
table.attach(self.Panel2, 2, 3, 0, 1, twindow, twindow, 5, 5)
self.Panel3 = Panel(3)
table.attach(self.Panel3, 0, 1, 2, 3, twindow, twindow, 5, 5)
self.Panel4 = Panel(4)
table.attach(self.Panel4, 2, 3, 2, 3, twindow, twindow, 5, 5)
ligneH = gtk.HSeparator()
table.attach(ligneH, 0, 3, 1, 2)
ligneV = gtk.VSeparator()
table.attach(ligneV, 1, 2, 0, 3)
self.gui.add(table)
def do_quit(self, widget):
if __name__ == '__main__':
#Fermer les processus mplayer!
self.Panel1.Ecran.quit()
self.Panel2.Ecran.quit()
self.Panel3.Ecran.quit()
self.Panel4.Ecran.quit()
gtk.main_quit()
def loop(self):
gtk.main()
multivideos = guiPymplayer()
multivideos.loop()
Conclusion
Le plus long a été la recherche consacré aux différents modules vidéos sous python, avec pygtk, puisque ce programme a été développé en 2H30(j'ai déjà réalisé une autre application, un peu plus précise, sur le même style).
En effet, la documentation francaise est quasi-inexistante, même aux niveaux des exemples. En anglais, un peu mieux, mais toujours pas d'élément concret démontrant l'utilité de telle ou telle classe sous python.
Cette solution me semble la plus approprié si vous voulez simplement embarqué un programme.
Le code est abordable. Il utilise simplement des classes hérités pour certaine de widget spécifique. Il quitte en nettoyant les processus lancés au démarrage.
Historique
- 01 avril 2008 12:08:30 :
- Ajout de l'environnement de développement (OS, version...etc)
- 01 avril 2008 12:10:43 :
- Ajout de l'environnement de développement(OS, version...etc)
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Bot IRC Python ... problème à l'ouverture de la socket [ par tcyrill2 ]
Bonjour ici, Voilà, on m'a filé les bases d'un bot IRC en python. Je sais qu'il fonctionne car j'ai eu l'occaz de le tester avec la personne qui me
Comment jouer la video avec python [ par TYKO86 ]
Bonjour, je travaille sur la réalisation d'une interface graphique avec pyqt et je voulais savoir comment jouer de la video avec. merci.
Socket Python en SSL et Jabber [ par superzero93 ]
Bonsoir à tousJ'ai installé un serveur XMPP Jabber sur une machine virtuelle Debian Lenny 32 bits (noyau 2.6.29 et sans interface graphique), et un cl
Python et SPSS [ par spirix88 ]
Bonjour,Comment faire appel à python depuis SPSS ? Merci d'avance.
Tuto Swinnen : mouvement aléatoire ? [ par nemo43 ]
Bonjour à tous,J'étudie le langage python - c'est un loisir - avec le livre de Gérard Swinnen (comme beaucoup de francophones je pense ). Je bloque su
{Python} remplacer des caractere dans une chaine [ par Yann2704 ]
Bonjours, Python 2.6.1 ... ... Win 32 ... ... >>> c1 = "plop" >>> c2 = "blabla" >>> print c1[3] p >>> print c2[3
Comment peut on recuperer les informations de la boussole en Python? [ par snap0merlin ]
Bonjour a tous!J'ai un nokia 6210 navigator et j'aimerais recuperer les donnees de la boussole (inclue dans le telephone) pour un de mes programmes en
Lancement exécutable Python depuis VBA [ par bichon3001 ]
Bonjour, j'ai crée un programme Python sur un problème de tournées de livraisons. Mon programme python ouvre un fichier csv, récupère les données et l
Python et Octave"matlab" [ par soufianovich ]
Bonjour, je suis stagiaire dans une entreprise, jai fait un code octave ou"matlab" c'est la meme chose qui traite mes données. Maintenant je suis en t
Python et octave [ par soufianovich ]
Bonjour, je suis stagiaire dans une entreprise, jai fait un code octave ou"matlab" c'est la meme chose qui traite mes données. Maintenant je suis en t
|
Derniers Blogs
TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Vincent Bellet et Baptiste Giraudier La BI dans SharePoint 2010, Les nouveaux services d'application dans SP2010 et SQL Server Reporting services 2008 R2. La BI dans SharePoint est généralisée pour tous afin de permettre à tous les coll...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2010 : PLAN DE MIGRATION VERS SHAREPOINT 2010TECHDAYS PARIS 2010 : PLAN DE MIGRATION VERS SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Arnault Nouvel et Antoine Dongois Le processus à prendre : Apprendre (découvrir la plateforme) Préparer (documenter l'historique et choisir la méthode de MAJ) Test (Test de MAJ) Implémenter (Effectuer la MAJ) Valid...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2010 : LA PLEINIèRE DU SECOND JOURTECHDAYS PARIS 2010 : LA PLEINIèRE DU SECOND JOUR par ROMELARD Fabrice
Après un retour sur l'histoire des TechDays de Paris et le fait que ce soit le plus gros event MS au monde (du fait de sa gratuité), le président de MS France (Eric Boustoullier) a fait une présentation de la vision Microsoft pour les années à venir...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|