使用CSS3的clip-path(裁剪路徑)實現剪貼區域的顯示以及實例實現圖片漸變

来源:https://www.cnblogs.com/moqiutao/archive/2019/03/18/10547330.html
-Advertisement-
Play Games

clip-path介紹 clip-path 直譯過來就是裁剪路徑,使用SVG或形狀定義一個HTML元素的可見區域的方法。想象一下你在Photoshop中勾勒路徑的場景。MDN上是這樣介紹 clip-path的: clip-path屬性可以防止部分元素通過定義的剪切區域來顯示,僅通過顯示的特殊區域。剪 ...


clip-path介紹

clip-path 直譯過來就是裁剪路徑,使用SVG或形狀定義一個HTML元素的可見區域的方法。想象一下你在Photoshop中勾勒路徑的場景。MDN上是這樣介紹 clip-path的:

clip-path屬性可以防止部分元素通過定義的剪切區域來顯示,僅通過顯示的特殊區域。剪切區域是被URL定義的路徑代替行內或者外部svg,或者定義路線的方法例如circle().。clip-path屬性代替了現在已經棄用的剪切 clip屬性。

基本語法

<clip-source> | [ <basic-shape> || <geometry-box> ] | none

/*屬性說明*/
<clip-source> = <url>
<basic-shape> = <inset()> | <circle()> | <ellipse()> | <polygon()>
<geometry-box> = <shape-box> | fill-box | stroke-box | view-box

相容性

clip-path目前相容性較差,IE和Edge直接不支持。

語法詳解和示例

為了更明顯的表示裁剪區域,我給每個demo添加了同樣寬高的透明背景,其中色塊表示被裁剪後的部分,透明背景表示被裁剪的區域。

基本圖形:inset(定義矩形)

inset() : 定義一個矩形 。註意,定義矩形不是rect,而是 inset。

//語法
inset( <length-percentage>{1,4} [ round <border-radius> ]? )
//說明
inset()可以傳入5個參數,分別對應top,right,bottom,left的裁剪位置,round radius(可選,圓角)

//示例
clip-path: inset(2em 3em 2em 1em round 2em);

 

基本圖形:circle(定義圓)

//語法
circle( [ <shape-radius> ]? [ at <position> ]? )
//說明
circle()可以傳人2個可選參數;
1. 圓的半徑,預設元素寬高中短的那個為直徑,支持百分比
2. 圓心位置,預設為元素中心點
//半徑公式
如果半徑使用百分比:圓的半徑 = (sqrt(width^2+height^2)/sqrt(2)) * 百分比 

//示例
clip-path: circle(30% at 150px 120px);

基本圖形:ellipse(定義橢圓)

//語法
ellipse( [ <shape-radius>{2} ]? [ at <position> ]? )
//說明
ellipse()可以傳人3個可選參數;
1. 橢圓的X軸半徑,預設是寬度的一半,支持百分比
2. 橢圓的Y軸半徑,預設是高度的一半,支持百分比
3. 橢圓中心位置,預設是元素的中心點

//示例
clip-path: ellipse(45% 30% at 50% 50%);

 

基本圖形:polygon(定義多邊形)

//語法
polygon( <fill-rule>? , [ <length-percentage> <length-percentage> ]# )
//說明
<fill-rule>可選,表示填充規則用來確定該多邊形的內部。可能的值有nonzero和evenodd,預設值是nonzero
後面的每對參數表示多邊形的頂點坐標(X,Y),也就是連接點

//示例
clip-path: polygon(50% 0,100% 50%,0 100%);

其他屬性

除了 inset, circle等 basic-shape屬性外,clip-path還具有url, geometry-box等屬性值,具體可以參考MDN上的介紹。

完整語法

/* Keyword values */
clip-path: none;

/* <clip-source> values */ 
clip-path: url(resources.svg#c1);

/* <geometry-box> values */
clip-path: margin-box;
clip-path: border-box;
clip-path: padding-box;
clip-path: content-box;
clip-path: fill-box;
clip-path: stroke-box;
clip-path: view-box;

/* <basic-shape> values */
clip-path: inset(100px 50px);
clip-path: circle(50px at 0 100px);
clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
clip-path: path('M0.5,1 C0.5,1,0,0.7,0,0.3 A0.25,0.25,1,1,1,0.5,0.3 A0.25,0.25,1,1,1,1,0.3 C1,0.7,0.5,1,0.5,1 Z');

/* Box and shape values combined */
clip-path: padding-box circle(50px at 0 100px);

/* Global values */
clip-path: inherit;
clip-path: initial;
clip-path: unset;

圖片漸變實例

實現圖片從上往下漸變

html代碼:

<div class="img">
    <img src="images/1.jpg"/>
</div>

CSS代碼:

*{padding:0;margin:0;}
.img{width:630px;height:630px;}
.img img{display: block;width:100%;}
.img{
    overflow: hidden;
    -webkit-clip-path: polygon(0 0,0 0,100% 0,100% 0);
    clip-path: polygon(0 0,0 0,100% 0,100% 0);
    opacity: 0;
    transition: opacity 1.1s ease 167ms,-webkit-clip-path 1.1s cubic-bezier(.19,1,.22,1);
    transition: clip-path 1.1s cubic-bezier(.19,1,.22,1),opacity 1.1s ease 167ms;
    transition: clip-path 1.1s cubic-bezier(.19,1,.22,1),opacity 1.1s ease 167ms,-webkit-clip-path 1.1s cubic-bezier(.19,1,.22,1);
}
.img.current{
    opacity: 1;
    -webkit-clip-path: polygon(0 0,0 100%,100% 100%,100% 0);
    clip-path: polygon(0 0,0 100%,100% 100%,100% 0);
}

JS代碼:

$(function(){
    $(".img").addClass('current');
})

實現圖片從左往右漸變

圖片不顯示的時候:

 -webkit-clip-path: polygon(0 0,0 0,0 100%,0 100%);
 clip-path: polygon(0 0,0 0,0 100%,0 100%);

圖片顯示的時候:

-webkit-clip-path: polygon(0 0,100% 0,100% 100%,0 100%);
 clip-path: polygon(0 0,100% 0,100% 100%,0 100%);

參考地址


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • node簡介 node.js也是用js開發的語言,而且是一門服務端語言,更有大神利用node寫了一個操作系統出來——NodeOS node能幹什麼 自帶下載工具: 對於我們開發前端項目,node其實用處挺大的,它自帶了一個包管理器npm,類似於Python的pip,這個npm就可以下載很多第三方庫... ...
  • /* *@url --string下載路徑 *@filename --string文件名稱*/ downLoadProcess(url,filename){ filename = filename || 'xxx.csv'; // 創建xhr對象 var req = new XMLHttpReque ...
  • 共有三種方法: 1.結合 vue-axios使用 首先在主入口文件main.js中引用 之後就可以在組件文件中的methods里去使用了 2. axios 改寫為 Vue 的原型屬性 首先在主入口文件main.js中引用,之後掛在vue的原型鏈上 在組件中使用 3.結合 Vuex的action 在v ...
  • chapter08 數組的擴展 8.1 擴展運算符 8.1.1 擴展運算符的含義 如同rest運算符的逆運算,將一個數組轉換為用逗號分隔的參數序列。 8.1.2 代替數組的apply方法 apply方法可以將數組轉為函數的參數 8.1.3 擴展運算符的應用 合併數組 與解構賦值相結合 註意:如果擴展 ...
  • 編碼規範 1. 縮進 採用2個空格縮進,而不是tab縮進。空格在編輯器中與字元是等寬的,而tab可能因編輯器的設置不同。2個空格會讓代碼看起來緊湊、明快。 2. 變數聲明 永遠用var聲明變數,不加var時會將其變為全局變數,這樣可能會意外污染上下文,或是被意外污染。在ECMAScript5的scr ...
  • 前言 本案列僅針對剛剛入門vue學習的伙伴,博主也是剛剛在學基於vue cli搭建腳手架項目,對於前端大牛,可以移步。 快速搭建vue cli環境 如何搭建基於vue cli項目,這裡不再敘述,如果不會的伙伴可以自己百度。 項目搭建完成後,基本文件目錄如下: 打開我們剛剛創建的my project文 ...
  • 背景,做一個前面圖片寬度固定,後面寬度自適應,使用到了flex佈局,但是想讓後面div里文字不換行,超出以點點表示時,這時佈局就亂了,查了下,原來flex佈局與white-space:nowrap有影響 解決辦法,父div設置min-width:0即可 w3c上面是這樣說的 By default, ...
  • 三點註意事項 "JS作用域傳送門" JS沒有塊級作用域,只有全局作用域和局部作用域(函數作用域)。 JS中的作用域鏈,內部的作用域可以訪問到外部作用域中的變數和方法,而外部作用域不能訪問內部作用域的變數和方法。 當前作用域沒有此變數或方法,會向外部作用域尋找變數或方法。 閉包的兩種使用場景 函數作為 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...