Quando si fa clic, voglio un pulsante per produrre tre opzioni figlio, che poi quando toccato di nuovo dovrebbero rientrare e poi scomparire quando si trova dietro il pulsante genitore. Spero che questo sia chiaro dal codice (si noti che questa è un'applicazione nativizzata, quindi le scelte di css leggermente strane).Le animazioni JavaScript non sono in esecuzione in ordine?
exports.fabTap = function (args) {
var google = page.getViewById("google");
var facebook = page.getViewById("facebook");
var amazon = page.getViewById("amazon");
if (clicked == false) {
google.style.visibility = "visible";
facebook.style.visibility = "visible";
amazon.style.visibility = "visible";
google.animate({
translate: { x: -55, y: -66 },
duration: 500,
curve: enums.AnimationCurve.cubicBezier(0.1, 0.1, 0.1, 1)
});
facebook.animate({
translate: { x: 0, y: -75 },
duration: 500,
curve: enums.AnimationCurve.cubicBezier(0.1, 0.1, 0.1, 1)
});
amazon.animate({
translate: { x: 55, y: -66 },
duration: 500,
curve: enums.AnimationCurve.cubicBezier(0.1, 0.1, 0.1, 1)
});
} else {
google.animate({
translate: { x: 0, y: 0 },
duration: 500,
curve: enums.AnimationCurve.cubicBezier(0.1, 0.1, 0.1, 1)
});
facebook.animate({
translate: { x: 0, y: 0 },
duration: 500,
curve: enums.AnimationCurve.cubicBezier(0.1, 0.1, 0.1, 1)
});
amazon.animate({
translate: { x: 0, y: 0 },
duration: 500,
curve: enums.AnimationCurve.cubicBezier(0.1, 0.1, 0.1, 1)
});
google.style.visibility = "collapse";
facebook.style.visibility = "collapse";
amazon.style.visibility = "collapse";
}
clicked = !clicked;
}
Tuttavia, come si può vedere dalla gif, durante il viaggio di ritorno, i pulsanti scompaiono prima del ritorno. Cosa posso fare per garantire che questo si anima in sequenza?
Perché è necessario impostare 'google.style.visibility' (non vedo che lo imposti nello stesso modo quando li stai facendo apparire)? Hai provato a rimuovere queste linee? –