Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Canvas-confetti on mobile devices. #230

Open
KariReis opened this issue May 2, 2024 · 0 comments
Open

Canvas-confetti on mobile devices. #230

KariReis opened this issue May 2, 2024 · 0 comments

Comments

@KariReis
Copy link

KariReis commented May 2, 2024

Hello Kiril,

I'm using canvas-confetti on a website. It was incredible. However, I'm having difficulty getting it to work on tablet and mobile.

As I don't have much experience, I was wondering if you could help me.

My code is like this:

<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/confetti.browser.min.js"></script> <script> function myConfetti() { var end = Date.now() + (5 * 1000); var colors = ['#8f00ff', '#fbf9fc']; (function frame() { confetti({ particleCount: 2, angle: 60, spread: 40, origin: { x: 0 }, colors: colors }); confetti({ particleCount: 2, angle: 120, spread: 40, origin: { x: 1 }, colors: colors }); if (Date.now() < end) { requestAnimationFrame(frame); } }()); } // Function to check if the element is leaving the screen function isElementOutViewport(el) { var rect = el.getBoundingClientRect(); return ( rect.bottom < 0 || rect.right < 0 || rect.left > window.innerWidth || rect.top > window.innerHeight ); } // Function to check section visibility function isSectionVisible(section) { var rect = section.getBoundingClientRect(); return ( rect.top < window.innerHeight && rect.bottom > 0 ); } // Function to observe changes in element and section visibility function observeVisibility() { var confettiElement = document.querySelector('.how-layout_card.is-confetti'); var section = document.querySelector('.section_how-layout'); var observer = new IntersectionObserver(function(entries) { entries.forEach(function(entry) { if (entry.isIntersecting) { myConfetti(); } }); }, { threshold: 0 }); observer.observe(confettiElement); // Observe section visibility var sectionObserver = new IntersectionObserver(function(entries) { entries.forEach(function(entry) { if (!entry.isIntersecting) { // Stop animation when section is no longer visible } }); }, { threshold: 0 }); sectionObserver.observe(section); } // Function call to observe visibility observeVisibility(); </script>

I'm using this animation in Weblfow.

Thank you very much!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant