主頁 > 資料庫 > 旋轉父級后如何正確翻譯SVG圖形的一部分?

旋轉父級后如何正確翻譯SVG圖形的一部分?

2021-12-23 07:05:36 資料庫

我試圖在整個圖形已經旋轉后翻譯部分 SVG 圖形。它由兩個三角形的括號組成,它們首先按比例縮放,然后旋轉。完成后,我只希望右括號在 x 軸上向右移動,而左括號保持原位。

圍繞它們的中心縮放和旋轉元素不是問題,但是當我想在 x 軸上平移右括號時,我得到了意想不到的副作用。

這是一個說明問題的作業片段:

    .brackets {
      animation: scaling 1s, rotating 2s 1s;
      transform-box: fill-box;
    }
    
    .bracket-left {
      animation: rotate-left 1s 3s forwards;
      transform-box: fill-box;
    }
    
    .bracket-right {
      animation: sliding 1s 3s forwards;
      transform-box: fill-box;
    }
    
    @keyframes scaling {
      0% {
        transform: scale(0);
      }
      25% {
        transform: scale(1);
      }
      100% {
        transform: scale(1);
      }
    }
    
    @keyframes rotating {
      0% {
        transform-origin: center;
        transform: rotate(0deg);
      }
      100% {
        transform-origin: center;
        transform: rotate(-405deg);
      }
    }
    
    @keyframes sliding {
      100% {
        transform: translate(40px, 0px) rotate(-45deg);
      }
    }
    
    @keyframes rotate-left {
      0% {
        transform-origin: center;
        transform: rotate(-45deg);
      }
      100% {
        transform-origin: center;
        transform: rotate(-45deg);
      }
    }
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>CSS SVG</title>
    <link rel="stylesheet" href="test.css" />
  </head>

  <body>
    <svg
      width="256"
      height="256"
      viewbox="0 0 100 100"
      xmlns:xlink="http://www.w3.org/1999/xlink"
      xmlns="http://www.w3.org/2000/svg"
    >
      <defs>
        <linearGradient
          xlink:href="#a"
          id="e"
          gradientUnits="userSpaceOnUse"
          x1="-3.999"
          y1=".503"
          x2="-.497"
          y2="4.005"
        />
        <linearGradient id="a">
          <stop
            style="stop-color: #17ce17; stop-opacity: 0.80000001"
            offset="0"
          />
          <stop
            style="stop-color: #11b3d4; stop-opacity: 0.49803922"
            offset=".5"
          />
          <stop style="stop-color: #00f; stop-opacity: 0" offset=".5" />
        </linearGradient>
        <linearGradient
          xlink:href="#b"
          id="f"
          gradientUnits="userSpaceOnUse"
          x1="1.906"
          y1="1.889"
          x2="15.117"
          y2="15.107"
        />
        <linearGradient id="b">
          <stop style="stop-color: #17ceb5; stop-opacity: 1" offset=".364" />
          <stop style="stop-color: #05fa05; stop-opacity: 0" offset="1" />
        </linearGradient>
        <linearGradient
          xlink:href="#a"
          id="c"
          gradientUnits="userSpaceOnUse"
          x1="-3.999"
          y1=".503"
          x2="-.497"
          y2="4.005"
        />
        <linearGradient
          xlink:href="#b"
          id="d"
          gradientUnits="userSpaceOnUse"
          x1="1.906"
          y1="1.889"
          x2="15.117"
          y2="15.107"
        />
      </defs>
      <g class="brackets" style="display: inline">
        <g class="bracket-right" style="display: inline">
          <path
            style="
              display: inline;
              fill: url(#c);
              fill-rule: evenodd;
              stroke-width: 0.264583;
            "
            transform="rotate(90 0 41.401) scale(3.77953)"
            d="M-3.5 0h3a.499.499 0 1 1 0 1h-3a.499.499 0 1 1 0-1Z"
          />
          <path
            style="
              display: inline;
              fill: url(#d);
              fill-opacity: 1;
              fill-rule: evenodd;
              stroke-width: 0.999999;
            "
            d="M1.89 0C.845 0 .002.845 0 1.89v3.78a1.89 1.89 0 0 1 1.885-1.89h11.344a1.884 1.884 0 0 0 1.888-1.89C15.117.845 14.275 0 13.23 0Zm1.89 5.67a1.89 1.89 0 0 1-.009.17h.008z"
            transform="rotate(179.997 20.7 20.7)"
          />
        </g>
        <g class="bracket-left" style="display: inline">
          <path
            style="
              display: inline;
              fill: url(#e);
              fill-rule: evenodd;
              stroke-width: 0.264583;
            "
            transform="rotate(-90 22.599 0) scale(3.77953)"
            d="M-3.5 0h3a.499.499 0 1 1 0 1h-3a.499.499 0 1 1 0-1Z"
          />
          <path
            style="
              display: inline;
              fill: url(#f);
              fill-opacity: 1;
              fill-rule: evenodd;
              stroke-width: 0.999999;
            "
            d="M1.89 0C.845 0 .002.845 0 1.89v3.78a1.89 1.89 0 0 1 1.885-1.89h11.344a1.884 1.884 0 0 0 1.888-1.89C15.117.845 14.275 0 13.23 0Zm1.89 5.67a1.89 1.89 0 0 1-.009.17h.008z"
            transform="matrix(1 0 0 1 22.599 22.598)"
          />
        </g>
      </g>
    </svg>
  </body>
</html>

這是迄今為止我距離最近的一次。請注意左括號在最后一個影片期間看起來如何平移,即使我只有一個旋轉活動。我也不希望右支架在 y 軸上移動,只在 x 軸上移動。

我不太確定為什么會發生這種情況,但我認為這與旋轉也修改了 SVG 的坐標系有關。我已經嘗試將每個括號作為 SVG 嵌套在主 SVG 中,但是要么我太笨而無法正確執行此操作,要么沒有幫助。

我怎樣才能做到這一點?在為不同/組合的 SVG 圖形設定影片時,處理修改 SVG 坐標系的變換的最佳方法是什么?

uj5u.com熱心網友回復:

像這樣的問題幾乎總是由以下兩種情況之一引起的:

  1. 不小心用不等價的變換替換了現有變換,或
  2. 變換原點意外改變

在你的情況下,我相信是后者。移動 時.bracket-right,對應的點transform-origin: center移動。那是因為fill-box它越來越大。這會影響轉換組合產生的結果。

我建議簡化你的影片。你真的只有兩個轉換發生:

  1. 兩個括號的縮放和旋轉
  2. 右支架的移動

我在下面所做的最重要的更改是 (a) 洗掉transform-box: fill和 (b) 使用絕對坐標transform-origin

對于初始比例,我使用transform-origin: 22.6px, 22.6px. 這對應于括號的左上角。對于我使用的旋轉transform-origin: 32px, 32px,它對應于兩個括號的中心點。而且因為我使用的是絕對坐標,所以當右括號移動時,變換不會受到影響。

至于右括號影片,我將其簡化為簡單的向下和向右平移。因為如果您考慮原始未旋轉的圖示,那才是真正的樣子。

.brackets {
  animation: anim-both 3s forwards;
}

.bracket-right {
  animation: anim-right 1s 3s forwards;
}
    
@keyframes anim-both {
  0% {
    transform: rotate(0deg) scale(0);
    transform-origin: 22.6px 22.6px;
  }
  33% {
    transform: rotate(0deg) scale(1);
    transform-origin: 22.6px 22.6px;
  }
  34% {
    transform: rotate(0deg) scale(1);
    transform-origin: 32px 32px;
  }
  100% {
    transform: rotate(-405deg) scale(1);
    transform-origin: 32px 32px;
  }
}
    
@keyframes anim-right {
  0% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(40px, 40px);
  }
}
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>CSS SVG</title>
    <link rel="stylesheet" href="test.css" />
  </head>

  <body>
    <svg
      width="256"
      height="256"
      viewbox="0 0 100 100"
    >
      <defs>
        <linearGradient
          xlink:href="#a"
          id="e"
          gradientUnits="userSpaceOnUse"
          x1="-3.999"
          y1=".503"
          x2="-.497"
          y2="4.005"
        />
        <linearGradient id="a">
          <stop
            style="stop-color: #17ce17; stop-opacity: 0.80000001"
            offset="0"
          />
          <stop
            style="stop-color: #11b3d4; stop-opacity: 0.49803922"
            offset=".5"
          />
          <stop style="stop-color: #00f; stop-opacity: 0" offset=".5" />
        </linearGradient>
        <linearGradient
          xlink:href="#b"
          id="f"
          gradientUnits="userSpaceOnUse"
          x1="1.906"
          y1="1.889"
          x2="15.117"
          y2="15.107"
        />
        <linearGradient id="b">
          <stop style="stop-color: #17ceb5; stop-opacity: 1" offset=".364" />
          <stop style="stop-color: #05fa05; stop-opacity: 0" offset="1" />
        </linearGradient>
        <linearGradient
          xlink:href="#a"
          id="c"
          gradientUnits="userSpaceOnUse"
          x1="-3.999"
          y1=".503"
          x2="-.497"
          y2="4.005"
        />
        <linearGradient
          xlink:href="#b"
          id="d"
          gradientUnits="userSpaceOnUse"
          x1="1.906"
          y1="1.889"
          x2="15.117"
          y2="15.107"
        />
      </defs>
      <g class="brackets">
        <g class="bracket-right">
          <path
            style="
              fill: url(#c);
              fill-rule: evenodd;
              stroke-width: 0.264583;
            "
            transform="rotate(90 0 41.401) scale(3.77953)"
            d="M-3.5 0h3a.499.499 0 1 1 0 1h-3a.499.499 0 1 1 0-1Z"
          />
          <path
            style="
              fill: url(#d);
              fill-opacity: 1;
              fill-rule: evenodd;
              stroke-width: 0.999999;
            "
            d="M1.89 0C.845 0 .002.845 0 1.89v3.78a1.89 1.89 0 0 1 1.885-1.89h11.344a1.884 1.884 0 0 0 1.888-1.89C15.117.845 14.275 0 13.23 0Zm1.89 5.67a1.89 1.89 0 0 1-.009.17h.008z"
            transform="rotate(179.997 20.7 20.7)"
          />
        </g>
        <g class="bracket-left">
          <path
            style="
              fill: url(#e);
              fill-rule: evenodd;
              stroke-width: 0.264583;
            "
            transform="rotate(-90 22.599 0) scale(3.77953)"
            d="M-3.5 0h3a.499.499 0 1 1 0 1h-3a.499.499 0 1 1 0-1Z"
          />
          <path
            style="
              fill: url(#f);
              fill-opacity: 1;
              fill-rule: evenodd;
              stroke-width: 0.999999;
            "
            d="M1.89 0C.845 0 .002.845 0 1.89v3.78a1.89 1.89 0 0 1 1.885-1.89h11.344a1.884 1.884 0 0 0 1.888-1.89C15.117.845 14.275 0 13.23 0Zm1.89 5.67a1.89 1.89 0 0 1-.009.17h.008z"
            transform="matrix(1 0 0 1 22.599 22.598)"
          />
        </g>
      </g>
    </svg>
  </body>
</html>

uj5u.com熱心網友回復:

我會采取非常不同的方法。我會使用筆觸而不是填充路徑stroke-linecap="round"

在下一個示例中,筆畫是黑色的,但如果需要,您可以使用漸變。

請注意,我已經更改了 viewBox 屬性的前 2 個引數的值,因為我想將括號放在 0,0 附近。這大大簡化了代碼。

觀察:我保持與您的代碼相同的 svg 大小和縱橫比,但我會將其更改為較小的畫布。為了理解我的意思,我在 svg 畫布上添加了銀色背景。

svg{background:silver}

path{animation: a 1s forwards;}

g{animation: b 1s 1s forwards;}


 @keyframes a{
      100% {
        transform: rotate(-45deg);
      }
    }


 @keyframes b{
      100% {
        transform: translate(20px,0px);
      }
    }
<svg width="256" height="256" viewbox="-20 -20 100 100" fill="none" stroke="black" stroke-width="4" stroke-linecap="round">

  <path d="M-7.5,-7.5h11" />
  <path d="M-7.5,-7.5v11" />

  <g>
    <path d="M7.5,7.5h-11" />
    <path d="M7.5,7.5v-11" />
  </g>
</svg>

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/390332.html

標籤:css svg

上一篇:ERROR 1396 (HY000): Operation ALTER USER failed for 'root'@'localhost'

下一篇:使用Radiobutton函式并提交Button以更改布林值

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more