Viadeo Twitter Google Bookmarks ! Facebook Digg del.icio.us MySpace Yahoo MyWeb Blinklist Netvouz Reddit Simpy StumbleUpon Bookmarks Windows Live Favorites 
Logo Documentation Qt ·  Page d'accueil  ·  Toutes les classes  ·  Toutes les fonctions  ·  Vues d'ensemble  · 

MediaNode Class Reference

(Phonon::MediaNode)

The MediaNode class is the base class for all nodes in a media graph. More...

 #include <Phonon/MediaNode>

Inherited by: Phonon::AudioDataOutput, Phonon::AudioOutput, Phonon::Effect, Phonon::MediaObject, and Phonon::VideoWidget.

This class was introduced in Qt 4.4.

Public Functions

virtual ~MediaNode ()
QList<Path> inputPaths () const
bool isValid () const
QList<Path> outputPaths () const

Detailed Description

The MediaNode class is the base class for all nodes in a media graph.

In all phonon applications, one builds a media graph consisting of MediaNodes. The graph will take multimedia content, e.g., from a file, as input. After its nodes have processed the multimedia, the graph will output the media again, e.g., to a sound card.

The multimedia content is streamed over Paths between the nodes in the graph. You can query the paths that are connected to a media node with inputPaths() and outputPaths().

You can check whether the node is implemented by the current backend by calling isValid(). This does not guarantee that an instance of the class works as expected, but that the backend has implemented functionality for the class.

Currently, Phonon has four media nodes: MediaObject, AudioOutput, VideoWidget, and Effect. Please refer to their class descriptions for details about their usage, and to find out which nodes can be connected to each other. See also Building Graphs in Phonon's overview document.

Two nodes are connected to each other using the Phonon::createPath() or Path::insertEffect() functions (only Phonon::Effects use insertEffect()). We show a code example below, in which we build a media graph for video playback and then query its media nodes for their Paths:

     Phonon::MediaObject *mediaObject = new Phonon::MediaObject;
     Phonon::AudioOutput *audioOutput = new Phonon::AudioOutput;
     Phonon::VideoWidget *videoWidget = new Phonon::VideoWidget;

     Phonon::createPath(mediaObject, audioOutput);
     Phonon::createPath(mediaObject, videoWidget);

     QList<Phonon::Path> inputPaths =
         audioOutput->inputPaths();   // inputPaths = [ mediaObject ]
     QList<Phonon::Path> outputPaths =
         mediaObject->outputPaths(); // outputPaths = [ audioOutput, videoWidget ]

When you create a Phonon application, you will likely build the graph yourself. This makes isValid() the most useful function of this class. The other two functions help navigate the graph, which you do not need to do as you created the nodes yourself.

See also Phonon Overview, Phonon::MediaObject, Phonon::AudioOutput, Phonon::VideoWidget, and Phonon Module.

Member Function Documentation

MediaNode::~MediaNode () [virtual]

Destroys the media node and any paths connecting it to other nodes. Any Effects connected to these paths will also be deleted.

QList<Path> MediaNode::inputPaths () const

Returns the paths that inputs multimedia to this media node.

See also outputPaths().

bool MediaNode::isValid () const

Returns true if the backend provides an implementation of this class; otherwise returns false.

This does not guarantee that instances of the class works as expected, but that the backend has implemented the functionality for this class. For instance, Qt's GStreamer backend will return true for instances of the AudioOutput class, even if there is a problem with GStreamer and it could not play sound.

QList<Path> MediaNode::outputPaths () const

Returns the paths to which this media node outputs media.

See also inputPaths().

Publicité

Best Of

Actualités les plus lues

Semaine
Mois
Année
  1. « Quelque chose ne va vraiment pas avec les développeurs "modernes" », un développeur à "l'ancienne" critique la multiplication des bibliothèques 64
  2. Apercevoir la troisième dimension ou l'utilisation multithreadée d'OpenGL dans Qt, un article des Qt Quarterly traduit par Guillaume Belz 0
  3. Les développeurs ignorent-ils trop les failles découvertes dans leur code ? Prenez-vous en compte les remarques des autres ? 17
  4. BlackBerry 10 : premières images du prochain OS de RIM qui devrait intégrer des widgets et des tuiles inspirées de Windows Phone 0
  5. Quelles nouveautés de C++11 Visual C++ doit-il rapidement intégrer ? Donnez-nous votre avis 10
  6. Adieu qmake, bienvenue qbs : Qt Building Suite, un outil déclaratif et extensible pour la compilation de projets Qt 17
  7. La rubrique Qt a besoin de vous ! 1
Page suivante

Le blog Digia au hasard

Logo

Créer des applications avec un style Metro avec Qt, exemples en QML et C++, un article de Digia Qt traduit par Thibaut Cuvelier

Le blog Digia est l'endroit privilégié pour la communication sur l'édition commerciale de Qt, où des réponses publiques sont apportées aux questions les plus posées au support. Lire l'article.

Communauté

Ressources

Liens utiles

Contact

  • Vous souhaitez rejoindre la rédaction ou proposer un tutoriel, une traduction, une question... ? Postez dans le forum Contribuez ou contactez-nous par MP ou par email (voir en bas de page).

Qt dans le magazine

Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. Qt 4.7-snapshot
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP !
 
 
 
 
Partenaires

Hébergement Web