aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xdoc/exemple_switch.pl58
-rw-r--r--doc/manuel_utilisateur.txt32
2 files changed, 90 insertions, 0 deletions
diff --git a/doc/exemple_switch.pl b/doc/exemple_switch.pl
new file mode 100755
index 0000000..bbc9b20
--- /dev/null
+++ b/doc/exemple_switch.pl
@@ -0,0 +1,58 @@
+#!/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::MSwitch;
+use MTools::MTimer;
+use MTools::Anim::MPath;
+
+new MTools (800, 600, "Exemple de switch");
+
+my $mauve = minstance("basique.svg#mauve", 1);
+rotate($mauve, 45);
+
+my $anim = new MTools::Anim::MPath(targets => $mauve,
+ path => [[0, 0],
+ [100, -300],
+ [200, 0],
+ [0, 0]]);
+
+# Un des états du switch est utilisé pour activer l'animation.
+# De la même manière, on peut activer un comportement tel que l'inertie,
+# anti-recouvrement, sélectionnable...
+my $switch = new MTools::MSwitch(1,
+ vide => [],
+ partiel => $mauve,
+ anim => ["basique.svg#layer1", $mauve, $anim],
+ complet => ["basique.svg#layer1", $mauve]);
+$switch->setState(partiel);
+
+my @states = qw(vide partiel anim complet);
+my $timer = new MTools::MTimer(1000, 1, \&switch);
+$timer->start();
+
+mrun;
+
+sub switch {
+ my $new_state = pop @states;
+ $switch->setState($new_state);
+ unshift @states, $new_state;
+}
diff --git a/doc/manuel_utilisateur.txt b/doc/manuel_utilisateur.txt
index ae4a163..65fb16c 100644
--- a/doc/manuel_utilisateur.txt
+++ b/doc/manuel_utilisateur.txt
@@ -730,6 +730,38 @@ Les fonctions applicables à un objet MOpacity sont :
- setState : $switch->setState('etat') équivalent à
$swicth->mconfigure(state=>'etat')
+Exemple d'utilisation :
+use MTools;
+use MTools::MSwitch;
+use MTools::MTimer;
+use MTools::Anim::MPath;
+new MTools (800, 600, "Exemple de switch");
+my $mauve = minstance("basique.svg#mauve", 1);
+rotate($mauve, 45);
+my $anim = new MTools::Anim::MPath(targets => $mauve,
+ path => [[0, 0],
+ [100, -300],
+ [200, 0],
+ [0, 0]]);
+# Un des états du switch est utilisé pour activer l'animation.
+# De la même manière, on peut activer un comportement tel que l'inertie,
+# anti-recouvrement, sélectionnable...
+my $switch = new MTools::MSwitch(1,
+ vide => [],
+ partiel => $mauve,
+ anim => ["basique.svg#layer1", $mauve, $anim],
+ complet => ["basique.svg#layer1", $mauve]);
+$switch->setState(partiel);
+my @states = qw(vide partiel anim complet);
+my $timer = new MTools::MTimer(1000, 1, \&switch);
+$timer->start();
+mrun;
+
+sub switch {
+ my $new_state = pop @states;
+ $switch->setState($new_state);
+ unshift @states, $new_state;
+}
_________
MTimer.pm :
Le composant MTimer permet de déclencher des actions dans un certain temps, de