Tenho um xml fazendo referências a 5 imagens e um flash que carrega uma a uma em uma espécie de slideshow (galeria de imagens automática)
O problema que estou tendo é que quando vai carregar a próxima imagem, a anterior "some" ficando um fundo em branco até aparecer a imagem seguinte carregada.
Sei que posso colocar um loading para não ficar totalmente em branco porém quero que a imagem que já foi carregada continue no movieclip e que quando a próxima carregar ai sim essa imagem pode fazer um fade in.
Segue o codigo de Actionscript:
delay = 5000;
// -----------------------
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_local.xml");
p = 0;
s = 0;
this.onEnterFrame = function() {
filesize[s] = picture.getBytesTotal();
loaded[s] = picture.getBytesLoaded();
preloader._visible = true;
if (loaded[s] != filesize[s]) {
preloader.preload_bar._xscale = 100*loaded[s]/filesize[s];
} else {
preloader._visible = false;
if (picture._alpha<100) {
picture._alpha += 10;
s++;
}
}
};
function firstImage() {
if (loaded[s] == filesize[s]) {
picture._alpha = 0;
picture.loadMovie(image[0], 1);
slideshow();
}
}
function nextImage() {
if (p<(total-1)) {
p++;
if (loaded[s] == filesize[s]) {
picture._alpha = 0;
picture.loadMovie(image[p], 1);
slideshow();
}
}
}
function slideshow() {
myInterval = setInterval(pause_slideshow, delay);
function pause_slideshow() {
clearInterval(myInterval);
if (p == (total-1)) {
p = 0;
firstImage();
} else {
nextImage();
}
}
}
Alguma ideia?
OSB: picture é o nome do meu movieclip que contem as imagens
Pergunta
rogernem
Tenho um xml fazendo referências a 5 imagens e um flash que carrega uma a uma em uma espécie de slideshow (galeria de imagens automática)
O problema que estou tendo é que quando vai carregar a próxima imagem, a anterior "some" ficando um fundo em branco até aparecer a imagem seguinte carregada.
Sei que posso colocar um loading para não ficar totalmente em branco porém quero que a imagem que já foi carregada continue no movieclip e que quando a próxima carregar ai sim essa imagem pode fazer um fade in.
Segue o codigo de Actionscript:
delay = 5000; // ----------------------- 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_local.xml"); p = 0; s = 0; this.onEnterFrame = function() { filesize[s] = picture.getBytesTotal(); loaded[s] = picture.getBytesLoaded(); preloader._visible = true; if (loaded[s] != filesize[s]) { preloader.preload_bar._xscale = 100*loaded[s]/filesize[s]; } else { preloader._visible = false; if (picture._alpha<100) { picture._alpha += 10; s++; } } }; function firstImage() { if (loaded[s] == filesize[s]) { picture._alpha = 0; picture.loadMovie(image[0], 1); slideshow(); } } function nextImage() { if (p<(total-1)) { p++; if (loaded[s] == filesize[s]) { picture._alpha = 0; picture.loadMovie(image[p], 1); slideshow(); } } } function slideshow() { myInterval = setInterval(pause_slideshow, delay); function pause_slideshow() { clearInterval(myInterval); if (p == (total-1)) { p = 0; firstImage(); } else { nextImage(); } } }Alguma ideia?
OSB: picture é o nome do meu movieclip que contem as imagens
Link para o comentário
Compartilhar em outros sites
2 respostass a esta questão
Posts Recomendados
Participe da discussão
Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.