基于CSS3的animation属性实现微信拍一拍动画效果


Posted in HTML / CSS onJune 22, 2020

看到最近流行的微信拍一拍功能,复习下CSS3的animation,所以写下这个盒子晃动的动画,把qq的窗口抖动也加上吧

@-webkit-keyframes shake {
    0% {
        -webkit-transform: translate(2px, 2px);
    }

    25% {
        -webkit-transform: translate(-2px, -2px);
    }

    50% {
        -webkit-transform: translate(0px, 0px);
    }

    75% {
        -webkit-transform: translate(2px, -2px);
    }

    100% {
        -webkit-transform: translate(-2px, 2px);
    }
}

@keyframes shake {
    0% {
        transform: translate(2px, 2px);
    }

    25% {
        transform: translate(-2px, -2px);
    }

    50% {
        transform: translate(0px, 0px);
    }

    75% {
        transform: translate(2px, -2px);
    }

    100% {
        transform: translate(-2px, 2px);
    }
}

.shake {
    position: relative;
    top: 30px;
    left: 100px;
    height: 200px;
    width: 200px;
    color: #ff0000;
    background: #000;
}

.shake:hover {
    -webkit-animation: shake 0.2s infinite;
    animation: shake 0.2s infinite;
}
 /*活动摇摆动画*/
 @-webkit-keyframes swing {
  10% {
    transform: rotate(15deg);
  }
  20% {
    transform: rotate(-10deg);
  }
  30% {
    transform: rotate(5deg);
  }
  40% {
    transform: rotate(-5deg);
  }
  50%,100% {
    transform: rotate(0deg);
  }
}
@-moz-keyframes swing {
  10% {
    transform: rotate(15deg);
  }
  20% {
    transform: rotate(-10deg);
  }
  30% {
    transform: rotate(5deg);
  }
  40% {
    transform: rotate(-5deg);
  }
  50%,100% {
    transform: rotate(0deg);
  }
}
@-o-keyframes swing {
  10% {
    transform: rotate(15deg);
  }
  20% {
    transform: rotate(-10deg);
  }
  30% {
    transform: rotate(5deg);
  }
  40% {
    transform: rotate(-5deg);
  }
  50%,100% {
    transform: rotate(0deg);
  }
}
@keyframes swing {
  10% {
    transform: rotate(12deg);
  }
  20% {
    transform: rotate(-11.5deg);
  }
  30% {
    transform: rotate(1deg);
  }
  40% {
    transform: rotate(-1deg);
  }
  50%,100% {
    transform: rotate(0.5deg);
  }
}
.stagger {
  background-color: #ff0000;
  width: 60px;
  height: 60px;
}
.stagger1{
  animation: swing .5s .15s linear 1;
  /* animation-play-state: paused; */
}
 <!-- qq窗口抖动 -->
  <div class="shake">qq窗口抖动</div>
  <!-- 微信拍拍头像晃动 -->
  <div class="stagger">微信拍拍头像晃动</div>
document.querySelector('.stagger').addEventListener('click', function() {
      document.querySelector('.stagger').classList.add('stagger1')
      console.log('papa nudged baby')
})
	/*每次点击实现动画,注意监听动画结束,移除动画类,后再添加动画类
    document.querySelector('.stagger').addEventListener('animationend', function() {
      document.querySelector('.stagger').classList.remove('stagger1')
    })

到此这篇关于基于CSS3的animation属性实现微信拍一拍动画效果的文章就介绍到这了,更多相关css3 微信拍一拍功能内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
CSS3教程(6):创建网站多列
Apr 02 HTML / CSS
CSS3 开发工具收集
Apr 17 HTML / CSS
css3实现图片遮罩效果鼠标hover以后出现文字
Nov 05 HTML / CSS
利用HTML5+CSS3实现3D转换效果实例详解
May 02 HTML / CSS
CSS3 函数技巧 用css 实现js实现的事情(clac Counters Tooltip)
Aug 15 HTML / CSS
CSS3中animation实现流光按钮效果
Dec 21 HTML / CSS
使用HTML5的File实现base64和图片的互转
Aug 01 HTML / CSS
一些常用的HTML5模式(pattern) 总结
Jul 14 HTML / CSS
canvas拼图功能实现代码示例
Nov 21 HTML / CSS
HTML5实现移动端弹幕动画效果
Aug 01 HTML / CSS
html5移动端自适应布局的实现
Apr 15 HTML / CSS
利用html+css实现菜单栏缓慢下拉效果的示例代码
Mar 30 HTML / CSS
CSS3为背景图设置遮罩并解决遮罩样式继承问题
Jun 22 #HTML / CSS
CSS3 box-shadow属性实例详解
Jun 19 #HTML / CSS
CSS3新增布局之: flex详解
Jun 18 #HTML / CSS
如何使用css3实现一个类在线直播的队列动画的示例代码
Jun 17 #HTML / CSS
CSS3+JavaScript实现炫酷呼吸效果的示例代码
Jun 15 #HTML / CSS
CSS3中引入多种自定义字体font-face
Jun 12 #HTML / CSS
详解CSS3实现响应式手风琴效果
Jun 10 #HTML / CSS
You might like
PHP中防止直接访问或查看或下载config.php文件的方法
2012/07/07 PHP
无需重新编译php加入ftp扩展的解决方法
2013/02/07 PHP
PHP header()函数使用详细(301、404等错误设置)
2013/04/17 PHP
基于php无限分类的深入理解
2013/06/02 PHP
兼容PHP和Java的des加密解密代码分享
2014/06/26 PHP
Bootstrap+PHP实现多图上传功能实例详解
2018/04/08 PHP
javascript dom代码应用 简单的相册[firefox only]
2010/06/12 Javascript
jQuery 遍历-nextUntil()方法以及prevUntil()方法的使用介绍
2013/04/26 Javascript
ie下$.getJSON出现问题的解决方法
2014/02/12 Javascript
jQuery is()函数用法3例
2014/05/06 Javascript
node.js中的fs.utimesSync方法使用说明
2014/12/15 Javascript
javascript中返回顶部按钮的实现
2015/05/05 Javascript
jquery预加载图片的方法
2015/05/27 Javascript
javascript实现动态标签云
2015/10/16 Javascript
jQuery实现简单的DIV拖动效果
2016/02/19 Javascript
[05:28]刀塔密之一:团结则存
2014/07/03 DOTA
pyside写ui界面入门示例
2014/01/22 Python
python统计cpu利用率的方法
2015/06/02 Python
python简单获取数组元素个数的方法
2015/07/13 Python
Python 使用with上下文实现计时功能
2018/03/09 Python
python 删除列表里所有空格项的方法总结
2018/04/18 Python
Django2.1.3 中间件使用详解
2018/11/26 Python
Python实现图片识别加翻译功能
2019/12/26 Python
CSS3不透明度实例讲解
2016/04/26 HTML / CSS
HTML5 新事件 小结
2009/07/16 HTML / CSS
HTML5语音识别标签写法附图
2013/11/18 HTML / CSS
大都会艺术博物馆商店:The Met Store
2018/06/22 全球购物
Ariat官网:美国马靴和服装品牌
2019/12/16 全球购物
教师网络培训感言
2014/03/09 职场文书
文明寝室申报材料
2014/05/12 职场文书
社保转移委托书范本
2014/10/08 职场文书
2014年行政后勤工作总结
2014/12/06 职场文书
2015年初一班主任工作总结
2015/05/13 职场文书
2016年元旦致辞
2015/08/01 职场文书
vue-cropper组件实现图片切割上传
2021/05/27 Vue.js
springboot用户数据修改的详细实现
2022/04/06 Java/Android