表单/表格

超炫喷洒墨水效果打开模态窗口特效

阿里云


这是一款使用 CSS3 和 jQuery 来制作的炫酷喷洒墨水式打开模态窗口特效。该特效在点击按钮时通过一张 PNG 墨水喷洒的雪碧图和 steps()函数来制作墨水散开的效果,整个效果就像在屏幕上撒上了墨水,使屏幕改变了一个颜色。通过一张制作好的雪碧图,以及 CSS 的 steps()函数,我们可以制作出各种平滑过渡的动画效果。一些效果的图片可以直接从某些视频 video 中提取,使用的工具是 After Effects。你可以将需要的视频的帧转换为连续的 PNG 图片,然后将这些图片拼接为雪碧图。

HTML 结构

该效果的 HTML 结构分为 3 个主要部分:main.cd-main-content 是页面的主体部分,div.cd-modal 是模态窗口,div.cd-transition-layer 是一个动画过渡层。

也想出现在这里?联系我们
创客主机
  1. <main class="cd-main-content">
  2.   <div class="center">
  3.     <h1>Ink Transition Effect</h1>
  4.     <a href="#0" class="cd-btn cd-modal-trigger">Start Effect</a>
  5.   </div>
  6. </main> <!-- .cd-main-content -->
  7.  
  8. <div class="cd-modal">
  9.   <div class="modal-content">
  10.     <h1>My Modal Content</h1>
  11.  
  12.     <p>
  13.       Lorem ipsum dolor sit amet, consectetur adipisicing elit. 
  14.       Ad modi repellendus, optio eveniet eligendi molestiae? 
  15.       Fugiat, temporibus! 
  16.     </p>
  17.   </div> <!-- .modal-content -->
  18.  
  19.   <a href="#0" class="modal-close">Close</a>
  20. </div> <!-- .cd-modal -->
  21.  
  22. <div class="cd-transition-layer"> 
  23.   <div class="bg-layer"></div>
  24. </div> <!-- .cd-transition-layer -->

CSS 样式

模态窗口.cd-modal 开始时通过 visibility: hidden 来隐藏,高度和宽度都设置为 100%,并且使用固定定位方式。当用户点击了触发按钮 a.cd-modal-trigger,模态窗口通过.visible 属性设置为可见。

  1. .cd-modal {
  2.   position: fixed;
  3.   top: 0;
  4.   left: 0;
  5.   z-index: 3;
  6.   height: 100%;
  7.   width: 100%;
  8.   opacity: 0;
  9.   visibility: hidden;
  10. }
  11. .cd-modal.visible {
  12.   opacity: 1;
  13.   visibility: visible;
  14. }

div.cd-transition-layer 元素用于创建喷洒墨水效果的动画过渡层。它初始时被设置为:visibility: hidden,高度和宽度都设置为 100%,并且使用固定定位方式。

  1. .cd-transition-layer {
  2.   position: fixed;
  3.   top: 0;
  4.   left: 0;
  5.   z-index: 2;
  6.   height: 100%;
  7.   width: 100%;
  8.   opacity: 0;
  9.   visibility: hidden;
  10.   overflow: hidden;
  11. }

它的子元素 div.bg-layer 使用雪碧图作为背景图片,并设置 background-size: 100%,100%高度和 2500%的宽度(因为在这个 DEMO 中,ink.png 有 25 帧)。开始时,ink.png 的第一帧被居中放置在 div.cd-transition-layer 中。

  1. .cd-transition-layer .bg-layer {
  2.   position: absolute;
  3.   left: 50%;
  4.   top: 50%;
  5.   transform: translateY(-50%) translateX(-2%);
  6.   height: 100%;
  7.   /* our sprite is composed of 25 frames */
  8.   width: 2500%;
  9.   background: url(../img/ink.png) no-repeat 0 0;
  10.   background-size: 100% 100%;
  11. }

上面的居中方式需要注意的是,通常我们使用绝对定位居中一个元素都是使用如下的代码:

  1. position: absolute;
  2. left: 50%;
  3. top: 50%;
  4. transform: translateY(-50%) translateX(-50%);

在这个 DEMO 中,我们需要居中 ink.png 雪碧图的第一帧,由于 div.bg-layer 的宽度是它的父元素宽度的 25 倍,所以要使用 translateX(-(50/25)%)来进行居中。为了创建喷洒墨水的动画,我们需要修改 div.bg-layer 的值。可以定义如下的@keyframes 帧动画。

  1. @keyframes cd-sequence {
  2.   0% {
  3.     transform: translateY(-50%) translateX(-2%);
  4.   }
  5.   100% {
  6.     transform: translateY(-50%) translateX(-98%);
  7.   }
  8. }

通过上面的帧动画,在动画结束时,ink.png 雪碧图的最后一帧将在 div.cd-transition-layer 中居中。对于上面 100%时的 translateX 的值可以这样理解:由于 DEMO 中有 25 个帧,为了显示最后一个帧你需要移动.bg-layer 层-100% * (25 – 1) = -96%。接着需要使最后一帧居中显示,就需要额外的调整-2%,所以最后 translateX()的值为-98%。当用户点击了触发按钮 a.cd-modal-trigger 时,.cd-transition-layer 会被添加.visible class 类使其可见,同时通过.opening class 类来触发喷洒墨水动画。

  1. .cd-transition-layer.visible {
  2.   opacity: 1;
  3.   visibility: visible;
  4. }
  5. .cd-transition-layer.opening .bg-layer {
  6.   animation: cd-sprite 0.8s steps(24);
  7.   animation-fill-mode: forwards;
  8. }

JavaScript

DEMO 中在用户点击触发按钮和关闭模态窗口按钮时通过 jQuery 来添加和移除相应的 class 类。另外,还使用 jQuery 来调整 png 图片的比例使它们不至于变形。在样式文件中,.bg-layer 的每一帧的宽度和高度都被设置为和视口一样大小。但是用户显示器的视口可能会是不同的比例,这会导致某些帧不能完全显示。setLayerDimensions()函数正是用于修正这些问题的。

  1. var frameProportion = 1.78, //png frame aspect ratio
  2.   frames = 25, //number of png frames
  3.   resize = false;
  4.  
  5. //set transitionBackground dimentions
  6. setLayerDimensions();
  7. $(window).on('resize', function(){
  8.   if( !resize ) {
  9.     resize = true;
  10.     (!window.requestAnimationFrame) 
  11.                         ? setTimeout(setLayerDimensions, 300) 
  12.                         : window.requestAnimationFrame(setLayerDimensions);
  13.   }
  14. });
  15.  
  16. function setLayerDimensions() {
  17.   var windowWidth = $(window).width(),
  18.     windowHeight = $(window).height(),
  19.     layerHeight, layerWidth;
  20.  
  21.   if( windowWidth/windowHeight > frameProportion ) {
  22.     layerWidth = windowWidth;
  23.     layerHeight = layerWidth/frameProportion;
  24.   } else {
  25.     layerHeight = windowHeight;
  26.     layerWidth = layerHeight*frameProportion;
  27.   }
  28.  
  29.   transitionBackground.css({
  30.     'width': layerWidth*frames+'px',
  31.     'height': layerHeight+'px',
  32.   });
  33.  
  34.   resize = false;
  35. }

超炫喷洒墨水效果打开模态窗口特效

已有 356 人购买
  • m43v
查看演示升级 VIP立刻购买

演示地址 下载地址
收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!