编程 CSS实现亚克力和磨砂玻璃效果

2024-11-18 01:21:20 +0800 CST views 1686

CSS构建亚克力和磨砂玻璃效果

最近在一些设计教程中,接触到关于微软Fluent设计系统中的亚克力效果(Acrylic Material)以及Mac OS中的磨砂玻璃效果(Frosted Glass)。这些效果引人注目,并被广泛应用在现代UI设计中。今天我们来讨论如何用CSS实现这些设计效果。

发展历程

  • 磨砂玻璃效果(Frosted Glass):iOS系统于2013年首次引入这种背景模糊效果,之后微软Windows 10的Fluent设计系统进一步扩展了这种半透明模糊的视觉体验。
  • 亚克力效果(Acrylic Material):微软在Fluent设计系统中将其命名为亚克力效果,增强了背景的模糊度和层次感,使界面更加有层次和质感。
  • Neumorphism和Glassmorphism:这两种UI风格近年来成为热门设计趋势,其中Glassmorphism因其透明和多层次的效果引人注目。

实现磨砂玻璃效果

为了实现磨砂玻璃效果,首先我们需要三个层次:

  1. 背景层
  2. 模糊层
  3. 内容层

我们可以使用CSS的filterbackdrop-filter属性来实现模糊效果。

磨砂玻璃效果的代码实现

首先,我们设置背景图片:

body {
    background: url("/glassmorphism-css-11.jpeg") no-repeat center fixed;
    background-size: cover;
}

接着,为卡片元素添加模糊效果:

.card {
    background: rgba(255, 255, 255, 0.3);
    filter: blur(10px);
}

使用伪元素实现模糊层

如果不希望filter影响子元素,可以使用CSS伪元素来构建模糊层:

.card {
    position: relative;
    background: inherit;
    overflow: hidden;
}

.card::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: 8px;
    background: inherit;
    filter: blur(10px);
    z-index: 1;
}

.card > * {
    position: relative;
    z-index: 2;
}

使用backdrop-filter提升效果

backdrop-filter在不影响子元素的情况下,可以提供更自然的模糊效果:

.card {
    background-color: rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(20px);
    border-radius: 8px;
}

实现亚克力效果

亚克力效果可以通过类似的方式实现,增加一定的透明度和背景噪点来模拟亚克力材质的效果。我们同样可以使用filterbackdrop-filter来构建亚克力效果。

.card {
    background-color: rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(20px);
    border-radius: 8px;
    box-shadow: 20px 20px 30px rgba(0, 0, 0, 0.1);
}

实现Glassmorphism效果

Glassmorphism设计风格具有透明、模糊和多层次的特点。我们可以通过以下方式来实现。

设置渐变背景和模糊效果

.card {
    border-radius: 40px;
    background-image: linear-gradient(
        to right bottom,
        rgba(255, 255, 255, 0.4),
        rgba(255, 255, 255, 0.1)
    );
    backdrop-filter: blur(20px);
    border: 3px solid transparent;
    box-shadow: 20px 20px 30px rgba(0, 0, 0, 0.2);
}

为内容层添加透明度和阴影

.card__content {
    background-color: rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(20px);
    border-radius: 0 0 40px 40px;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.1);
}

小结

磨砂玻璃(Frosted Glass)、亚克力(Acrylic Material)、Neumorphism UI和Glassmorphism UI都是现代UI设计中的重要风格。通过CSS的filterbackdrop-filter以及box-shadow等属性,我们可以轻松实现这些效果。

复制全文 生成海报 UI设计 前端开发 CSS效果

推荐文章

一个有趣的进度条
2024-11-19 09:56:04 +0800 CST
PHP来做一个短网址(短链接)服务
2024-11-17 22:18:37 +0800 CST
免费常用API接口分享
2024-11-19 09:25:07 +0800 CST
Vue3中的Slots有哪些变化?
2024-11-18 16:34:49 +0800 CST
动态渐变背景
2024-11-19 01:49:50 +0800 CST
10个极其有用的前端库
2024-11-19 09:41:20 +0800 CST
快速提升Vue3开发者的效率和界面
2025-05-11 23:37:03 +0800 CST
避免 Go 语言中的接口污染
2024-11-19 05:20:53 +0800 CST
记录一次服务器的优化对比
2024-11-19 09:18:23 +0800 CST
Gin 框架的中间件 代码压缩
2024-11-19 08:23:48 +0800 CST
从Go开发者的视角看Rust
2024-11-18 11:49:49 +0800 CST
mysql时间对比
2024-11-18 14:35:19 +0800 CST
使用 `nohup` 命令的概述及案例
2024-11-18 08:18:36 +0800 CST
为什么大厂也无法避免写出Bug?
2024-11-19 10:03:23 +0800 CST
XSS攻击是什么?
2024-11-19 02:10:07 +0800 CST
php使用文件锁解决少量并发问题
2024-11-17 05:07:57 +0800 CST
实现微信回调多域名的方法
2024-11-18 09:45:18 +0800 CST
程序员茄子在线接单