У меня возникают некоторые проблемы с Javascript и GreenSock с некоторыми анимационными играми и кнопкой. Я пытаюсь получить массив игральных карт в тесте на ...Javascript + GreenSock - твинов не работает правильно после включения/выключения нажмите кнопку
- Сдвиг вниз по наведению - сделано
- перевернуть карту, чтобы увидеть другую сторону на щелчок, затем один раз мышь влево карта лицо должно перевернуть обратно - сделать
- Реализовать на кнопку включения/выключения для переключения между показать все лица карты/показать все карты спины - сделали
Теперь здесь возникают проблемы, когда все они выполняются за один сеанс ...
Как только кнопка включения/выключения была нажата даже один раз, пользователь застревает в цикле, где вы можете использовать только вкл/выкл, чтобы повернуть карты.
Я думаю, что это происходит потому, что кнопка включения/выключения активна, так что только с помощью от или еще часть анимации, проблема, я просто не могу обернуть мою голову вокруг того, как я бы подходите к этому, чтобы решить проблему и включить нормальную функцию после вскрытия всех карт. Я подумал об использовании другого метода вместо того, чтобы по существу использовать true/false для управления, но я изо всех сил стараюсь придумать любые желаемые результаты.
Вторичная проблема заключается в том, что после того, как будут показаны все грани карты, я хотел бы, чтобы она игнорировала предыдущую анимацию флип-движения и удерживала лица до тех пор, пока не будет нажата карта или кнопка не перевернет их все, но это неважно по сравнению с первой проблемой.
Любая помощь будет принята с благодарностью, поскольку это меня озадачило со вчерашнего дня!
http://codepen.io/Nexus1234/pen/oIgDi
TweenLite.set(".cardWrapper", {perspective:800});
TweenLite.set(".card", {transformStyle:"preserve-3d"});
TweenLite.set(".back", {rotationY:-180});
TweenLite.set([".back", ".front"], {backfaceVisibility:"hidden"});
function onoff(){
currentvalue = document.getElementById('onoff').value;
if(currentvalue == "Off"){
document.getElementById("onoff").value="On",
$(".cardflip").click(
function() {
TweenLite.to($(this).find(".card"), 2.0, {scale:1, rotationY:20, ease:Power4.easeOut});
});
}else{
document.getElementById("onoff").value="Off",
$(".cardflip").click(
function() {
TweenLite.to($(this).find(".card"), 1.0, {scale:1.2, rotationY:180, ease:Strong.easeOut});
});
}
}
$(".cardWrapper").hover(
function() {
TweenLite.to($(this).find(".card"), 4.0, {rotationY:20, scale:1, ease:Power4.easeOut});
TweenLite.to($(this).find(".shine"), 0, {scale:1, rotationY:0, ease:Strong.easeOut
});
});
$(".cardWrapper").click(
function() {
TweenLite.to($(this).find(".card"), 1.0, {scale:1.2, rotationY:180, ease:Strong.easeOut
});
TweenLite.to($(this).find(".shine"), 0, {scale:0, rotationY:180, ease:Strong.easeOut
});
});
TweenMax.staggerTo($(".card"), 0.45, {rotationY:20}, 0.1);
TweenMax.staggerTo(".shine", 0.75, {x:0}, 0);
Вы хороший человек! Спасибо. Это было приостановлено, так как это было опубликовано несколько месяцев назад, поэтому я ценю помощь. С другой стороны, когда все карты отображаются лицевой стороной вверх после нажатия кнопки «показать все», есть ли лучший способ написать мой особый наведение и функцию щелчка, поэтому, когда вы зависали над отдельными карточками, он не отбрасывал их обратно? – Nexus1234