REDIMENSIONNER ET TOURNER UN CLIP A L'AIDE DES FLECHES

Signaler
Messages postés
6146
Date d'inscription
dimanche 21 décembre 2003
Statut
Modérateur
Dernière intervention
4 septembre 2013
-
Messages postés
21
Date d'inscription
lundi 24 septembre 2007
Statut
Membre
Dernière intervention
30 janvier 2010
-
Cette discussion concerne un article du site. Pour la consulter dans son contexte d'origine, cliquez sur le lien ci-dessous.

https://codes-sources.commentcamarche.net/source/46053-redimensionner-et-tourner-un-clip-a-l-aide-des-fleches

Messages postés
21
Date d'inscription
lundi 24 septembre 2007
Statut
Membre
Dernière intervention
30 janvier 2010

bah alors la j'avoue ne pas avoir le niveau m'autorisant a juger d'esthetique en ce qui concerne la programmation.
Ton code est simple, complet et efficace:adopté. La variable de stockage est vraiment une bonne idee dont je prends note. Ca devrait pouvoir me simplifier pas mal de choses.
Merci Slagt
Messages postés
232
Date d'inscription
mercredi 2 avril 2003
Statut
Membre
Dernière intervention
29 mars 2011

J'aurais pas fait exactement comme ça, mais ton truc marche bien. Quoi que je trouve ça plutot moche de déclarer un keyListener dans un mouseListener, mais bon, les goûts et les couleurs...

Dans le code qui suit, il faut placer sur la scène un clip "monMc".
Ensuite, tu peux rajouter autant de clip que tu veux, ça marchera, du moment que tu leur attribue le même onPress et le même onRelease, le dernier clip sur lequel tu as cliqué étant stocké dans la variable CLIP.

==================
var CLIP:MovieClip;
monMc.onPress = function ()
{
CLIP = this;
startDrag (CLIP, false);
}

monMc.onRelease = function ()
{
stopDrag();
}

var EC:Object = new Object();
EC.onKeyDown = function ()
{
if (!CLIP)
return;

if (Key.isDown(Key.LEFT))
{
CLIP._rotation -= 5;
}
else if (Key.isDown(Key.RIGHT))
{
CLIP._rotation += 5;
}

if (Key.isDown(Key.UP))
{
CLIP._xscale += 10;
CLIP._yscale = CLIP._xscale;
}
else if (Key.isDown(Key.DOWN))
{
CLIP._xscale -= 10; CLIP._yscale CLIP._xscale Math.max(0, CLIP._xscale);
}
}
Key.addListener (EC);
==================

J'ai rajouté le code empêchant d'avoir un _xscale/_yscale négatif.
Messages postés
21
Date d'inscription
lundi 24 septembre 2007
Statut
Membre
Dernière intervention
30 janvier 2010

c'est nickel Slagt
voici le code pour le gars ou la gazesse qui comme moi aurait mal lu la notice, on peut y rajouter une condition pour eviter la symetrie lorsque num devient negatif :
plasrou_mc.onPress = function() {
this.startDrag(false);
};
plasrou_mc.onRelease = function() {
this.stopDrag();
};
var num:Number = 100

var mouseListener:Object = new Object();
mouseListener.onMouseUp = function():Void {
if (plasrou_mc.hitTest(_xmouse, _ymouse)) {
var keyListener:Object = new Object();
keyListener.onKeyDown = function() {

if (Key.isDown(Key.LEFT)) {
plasrou_mc._rotation -= 5;
} else if (Key.isDown(Key.RIGHT)) {
plasrou_mc._rotation += 5;
} else if (Key.isDown(Key.UP)) {
num += 10
plasrou_mc._xscale = num;
plasrou_mc._yscale = num;
trace(plasrou_mc._width);
trace(plasrou_mc._height);
} else if (Key.isDown(Key.DOWN)) {
num -= 10
plasrou_mc._xscale = num;
plasrou_mc._yscale = num;
}
};
}
Key.addListener(keyListener);
};
Mouse.addListener(mouseListener);
Messages postés
21
Date d'inscription
lundi 24 septembre 2007
Statut
Membre
Dernière intervention
30 janvier 2010

Merci Slagt.
Je vais essayer avec _xscale et _yscale et si ca marche, tant mieux. Apparament ca devrait le faire vu que ces instruction sont en pourcentage.
C'est d'ailleurs un peu pour cette raison que j'avais publie cette source, ca me semblait un peu trop b... et j'avais aucun retour sur le forum. En attendant, j'ai appris quelques trucs sur l'utilisation de matrix.
Bref mieux vaut bien relire la notice et trouver la bonne instruction avant de se lancer.
Afficher les 13 commentaires