0

0

使用 SVG 遮罩图像:clip-path 与 mask 的应用

霞舞

霞舞

发布时间:2025-09-07 23:20:01

|

537人浏览过

|

来源于php中文网

原创

使用 svg 遮罩图像:clip-path 与 mask 的应用

本文将深入探讨如何使用 SVG (Scalable Vector Graphics) 中的 clip-path 和 mask 属性,将图像或 GIF 裁剪为特定的 SVG形状。我们将通过示例代码详细讲解这两种方法的实现,并分析它们之间的差异与适用场景,帮助开发者灵活运用 SVG 技术,实现各种创意性的图像处理效果。

使用 clip-path 裁剪图像

clip-path 属性允许你定义一个 SVG 图形,作为图像的裁剪路径。只有位于该路径内部的图像部分才会被显示,路径外部的部分将被隐藏。

示例代码:

<svg width="300" viewBox="0 0 284 178" xmlns="http://www.w3.org/2000/svg">
  <defs>
    <clipPath id="cp1">
      <path clip-rule="evenodd"
      d="M104.5 0L0.143921 142.5H208.856L104.5 0ZM104.5 10.1551L11.9747 136.5H197.025L104.5 10.1551Z" />
    </clipPath>
   </defs>
   <image width="100%" height="100%"
   href="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQU69UnQwUGs3VTS51AEM2MRTHED0PRl0rMLVw3hdS_95xNdTPqY5_7E3N-pzgp49lrdkY&usqp=CAU"
   clip-path="url(#cp1)"/>
</svg>

代码解释:

  1. <svg> 元素: 定义 SVG 画布的宽度和 viewBox。viewBox 属性定义了 SVG 内容的坐标系统,这里设置为 0 0 284 178,确保图像的宽高比与 viewBox 的宽高比一致。
  2. <defs> 元素: 用于定义可重用的元素,例如 clipPath。
  3. <clipPath> 元素: 定义一个裁剪路径,并赋予 ID cp1。
  4. <path> 元素: 定义裁剪路径的形状。d 属性包含路径数据,描述了三角形的形状。clip-rule="evenodd" 定义了填充规则,这里使用 evenodd 规则,使得只有 "frame" 部分显示。
  5. <image> 元素: 嵌入图像,width="100%" 和 height="100%" 使图像填充整个 SVG 画布。
  6. clip-path="url(#cp1)": 将 clipPath 应用于图像,使用其 ID 作为引用。

使用 mask 遮罩图像

mask 属性允许你使用另一个 SVG 元素作为图像的遮罩。遮罩元素的颜色决定了图像的可见程度。白色区域完全显示图像,黑色区域完全隐藏图像,灰色区域则根据灰度值显示不同程度的透明度。

百灵大模型
百灵大模型

蚂蚁集团自研的多模态AI大模型系列

下载

示例代码:

<svg width="300" viewBox="0 0 284 178" xmlns="http://www.w3.org/2000/svg">
  <defs>
    <mask id="m1">
      <path d="M104.5 0L0.143921 142.5H208.856L104.5 0ZM104.5 10.1551L11.9747 136.5H197.025L104.5 10.1551Z"
      fill="white"/>
    </mask>
   </defs>
   <image width="100%" height="100%"
   href="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQU69UnQwUGs3VTS51AEM2MRTHED0PRl0rMLVw3hdS_95xNdTPqY5_7E3N-pzgp49lrdkY&usqp=CAU"
   mask="url(#m1)"/>
</svg>

代码解释:

  1. <svg> 元素: 与 clip-path 示例相同。
  2. <defs> 元素: 与 clip-path 示例相同。
  3. <mask> 元素: 定义一个遮罩,并赋予 ID m1。
  4. <path> 元素: 定义遮罩的形状。d 属性包含路径数据,描述了三角形的形状。fill="white" 将路径填充为白色,表示该区域的图像完全显示。
  5. <image> 元素: 嵌入图像,width="100%" 和 height="100%" 使图像填充整个 SVG 画布。
  6. mask="url(#m1)": 将 mask 应用于图像,使用其 ID 作为引用。

clip-path 与 mask 的区别

  • 功能: clip-path 用于裁剪图像,隐藏路径外部的部分。mask 用于遮罩图像,根据遮罩元素的颜色控制图像的透明度。
  • 颜色: clip-path 不考虑颜色,只考虑路径的形状。mask 则依赖于遮罩元素的颜色,白色显示,黑色隐藏,灰色控制透明度。
  • 复杂性: mask 可以实现更复杂的遮罩效果,例如渐变透明度。clip-path 更适合简单的裁剪。

注意事项

  • 确保 viewBox 的宽高比与图像的宽高比一致,以避免图像变形。
  • clip-path 和 mask 都可以应用于其他 SVG 元素,例如 <rect>、<circle> 等。
  • clip-path 和 mask 元素必须在 <defs> 元素中定义,以便重复使用。

总结

clip-path 和 mask 是 SVG 中强大的图像处理工具,它们可以帮助开发者实现各种创意性的视觉效果。选择使用哪种方法取决于具体的需求和效果。clip-path 适合简单的裁剪,而 mask 则适合更复杂的遮罩效果。熟练掌握这两种方法,可以让你在 SVG 图像处理方面更加得心应手。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

3

2026.03.18

bootstrap框架介绍
bootstrap框架介绍

本专题整合了bootstrap框架相关介绍,阅读专题下面的文章了解更多详细内容。

4

2026.03.18

vscode 格式化
vscode 格式化

本专题整合了vscode格式化相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.03.18

vscode设置中文教程
vscode设置中文教程

本专题整合了vscode设置中文相关内容,阅读专题下面的文章了解更多详细教程。

0

2026.03.18

vscode更新教程合集
vscode更新教程合集

本专题整合了vscode更新相关内容,阅读专题下面的文章了解更多详细教程。

3

2026.03.18

Gemini网页版零基础入门:5分钟上手Gemini聊天指南
Gemini网页版零基础入门:5分钟上手Gemini聊天指南

本专题专为零基础用户打造,5分钟快速掌握Gemini网页版核心用法。从账号登录到界面布局,详解如何发起对话、优化提示词及利用多模态功能。通过实战案例,教你高效获取信息、创作内容与分析数据。无论学习还是工作,轻松开启AI辅助新时代,让Gemini成为你的得力智能助手。

9

2026.03.18

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

8

2026.03.18

Java Spring Security权限控制与认证机制实战
Java Spring Security权限控制与认证机制实战

本专题围绕 Java 后端安全体系建设展开,重点讲解 Spring Security 在权限控制与认证机制中的应用实践。内容涵盖用户认证流程、权限模型设计、JWT 鉴权方案、OAuth2 集成以及接口安全防护策略。通过实际项目案例,帮助开发者构建安全可靠的后端认证体系,提升系统安全性与可扩展能力。

26

2026.03.18

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

176

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
svg中文手册
svg中文手册

共0课时 | 0.3万人学习

SVG 教程
SVG 教程

共20课时 | 13.3万人学习

React 教程
React 教程

共58课时 | 6.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号