fotogallery dinamico...

Di: ActionScrap79 | 26/09/2020 18:04:13
Salve a tutti e complimenti per il sito!
Vorrei chiedervi se possibile aiuto riguardo un problema che mi affligge: il mio obiettivo è creare un gallery fotografico dinamico in xml. ho seguito un tutorial e il filmato risultante è strutturato così: sullo stage è presente un solo mc 1x1 pixel che carica le immagini dal file xml esterno e sulla timeline al primo frame c'è il codice scritto in fondo a questo post.
Il punto è questo: vorrei inserire immagini di differenti dimensioni all'interno di una maschera rettangolare di dimensione stabilita, ottenendo un gallery di immagini continuo; le bitmap dovrebbero essere caricate dinamicamente tramite l'xml. quello che voglio ottenere è poter ridimensionare in automatico le bitmap in modo da farle entrare comunque, anche se solo per una dimensione delle 2 (larghezza o altezza) all'interno di questa maschera.
Non è necessario che la foto si veda interamente, ma solo una parte, animata poi con un motion tween (a proposito: sapreste per caso come si può comandare questo motion tween da AS, e magari inserirlo in questo stesso codice?)vi allego il codice del tutorial che ho seguito per creare (scaricato dal sito http://www.kirupa.com/developer/mx20...ogallery.htm):
delay = 3000;
//-----------------------
function loadXML(loaded) {
if (loaded) {
xmlNode = this.firstChild;
image = [];
description = [];
total = xmlNode.childNodes.length;
for (i=0; i<total; i++) {
image[i] = xmlNode.childNodes[i].childNodes[0].firstChild.nodeValue;
description[i] = xmlNode.childNodes[i].childNodes[1].firstChild.nodeValue;
}
firstImage();
} else {
content = "file not loaded!";
}
}
xmlData = new XML();
xmlData.ignoreWhite = true;
xmlData.onLoad = loadXML;
xmlData.load("images.xm");
/////////////////////////////////////
listen = new Object();
p = 0;
this.onEnterFrame = function() {
filesize = picture.getBytesTotal();
loaded = picture.getBytesLoaded();
preloader._visible = true;
if (loaded != filesize) {
preloader.preload_bar._xscale = 100*loaded/filesize;
} else {
preloader._visible = false;
if (picture._alpha<100) {
picture._alpha += 10;
}
}
};
function nextImage() {
if (p<(total-1)) {
p++;
if (loaded == filesize) {
picture._alpha = 0;
picture.loadMovie(image[p], 1);
desc_txt.text = description[p];
picture_num();
slideshow();
}
}
}
function prevImage() {
if (p>0) {
p--;
picture._alpha = 0;
picture.loadMovie(image[p], 1);
desc_txt.text = description[p];
picture_num();
}
}
function firstImage() {
if (loaded == filesize) {
picture._alpha = 0;
picture.loadMovie(image[0], 1);
desc_txt.text = description[0];
picture_num();
slideshow();
}
}
function picture_num() {
current_pos = p+1;
pos_txt.text = current_pos+" / "+total;
}
function slideshow() {
myInterval = setInterval(pause_slideshow, delay);
function pause_slideshow() {
clearInterval(myInterval);
if (p == (total-1)) {
p = 0;
firstImage();
} else {
nextImage();
}
}
}
Grazie in anticipo per ogni suggerimento!

Risposte


Nessuna risposta trovata!