实现毛玻璃效果
时间:2022-07-24
本文章向大家介绍实现毛玻璃效果,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
实现毛玻璃效果
使用CSS
实现毛玻璃效果,使用CSS
滤镜filter
中的blur
属性实现。
实现
首先定义一个填充满整个屏幕的背景。
<style type="text/css">
body{
width: 100vw;
height: 100vh;
margin: 0;
background-image: url("http://www.sdust.edu.cn/__local/B/F3/E4/693AB931C9FFB84646970D53BFE_C506394A_4282CA.jpg");
background-size: cover;
background-repeat: no-repeat;
background-position: center;
}
</style>
然后定义一个指定长宽的div
去实现模糊效果,因为直接在元素上使用blur
会将元素以及子元素全部模糊,显然不符合要求,于是使用一个伪元素去实现模糊效果。首先在元素CSS
属性设置position: absolute;
是为了伪元素去适应长宽使用,使用relative
也是可行的,但是会影响下文会提到的拖拽的定位,在伪元素中设置position: absolute;top: 0;left: 0;right: 0; bottom: 0;
来继承元素的尺寸,在伪元素中设置背景,在背景上实现模糊效果就可以避免子元素一并模糊的问题。
<style type="text/css">
.blur {
position: absolute;
overflow: hidden;
z-index: 1;
width: 500px;
height: 300px;
cursor: move;
}
.blur::after {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: -1;
margin: -30px;
background-image: url("http://www.sdust.edu.cn/__local/B/F3/E4/693AB931C9FFB84646970D53BFE_C506394A_4282CA.jpg");
background-position: center;
background-size: cover;
background-attachment: fixed;
filter: blur(10px);
}
</style>
为了更好的展示效果,实现了一个简单的拖拽功能。
<script type="text/javascript">
var element = document.querySelector(".blur");
element.onmousedown = function(event) {
var event = event || window.event;
var edgeX = event.clientX - element.offsetLeft;
var edgeY = event.clientY - element.offsetTop;
document.onmousemove = function(event) {
var event = event || window.event;
var relativeX = event.clientX - edgeX;
var relativeY = event.clientY - edgeY;
element.style.left = relativeX + "px";
element.style.top = relativeY + "px";
return false;
};
document.onmouseup = function() {
document.onmousemove = null;
document.onmouseup = null;
};
return false;
}
</script>
代码示例
<!DOCTYPE html>
<html>
<head>
<title>毛玻璃效果</title>
<style type="text/css">
body {
width: 100vw;
height: 100vh;
margin: 0;
overflow: hidden;
background-image: url("http://www.sdust.edu.cn/__local/B/F3/E4/693AB931C9FFB84646970D53BFE_C506394A_4282CA.jpg");
background-size: cover;
background-repeat: no-repeat;
background-position: center;
}
.container {
width: 100vw;
height: 100vh;
}
.x-y-center {
display: flex;
align-items: center;
justify-content: center;
}
.blur {
position: absolute;
overflow: hidden;
z-index: 1;
width: 500px;
height: 300px;
cursor: move;
}
.blur::after {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: -1;
margin: -30px;
background-image: url("http://www.sdust.edu.cn/__local/B/F3/E4/693AB931C9FFB84646970D53BFE_C506394A_4282CA.jpg");
background-position: center;
background-size: cover;
background-attachment: fixed;
filter: blur(10px);
}
</style>
</head>
<body>
<div class="container x-y-center">
<div class="blur x-y-center">
<div>Gaussian Blur</div>
</div>
</div>
</body>
<script type="text/javascript">
var element = document.querySelector(".blur");
element.onmousedown = function(event) {
var event = event || window.event;
var edgeX = event.clientX - element.offsetLeft;
var edgeY = event.clientY - element.offsetTop;
document.onmousemove = function(event) {
var event = event || window.event;
var relativeX = event.clientX - edgeX;
var relativeY = event.clientY - edgeY;
element.style.left = relativeX + "px";
element.style.top = relativeY + "px";
return false;
};
document.onmouseup = function() {
document.onmousemove = null;
document.onmouseup = null;
};
return false;
}
</script>
</html>
每日一题
https://github.com/WindrunnerMax/EveryDay
参考
https://www.jb51.net/article/73157.htm
https://www.cnblogs.com/ivan5277/p/10007273.html
https://blog.csdn.net/u010852544/article/details/43967749
- 仿网易新闻页面效果
- VS.Net 2005 Design-Time Integration
- XML Serializable Generic Dictionary
- MATLAB简易验证码识别程序介绍
- android之listview缓存图片(缓存优化)
- 使用ASP.NET实现Model View Presenter(MVP)
- android性能优化1
- 百度地图之收索视野内的建筑物
- Line Counter - Writing a Visual Studio 2005 Add-In
- 百度地图之标注聚会
- How to Add an API to your Web Service
- 「微信小程序」剖析(四):原生的实时DOM转Virtual DOM
- 让你的「微信小程序」运行在Chrome浏览器上,让我们使用WebStorm
- android上拉下拉加载更多数据
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- android自定义环形统计图动画
- 在Android环境下WebView中拦截所有请求并替换URL示例详解
- Android自定义控件横向柱状统计图
- Android处理视图圆角和色彩的工具类
- Flutter之Timer实现短信验证码获取60s倒计时功能的代码
- Android仿优酷视频的悬浮窗播放效果
- Android 本地广播和强制下线功能的实现代码
- Android实现强制下线功能的示例代码
- 如何用HMS Nearby Service给自己的App添加近距离数据传输功能
- Android自定义控件之圆形进度条动画
- Android 使用 Scroller 实现平滑滚动功能的示例代码
- Android文件操作工具类详解
- Android之RecycleView实现指定范围的拖动效果
- Android 通过代码安装 APK的方法详解
- Android ListView实现无限循环滚动