当前位置: 首页 > news >正文

CSS系列(27)- 图形与滤镜详解

前端技术探索系列:CSS 图形与滤镜详解 🎨

致读者:探索CSS的艺术表现力 👋

前端开发者们,

今天我们将深入探讨 CSS 图形和滤镜效果,学习如何创建引人注目的视觉效果。

基础图形 🚀

几何形状

/* 圆形 */
.circle {width: 100px;height: 100px;border-radius: 50%;background: #007bff;
}/* 三角形 */
.triangle {width: 0;height: 0;border-left: 50px solid transparent;border-right: 50px solid transparent;border-bottom: 86.6px solid #28a745;
}/* 六边形 */
.hexagon {width: 100px;height: 57.735px;background: #dc3545;position: relative;
}.hexagon::before,
.hexagon::after {content: '';position: absolute;width: 0;border-left: 50px solid transparent;border-right: 50px solid transparent;
}.hexagon::before {bottom: 100%;border-bottom: 28.867px solid #dc3545;
}.hexagon::after {top: 100%;border-top: 28.867px solid #dc3545;
}

复杂图形

/* 心形 */
.heart {width: 100px;height: 90px;position: relative;
}.heart::before,
.heart::after {content: '';position: absolute;top: 0;width: 50px;height: 80px;border-radius: 50px 50px 0 0;background: #ff4444;
}.heart::before {left: 50px;transform: rotate(-45deg);transform-origin: 0 100%;
}.heart::after {left: 0;transform: rotate(45deg);transform-origin: 100% 100%;
}/* 星形 */
.star {width: 0;height: 0;border-right: 100px solid transparent;border-bottom: 70px solid #ffd700;border-left: 100px solid transparent;transform: rotate(35deg);position: relative;
}.star::before {content: '';position: absolute;border-bottom: 80px solid #ffd700;border-left: 30px solid transparent;border-right: 30px solid transparent;transform: rotate(-35deg);top: -45px;left: -65px;
}.star::after {content: '';position: absolute;top: 3px;left: -105px;border-right: 100px solid transparent;border-bottom: 70px solid #ffd700;border-left: 100px solid transparent;transform: rotate(-70deg);
}

滤镜效果 🎯

基础滤镜

/* 模糊效果 */
.blur {filter: blur(5px);
}/* 亮度调整 */
.brightness {filter: brightness(150%);
}/* 对比度 */
.contrast {filter: contrast(180%);
}/* 组合滤镜 */
.combined-filters {filter: contrast(150%) brightness(110%) saturate(180%) hue-rotate(30deg);
}

高级滤镜

/* 毛玻璃效果 */
.frosted-glass {background: rgba(255, 255, 255, 0.2);backdrop-filter: blur(10px);-webkit-backdrop-filter: blur(10px);
}/* 动态滤镜 */
.hover-filter {transition: filter 0.3s;
}.hover-filter:hover {filter: brightness(110%) contrast(110%) saturate(120%);
}/* 图片处理 */
.image-effects {filter: sepia(50%)brightness(110%)contrast(120%)saturate(150%);
}

混合模式 💫

基础混合

/* 正片叠底 */
.multiply {background: #ff0000;mix-blend-mode: multiply;
}/* 叠加 */
.overlay {background: #00ff00;mix-blend-mode: overlay;
}/* 滤色 */
.screen {background: #0000ff;mix-blend-mode: screen;
}

高级混合

/* 渐变混合 */
.gradient-blend {background: linear-gradient(45deg, #ff0000, #00ff00);mix-blend-mode: overlay;
}/* 图片混合 */
.image-blend {background-image: url('image.jpg');mix-blend-mode: luminosity;
}/* 动态混合 */
.hover-blend {transition: mix-blend-mode 0.3s;
}.hover-blend:hover {mix-blend-mode: difference;
}

渐变技巧 ⚡

线性渐变

/* 基础渐变 */
.gradient {background: linear-gradient(45deg, #ff0000, #00ff00);
}/* 多色渐变 */
.multi-gradient {background: linear-gradient(to right,#ff0000,#ff7f00,#ffff00,#00ff00,#0000ff,#4b0082,#8f00ff);
}/* 重复渐变 */
.repeating-gradient {background: repeating-linear-gradient(45deg,#ff0000,#ff0000 10px,#ffffff 10px,#ffffff 20px);
}

径向渐变

/* 圆形渐变 */
.radial {background: radial-gradient(circle, #ff0000, #00ff00);
}/* 椭圆渐变 */
.elliptical {background: radial-gradient(ellipse at center,rgba(255,255,255,1) 0%,rgba(255,255,255,0) 70%);
}/* 多重渐变 */
.complex-gradient {background: radial-gradient(circle at 50% 0,rgba(255,0,0,.5),rgba(255,0,0,0) 70.71%),radial-gradient(circle at 6.7% 75%,rgba(0,0,255,.5),rgba(0,0,255,0) 70.71%),radial-gradient(circle at 93.3% 75%,rgba(0,255,0,.5),rgba(0,255,0,0) 70.71%);
}

最佳实践建议 💡

  1. 性能考虑

    • 合理使用滤镜
    • 优化渐变效果
    • 控制混合模式
    • 避免过度使用
  2. 创意表现

    • 组合多种效果
    • 动态交互
    • 响应式适配
    • 优雅降级
  3. 浏览器兼容

    • 特性检测
    • 回退方案
    • 前缀处理
    • 性能测试
  4. 实践建议

    • 模块化设计
    • 可维护性
    • 代码复用
    • 文档完善

写在最后 🌟

CSS图形和滤镜效果为我们提供了强大的视觉表现力,通过合理运用这些技术,我们可以创建出独特而吸引人的界面效果。

进一步学习资源 📚

  • CSS图形教程
  • 滤镜效果指南
  • 混合模式详解
  • 创意案例集

如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇

终身学习,共同成长。

咱们下一期见

💻

相关文章:

CSS系列(27)- 图形与滤镜详解

前端技术探索系列:CSS 图形与滤镜详解 🎨 致读者:探索CSS的艺术表现力 👋 前端开发者们, 今天我们将深入探讨 CSS 图形和滤镜效果,学习如何创建引人注目的视觉效果。 基础图形 🚀 几何形状…...

Docker 技术系列之安装多版本Mysql5.6和Mysql5.7

image 大家好,后面的就不是关于MAC专有的内容,基本是跟Java环境,基础技术方面有关。所以这个教程对于在linux系统还是macOS都是通用的,不用担心。 上一篇,我们安装好对应的Docker之后,感受到了它的便利。接…...

理解并使用Linux 内核中的 Tracepoint

理解并使用Linux 内核中的 Tracepoint 1. 引言 1.1 为什么需要 Tracepoint? 在内核调试与性能分析中,传统的 printk 方法虽然简单直接,但存在几个显著的局限性: 日志噪音:printk 会将所有输出无差别地记录到系统日…...

centos7中Gbase8s数据库安装,以及数据导入遇到的一系列问题

centos7中Gbase8s数据库安装,以及遇到的一系列问题 以下是我在centos7上安装gbase8s数据库遇到的一系列问题,包括数据库安装,数据导入,数据连接,不能完全作为标准,只可作为类似问题参考,有问题…...

AW36518芯片手册解读(3)

接前一篇文章:AW36518芯片手册解读(2) 二、详述 3. 功能描述 (1)上电复位 当电源电压VIN降至预定义电压VPOR(典型值为2.0V)以下时,该设备会产生复位信号以执行上电复位操作&#x…...

MySQL的REPEATABLE READ事务隔离级别

本文隔离级别: T1内读T2的update数据 首先开两个事务(左二) 事务1修改成李四,提交 事务2再读还是张三,也就是说,记录的数据从事务开始时一直到结束,读的都是同一个版本,读不到T2未提交的此条记录修改&…...

sqoop的参数有哪些?

Sqoop 是一款用于在 Hadoop 与关系型数据库之间进行数据传输的工具,它有很多参数,可分为通用参数、导入参数和导出参数等,以下是一些常见的参数介绍: 通用参数 --connect 说明:指定要连接的关系型数据库的 JDBC URL。…...

动态规划<四> 回文串问题(含对应LeetcodeOJ题)

目录 引例 其余经典OJ题 1.第一题 2.第二题 3.第三题 4.第四题 5.第五题 引例 OJ 传送门Leetcode<647>回文子串 画图分析&#xff1a; 使用动态规划解决 原理&#xff1a;能够将所有子串是否是回文的信息保存在dp表中 在使用暴力方法枚举出所有子串&#xff0c;是…...

跨模态知识迁移:基于预训练语言模型的时序数据建模

在NLP和CV领域&#xff0c;通常通过在统一的预训练模型上进行微调&#xff0c;能够在各自领域的下游任务中实现SOTA&#xff08;最先进&#xff09;的结果。然而&#xff0c;在时序预测领域&#xff0c;由于数据量相对较少&#xff0c;难以训练出一个统一的预训练模型来覆盖所有…...

重温设计模式--职责链模式

文章目录 职责链模式的详细介绍C 代码示例C示例代码2 职责链模式的详细介绍 定义与概念 职责链模式&#xff08;Chain of Responsibility Pattern&#xff09;是一种行为型设计模式&#xff0c;它旨在将请求的发送者和多个接收者解耦&#xff0c;让多个对象都有机会处理请求&a…...

git冲突解决

git冲突解决 最近遇到了一次git冲突的问题 起因是因为最近公司数据推送部分重构&#xff0c;负责重构的同事就改动了我的一小部分推送的代码&#xff0c;然后等我开发完合并到远程master的时候&#xff0c;报了merge冲突。我对于git工具确实不是很熟练&#xff0c;只是学习了…...

Java学习笔记(14)--面向对象编程

面向对象基础 学习资料来自多态 - Java教程 - 廖雪峰的官方网站 目录 面向对象基础 Override 多态 举个例子 覆写Object方法 调用super final 练习 小结 Override 在继承关系中&#xff0c;子类如果定义了一个与父类方法签名完全相同的方法&#xff0c;被称为覆写&…...

《Swift 字面量》

《Swift 字面量》 介绍 在 Swift 编程语言中&#xff0c;字面量是一种表示源代码中固定值的表达方式。字面量可以直接表示数字、字符串、布尔值等基本数据类型&#xff0c;为编程提供了简洁和直观的方式。Swift 支持多种类型的字面量&#xff0c;包括整数字面量、浮点数字面量…...

数据库 SQL 常用语句全解析

数据库 SQL 常用语句全解析 在数据库领域&#xff0c;SQL&#xff08;Structured Query Language&#xff09;作为标准语言&#xff0c;掌控着数据的查询、插入、更新与删除等关键操作。无论是新手入门数据库&#xff0c;还是经验丰富的开发者日常工作&#xff0c;熟练掌握 SQ…...

SQLite 命令

关于《SQLite 命令》的文章&#xff0c;我可以为您概述一些关键点。SQLite是一个轻量级的数据库管理系统&#xff0c;它被广泛用于各种应用程序中。SQLite命令主要分为两类&#xff1a;一类是SQL命令&#xff0c;另一类是SQLite特定的点命令。 SQL命令&#xff1a;这些命令用于…...

本地如何启动casdoor

1、下载代码 GitHub - casdoor/casdoor at v1.777.0 下载对应tag的代码&#xff0c;我这里选择的时v1.777.0版本 通过网盘分享的文件&#xff1a;casdoor-1.777.0.zip 链接: https://pan.baidu.com/s/1fPNqyJYeyfZnem_LtEc0hw 提取码: avpd 2、启动后端 1、使用goland编译…...

目标检测-R-CNN

R-CNN在2014年被提出&#xff0c;算法流程可以概括如下&#xff1a; 候选区域生成&#xff1a;利用选择性搜索(selective search)方法找出图片中可能存在目标的候选区域(region proposal) CNN网络提取特征&#xff1a;对候选区域进行特征提取(可以使用AlexNet、VGG等网络) 目…...

【持续更新】Github实用命令

Intro 最近高强度使用github&#xff0c;遂小计于此作为备忘。 Basic github是一个代码管理软件&#xff0c;能够track文件变动并且管理版本&#xff0c;是当代coding必不可少的工具。当你安装好github在本地以后&#xff0c;你可以通过以下命令初始化当前文件夹&#xff08…...

docker 容器的基本使用

docker 容器 一、docker是什么&#xff1f; 软件的打包技术&#xff0c;就是将算乱的多个文件打包为一个整体&#xff0c;打包技术在没有docker容器之前&#xff0c;一直是有这种需求的&#xff0c;比如上节课我把我安装的虚拟机给你们打包了&#xff0c;前面的这种打包方式是…...

css让按钮放在最右侧

要将 el-button 按钮放在最右侧&#xff0c;可以使用多种方法&#xff0c;具体取决于使用的布局方式和样式库。以下是几种常见的解决方案&#xff1a; 方法 1&#xff1a;使用 CSS Flexbox Flexbox 是一种非常灵活的布局方式&#xff0c;可以轻松实现水平或垂直对齐。你可以将…...

智能制造工业互联网工业大数据建设方案:工业大数据架构、工业大数据建模、关键应用场景、平台架构、全生命周期服务、管理与应用体系

本方案围绕工业4.0&#xff0c;构建“云、移、物、大、智”融合的工业大数据平台&#xff0c;实现数据采集、数据湖分析与机器学习建模&#xff0c;支撑预测性维修、生产过程优化、人机协同等应用&#xff0c;助力企业提升效率、降低运营成本&#xff0c;推动智能制造转型。 工…...

数学建模小白避坑指南:线性规划建模时,90%的人都会忽略的3个隐藏约束

数学建模小白避坑指南&#xff1a;线性规划建模时&#xff0c;90%的人都会忽略的3个隐藏约束 第一次参加数学建模竞赛的同学&#xff0c;往往会在线性规划问题上栽跟头——明明按照教材上的"三要素"一步步操作&#xff0c;最后求解结果却和实际场景对不上号。去年校…...

【码动四季】科研绘图不再难!LabPlot 高效科研制图实战指南

目录 一、前言 1. 科研论文制图&#xff1a;不止是“画个图”&#xff0c;更是学术表达的核心 2. 优秀配置&#xff1a;科研绘图的核心需求的是什么 二、LabPlot简介 1. LabPlot是什么 2. LabPlot可以做什么 三、LabPlot实战&#xff1a;教你绘制柱状图 1. 数据准备 方…...

30KHz调频深度0.5%:用示波器实测SSC扩频时钟的完整指南(以PCIe为例)

30KHz调频深度0.5%&#xff1a;用示波器实测SSC扩频时钟的完整指南&#xff08;以PCIe为例&#xff09; 在高速数字系统设计中&#xff0c;电磁干扰&#xff08;EMI&#xff09;始终是工程师面临的核心挑战之一。当PCIe 3.0信号以8GT/s速率传输时&#xff0c;时钟信号的谐波辐射…...

【神通数据库】从零到精通:安装配置、控制台操作与国产化适配全攻略

1. 神通数据库入门指南 第一次接触神通数据库的朋友可能会好奇&#xff0c;这到底是个什么样的数据库&#xff1f;简单来说&#xff0c;神通数据库是一款国产的企业级关系型数据库管理系统&#xff0c;由天津神舟通用数据技术有限公司研发。我在实际项目中使用过多个版本的数据…...

网盘下载限速终结者:8大平台直链解析终极指南

网盘下载限速终结者&#xff1a;8大平台直链解析终极指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼云盘 / 迅…...

BepInEx终极指南:5分钟掌握Unity游戏模组开发框架

BepInEx终极指南&#xff1a;5分钟掌握Unity游戏模组开发框架 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx 想要为Unity游戏添加自定义功能却苦于技术门槛&#xff1f;BepInEx作…...

DISCO-F469NI嵌入式LCD触摸驱动C++封装库

1. 项目概述DISCOF469LCD 是一个面向 STMicroelectronics DISCO-F469NI 开发板的触摸式 LCD 显示驱动封装库。该库并非从零实现底层硬件控制&#xff0c;而是基于 ST 官方提供的 BSP&#xff08;Board Support Package&#xff09;层进行面向对象的 C 封装&#xff0c;旨在为嵌…...

NVIDIA Profile Inspector 配置问题完全指南:从识别到解决的完整流程

NVIDIA Profile Inspector 配置问题完全指南&#xff1a;从识别到解决的完整流程 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector 是一款强大的 NVIDIA 显卡配置管理工具&…...

S2-Pro集成开发环境搭建:VSCode远程连接与调试指南

S2-Pro集成开发环境搭建&#xff1a;VSCode远程连接与调试指南 1. 为什么需要远程开发环境 当你开始使用S2-Pro这类大模型时&#xff0c;本地电脑的性能往往难以满足需求。GPU服务器提供了强大的计算能力&#xff0c;但直接在服务器上开发又不够方便。这就是为什么我们需要搭…...