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  · 

QGraphicsTransform

La classe QGraphicsTransform est une classe abstraite destinée à la construction de transformations avancées sur des QGraphicsItem. Plus d'informations...

#include <QGraphicsTransform>

Voir la position dans l'arbre des classes.

Héritage

Hérite de QObject.

Hérité par QGraphicsRotation and QGraphicsScale.

Cette classe a été introduite dans Qt 4.6.

Description détaillée

La classe QGraphicsTransform est une classe abstraite destinée à la construction de transformations avancées sur des QGraphicsItem.

En tant qu'alternative à QGraphicsItem::transform, QGraphicsTransform vous permet de créer et de contrôler des transformations avancées pouvant être configurées indépendamment en utilisant des propriétés spécialisées.

QGraphicsItem vous autorise à associer plusieurs instances de QGraphicsTransform à un QGraphicsItem. Chaque QGraphicsTransform est appliquée dans l'ordre, une par une, au QGraphicsItem à laquelle elle est associée.

QGraphicsTransform est particulièrement utile pour les animations. Comme QGraphicsItem::setTransform() vous fait affecter les transformations directement aux éléments, elle ne donne pas de moyen direct d'interpolation entre deux transformations différentes (par exemple, pour une transition entre deux états, pour chacun desquels l'élément a une transformation distincte affectée). En utilisant QGraphicsTransform, vous pouvez interpoler indépendamment les valeurs de propriété de chaque transformation. L'opération résultante est alors combinée dans une transformation unique qui est appliquée à QGraphicsItem.

Les transformations sont d'abord calculées dans un espace 3D en utilisant QMatrix4x4. Lorsque la transformation est appliquée à un QGraphicsItem, elle est ensuite projetée sur une QTransform 2D. Quand plusieurs objets QGraphicsTransform sont appliqués à un QGraphicsItem, toutes les transformations sont calculées dans un espace 3D, la projection en 2D étant effectuée seulement après l'application de la dernière QGraphicsTransform. L'exception est QGraphicsRotation, qui est projetée en 2D après chaque rotation pour préserver l'effet de perspective autour des axes X et Y.

Si vous voulez créer votre propre transformation configurable, vous pouvez créer une classe dérivée de QGraphicsTransform (ou d'une classe dérivée déjà existante) et réimplémenter la fonction virtuelle pure applyTo(), qui prend comme paramètre un pointeur vers une QMatrix4x4. Chaque opération que vous voulez appliquer doit être exposée sous forme de propriétés (par exemple, customTransform->setVerticalShear(2.5)). Dans votre réimplémentation de applyTo(), vous pouvez modifier la transformation fournie.

QGraphicsTransform peut être utilisée en même temps que QGraphicsItem::setTransform(), QGraphicsItem::setRotation() et QGraphicsItem::setScale().

Voir aussi QGraphicsItem::transform(), QGraphicsScale et QGraphicsRotation.

Fonctions membres

QGraphicsTransform::QGraphicsTransform ( QObject * parent = 0 )

Construit un nouveau QGraphicsTransform avec le parent donné.

QGraphicsTransform::~QGraphicsTransform ()

Détruit l'objet.

void QGraphicsTransform::applyTo ( QMatrix4x4 * matrix ) const [pure virtual]

Cette méthode virtuelle pure doit être réimplémentée dans les classes dérivées.

Elle applique cette transformation à matrix.

Voir aussi QGraphicsItem::transform() et QMatrix4x4::toTransform().

void QGraphicsTransform::update () [protected slot]

Prévient que cette opération de transformation a modifié ses paramètres et qu'en conséquence applyTo() renverra un résultat différent.

Si vous implémentez vos propres transformations graphiques, vous devez appeler cette fonction à chaque fois que vous modifiez un paramètre, pour que QGraphicsItem sache que sa transformation doit être mise à jour.

Voir aussi applyTo().

Remerciements

Merci à Ilya Diallo pour la traduction et à Dimitry Ernot ainsi qu'à Jacques Thery pour leur relecture !

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 53
  2. Les développeurs ignorent-ils trop les failles découvertes dans leur code ? Prenez-vous en compte les remarques des autres ? 17
  3. Apercevoir la troisième dimension ou l'utilisation multithreadée d'OpenGL dans Qt, un article des Qt Quarterly traduit par Guillaume Belz 0
  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 Qt Developer Network au hasard

Logo

Livre blanc de l'outillage de Qt Quick

Le Qt Developer Network est un réseau de développeurs Qt anglophone, où ils peuvent partager leur expérience sur le framework. 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
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