aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorribet2007-06-01 11:14:18 +0000
committerribet2007-06-01 11:14:18 +0000
commitf06a2c91b41e5e54ffbad7dd46bd700207fbdb84 (patch)
tree10ee6c69f315a34722af491dc4688e80a94eea4e
parent01729808a29f5bea02b5df9d9560ced638125126 (diff)
downloadmtc-f06a2c91b41e5e54ffbad7dd46bd700207fbdb84.zip
mtc-f06a2c91b41e5e54ffbad7dd46bd700207fbdb84.tar.gz
mtc-f06a2c91b41e5e54ffbad7dd46bd700207fbdb84.tar.bz2
mtc-f06a2c91b41e5e54ffbad7dd46bd700207fbdb84.tar.xz
Documentation de l'animation de translation.
-rwxr-xr-xdoc/exemple_translator.pl39
-rw-r--r--doc/manuel_utilisateur.txt63
2 files changed, 100 insertions, 2 deletions
diff --git a/doc/exemple_translator.pl b/doc/exemple_translator.pl
new file mode 100755
index 0000000..6e4e9b8
--- /dev/null
+++ b/doc/exemple_translator.pl
@@ -0,0 +1,39 @@
+#!/usr/bin/perl
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU GPL General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA,
+# or refer to http://www.gnu.org/copyleft/gpl.html
+#
+
+BEGIN {
+ unshift @INC, ".", "../src";
+}
+
+use MTools;
+use MTools::GUI::MRect;
+use MTools::Anim::MTranslator;
+
+new MTools (800, 600, "Exemple de animation translator");
+
+my $rect = new MTools::GUI::MRect (1, 300, 100, 300, 50, -filled => 1);
+
+my $anim = new MTools::Anim::MTranslator(targets => $rect,
+ loop => 1,
+ duration => 2,
+ to_x => 100,
+ to_y => 300);
+
+$anim->start();
+
+mrun;
+
diff --git a/doc/manuel_utilisateur.txt b/doc/manuel_utilisateur.txt
index 57ba3d6..419f4b4 100644
--- a/doc/manuel_utilisateur.txt
+++ b/doc/manuel_utilisateur.txt
@@ -499,6 +499,9 @@ MPath permet de réaliser une animation de déplacement suivant un chemin. Le
chemin est une suite de segments. L'animation peut porter sur un objet ou un
tableau d'objets.
+Remarque : si le chemin est composé seulement d'un segment, MTranslator.pm
+suffit.
+
La description du chemin est une liste de points (x, y). L'objet se déplace en
ligne droite d'un point à l'autre. La vitesse de déplacement est régulière tout
au long du trajet. Elle est déterminée par la durée de l'animation. Le premier
@@ -524,8 +527,8 @@ Les évènements émis sont :
Les évènements VALUE_CHANGED et ANIMATION_ABORD fournissent la valeur courante
de la position (x, y) et un vecteur qui donne la direction de déplacement de
-l'objet (ce vecteur n'est pas proportionnel à la vitesse). La position est dans
-le système de coordonnées définit par le path.
+l'objet (ce vecteur n'est pas proportionnel à la vitesse). La position est un
+point du chemin.
Les fonctions applicables à un objet MPath sont :
- start : démarre l'animation
@@ -617,6 +620,62 @@ $anim->start();
mrun;
______________
MTranslator.pm :
+MTranslator permet de realiser une animation de translation d'un ou plusieurs
+objets, c'est un déplacement suivant un segment.
+
+Remarque : dans le cas où le déplacement à effectuer ne peut pas être décrit par
+un seul segment, il suffit d'utiliser MPath.pm.
+
+La translation est décrite par un segment. Les coordonnées du segment n'ont
+aucun lien avec les coordonnées de l'objet, c'est-à-dire que l'objet ne va pas
+se déplacer pour aller à l'endroit du segment. Le segment est plutôt à
+considérer comme un vecteur déplacement.
+
+La fonction de création ne nécessite aucun argument. Elle permet de configurer
+toutes les propriétés comme mconfigure.
+
+Les valeurs modifiables par mconfigure sont :
+ - -visible : permet d'activer ou stopper l'animation
+ - from_x, from_y : coordonnées de l'origine du segment (défaut : 0)
+ - to_x, to_y : coordonnées de destination du segment (défaut : 0)
+ - duration : durée de l'animation (défaut : 1s)
+ - loop : indique le caractère répétitif de l'animation (défaut : faux)
+ - targets : objet ou tableau d'objets cible de cette animation. Ces
+ objets doivent disposer d'une fonction "translate".
+
+Dans le cas où on souhaite faire un déplacement, de (dx, dy), il suffit de
+positionner ces valeurs dans to_x et to_y puisque les valeurs par défaut de
+from_x et from_y sont 0.
+
+Les évènements émis sont :
+ - ANIMATION_END : Notifie la fin de l'annimation
+ - MOTION : Notifie un changement de position au cours de l'animation
+ - ANIMATION_ABORD : Notifie un arrêt prématuré de l'animation
+
+Les évènements MOTION et ANIMATION_ABORD fournissent la valeur courante de la
+position (x, y). La position est un point du segment.
+
+Les fonctions applicables à un objet MTranslator sont :
+ - start : démarre l'animation
+ - stop: arrête l'animation
+ - isRunning : détermine si l'animation est en cours
+
+*** Attention : dans le cas où une cible est de type MMover, le comportement est
+différent. Voir dans quelle mesure et pourquoi.
+
+Exemple d'utilisation :
+use MTools;
+use MTools::GUI::MRect;
+use MTools::Anim::MTranslator;
+new MTools (800, 600, "Exemple de animation translator");
+my $rect = new MTools::GUI::MRect (1, 300, 100, 300, 50, -filled => 1);
+my $anim = new MTools::Anim::MTranslator(targets => $rect,
+ loop => 1,
+ duration => 2,
+ to_x => 100,
+ to_y => 300);
+$anim->start();
+mrun;
2.6 Les comportements
---------------------