ویژگی تصویر

ساخت افکت متحرک حباب ها با CSS

  /  CSS   /  ساخت افکت متحرک حباب ها با CSS
بنر تبلیغاتی الف

افکت متحرک حباب‌ها (bubbles) یکی از جلوه‌های بصری پرطرفدار در طراحی وب است که می‌تواند به پس‌زمینه، هدر یا بخش‌های تعاملی حس زنده بودن و عمق ببخشد. با استفاده از صرفاً CSS و ساختار HTML ساده می‌توان افکتی سبک، قابل تنظیم و با کارایی مناسب ساخت. در این مقاله روش‌های مختلف، ترفندهای بهینه‌سازی و نمونه‌های عملی برای ساخت حباب‌های متحرک را بررسی می‌کنیم.

اصول پایه‌ای طراحی حباب با CSS

برای ساخت حباب‌ها به سه عنصر نیاز داریم: یک کانتینر برای نگه داشتن حباب‌ها، عناصر HTML برای خودِ حباب‌ها و انیمیشن‌های CSS برای حرکت آن‌ها. مفاهیم کلیدی که باید بدانید:

  • استفاده از transform (به‌جای موقعیت‌های گران) برای روانی انیمیشن
  • کلیدواژه‌های animation و keyframes برای تعریف مسیر حرکت، شفافیت و مقیاس
  • تنظیمات performance مثل will-change و پرهیز از shadowهای سنگین
  • پشتیبانی از prefers-reduced-motion برای کاربران نیازمند کاهش حرکت

مثال پایه

<div class="bubbles">
  <span class="bubble"></span>
  <span class="bubble"></span>
  <span class="bubble"></span>
  <!-- تعداد بیشتری bubble ... -->
</div>

.bubbles{
  position: relative;
  width: 100%;
  height: 400px;
  overflow: hidden;
  background: linear-gradient(#0e3, #036);
}
.bubble{
  position: absolute;
  bottom: -50px;
  width: 40px;
  height: 40px;
  background: rgba(255,255,255,0.15);
  border-radius: 50%;
  animation: rise 8s infinite ease-in;
  left: 20%;
}
@keyframes rise{
  0%   { transform: translateY(0) scale(0.9); opacity: 0.8; }
  50%  { transform: translateY(-200px) translateX(30px) scale(1.05); opacity: 0.9; }
  100% { transform: translateY(-500px) translateX(-10px) scale(0.8); opacity: 0; }
}

توضیح: این نمونه ساده یک کانتینر با چند عنصر span را نشان می‌دهد که با keyframes به بالا حرکت می‌کنند. transform برای جابجایی و scale استفاده شده است و opacity برای محو شدن در بالای صفحه. برای هر bubble می‌توانید left و animation-delay متفاوت تعیین کنید تا حرکت طبیعی‌تر شود.

تنوع و تصادفی‌سازی با :nth-child و CSS متغیرها

برای طبیعی‌تر شدن حباب‌ها از nth-child() و CSS variables استفاده می‌کنیم تا اندازه، تاخیر، سرعت و موقعیت هر حباب متفاوت باشد بدون تکرار دستی کد.

.bubble{
  --size: 40px;
  --left: 10%;
  --duration: 8s;
  --delay: 0s;

  position: absolute;
  bottom: -var(--size);
  left: var(--left);
  width: var(--size);
  height: var(--size);
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.9), rgba(255,255,255,0.15));
  border-radius: 50%;
  animation: rise var(--duration) linear infinite;
  animation-delay: var(--delay);
  will-change: transform, opacity;
}

/* نمونه‌ای از تنظیمات مختلف با nth-child */.bubble:nth-child(1){ --size: 20px; --left: 5%;  --duration: 10s; --delay: 0s; }
.bubble:nth-child(2){ --size: 50px; --left: 20%; --duration: 12s; --delay: 2s; }
.bubble:nth-child(3){ --size: 30px; --left: 35%; --duration: 9s;  --delay: 1s; }

@keyframes rise{
  0%   { transform: translateY(0) translateX(0) scale(1); opacity: 0.9; }
  30%  { transform: translateY(-120px) translateX(20px) scale(1.05); }
  70%  { transform: translateY(-320px) translateX(-15px) scale(0.95); }
  100% { transform: translateY(-600px) translateX(0) scale(0.9); opacity: 0; }
}

توضیح: با استفاده از متغیرهای CSS (–size, –left, –duration, –delay) می‌توان برای هر حباب رفتار اختصاصی تعیین کرد. nth-child کمک می‌کند مجموعه‌ای از الگوهای متفاوت بدون ایجاد کلاس‌های منفرد بسازیم. will-change به مرورگر می‌گوید که transform/opacity تغییر خواهند کرد تا رندر بهتر انجام شود.

حالت‌های پیشرفته و تعامل

برای ایجاد حس بیشتری از عمق می‌توان از فیلترها، سایه‌ها، و چند لایه حباب با سرعت‌های متفاوت استفاده کرد. همچنین می‌توان هنگام hover یا کلیک با تغییر scale یا سرعت انیمیشن تعامل ایجاد کرد.

.bubble:hover{
  transform: scale(1.15);
  filter: brightness(1.1);
  transition: transform 0.3s ease, filter 0.3s ease;
}

توضیح: این قطعه باعث می‌شود زمانی که کاربر ماوس را روی حباب می‌برد، حباب کمی بزرگ‌تر و روشن‌تر شود. این کار با transition انجام شده تا حس طبیعی‌تری داشته باشد. از تغییرات زیاد خودداری کنید تا حرکات ناگهانی باعث ناراحتی نشود.

دسترسی و بهینه‌سازی عملکرد

مهم است که کاربران با حساسیت به حرکت یا دستگاه‌های ضعیف هم تجربه خوبی داشته باشند:

  • استفاده از @media (prefers-reduced-motion: reduce) برای غیرفعال کردن یا کم‌کردن انیمیشن‌ها
  • پرهیز از box-shadow‌های سنگین و انیمیشن‌های مربوط به layout مثل top/left
  • استفاده از transform و opacity که توسط GPU معمولا بهتر اجرا می‌شوند
  • محدود کردن تعداد عناصر در DOM؛ برای تعداد بالا از canvas/WebGL استفاده کنید
@media (prefers-reduced-motion: reduce) {
  .bubble{
    animation: none;
    opacity: 0.8;
    transform: none;
  }
}

توضیح: این کد با استفاده از media query مربوط به prefers-reduced-motion، انیمیشن‌ها را غیرفعال می‌کند تا کاربران حساس به حرکت تجربه‌ای آرام‌تر داشته باشند.

نمونه جدول نکات کاربردی

موردتوصیه
انیمیشن‌هااز transform/opacity استفاده کنید — از top/left خودداری کنید
تعداد حباببرای موبایل کمتر، برای دسکتاپ می‌توانید بیشتر
بهینه‌سازیwill-change و prefers-reduced-motion را پیاده کنید
ایجاد عمقلایه‌بندی با سرعت‌ها و سایزهای متفاوت

موارد استفاده و ایده‌های عملی

  • پس‌زمینه هدر سایت‌های دریایی یا تفریحی
  • نوار لودینگ یا صفحه انتظار با حباب‌های شناور
  • اضافه کردن تاثیر بصری به بخش تماس با ما یا سرتیتر صفحات
  • استفاده در اسلایدرها یا صفحات محصول برای حس ملایم و پویا

جمع‌بندی و نکات پایانی

ساخت افکت متحرک حباب‌ها با CSS ساده و قدرتمند است. با استفاده از keyframes، CSS variables و انتخاب‌های درست برای transform و opacity می‌توانید جلوه‌ای زیبا و کم‌هزینه اجرا کنید. توجه به دسترسی، عملکرد و میزان سفارشی‌سازی باعث می‌شود این افکت در پروژه‌های واقعی قابل استفاده و منعطف باشد.

آیا این مطلب برای شما مفید بود ؟

خیر
بله
موضوعات شما در انجمن: