SVG基础|SVG坐标系统和图形转换

坐标系统
一个普通的笛卡尔坐标系统的坐标原点(0,0)位于左下角位置,X轴方向上向右是正值,向左是负值。Y轴方向上向上是正值,向下是负值。如下图所示:

而SVG的坐标系统坐标原点位于左上角,X轴和笛卡尔坐标系的X轴相同,但是Y轴则刚好相反,如果SVG中点或图形数值增加时往下增长,而不是往上。如下图所示:

SVG坐标系统的单位
你可以指定在SVG坐标系统值1个单位代表什么。如果你没有明确的指定单位,将会使用像素(px)为单位。下面是SVG元素可以使用的单位:
- em:默认的字体大小,通常一个字符的高度
- ex:字符x的高度
- px:像素
- pt:点数,1/72英寸
- pc:Picas,1/6英寸
- cm:厘米
- mm:毫秒
-
in:英寸
SVG元素转换-TRANSFORM属性
SVG元素可以被缩放,移动,倾斜和旋转,就像HTML元素可以使用CSS来转换一样。但是因为坐标系统不同,SVG和HTML元素的转换时有差别的。
TRANSFORM属性
transform用于在一个元素上指定一个或多个转换效果。它使用一系列预定义的值作为参数,并按先后顺序逐一应用到元素上。
SVG可用的转换有:旋转,位移,倾斜和旋转。SVG的transform属性和CSS的transform相似,但是它们的参数不同。
矩阵
你可以在一个SVG元素上通过matrix()函数来应用一个或多个转换。矩阵转换的语法是:
- matrix(
)
位移
要移动一个SVG元素,你可以使用translate()函数。位移的语法是:
- translate(
[ ])
translate()函数可以带一个或两个参数,分别用于表示水平或垂直的位移。
ty参数是可选的,如果没有指定,它默认是0。tx和ty参数可以使用空格隔开,也可以使用逗号隔开,还有它们不需要使用单位。它们的单位使用的是用户坐标系统的单位。
下面的例子将一个SVG元素向右移动100个用户单位,向下移动300个用户单位。
缩放
你可以使用scale()函数来缩放SVG元素。缩放的语法是:
- scale(
[ ])
scale()函数可以带一个或两个参数,分别表示水平或垂直方向上的缩放。
sy参数是可选值,如果没有指定,它等于sx的值。sx和sy参数可以使用空格或逗号隔开。并且它们是无单位的数字。
下面的例子将一个SVG元素放大到原来尺寸的2倍。
下面的例子将SVG元素水平方向放大2倍,垂直方向缩小一半。
同样,我们可以使用逗号来分隔scale()函数的参数,上面的代码可以写为:scale(2, .5)。
这里要注意:当一个SVG元素被缩放的时候,整个当前坐标系统也会被同时缩放,导致元素会在viewport中被重新定位。
倾斜
一个SVG元素也可以被倾斜。要倾斜一个SVG元素,你需要使用skewX或skewY函数。语法如下:
- skewX(
)
- skewY(
) - skewY(
skewX函数指定元素绕X旋转,skewY函数指定元素绕Y轴旋转。
旋转角度使用的是一个无单位的角度值,默认单位是度(degrees)。
注意,元素倾斜也可能会是元素在viewport中重新定位。
旋转
你可以使用rotate()函数来旋转一个SVG元素。语法如下:
- rotate(
[ ])
rotate()函数通过rotate-angle来指定旋转角度。于CSS转换中的 rotation 不同,你不能为旋转角度指定单位,只能使用度(degrees)为单位。角度值使用的是无单位的数字,默认单位为:度。
cx和cy为可选参数,用于代表旋转的中心点。如果没有提供cx和cy值,那么旋转的中心点位于当前用户坐标系统的原点。
在rotate()函数中指定中心点就像在CSS中设置transform: rotate()和transform-origin的简写方式。由于SVG默认的旋转中心点位于当前用户坐标系统的左上角(坐标原点),你创建的旋转效果可能不是你需要的,这时你就需要指定一个新的旋转中心点。如果你知道元素的尺寸和位置,你就可以非常容易的为它指定一个旋转中心点。
下面的例子在当前用户坐标系统中将一组SVG元素绕(50,50)中心点旋转45度。
-
- ......
- ......
本文版权属于jQuery之家,转载请注明出处:http://www.htmleaf.com/ziliaoku/ ... g/201506202075.html

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

uniapp如何實現小程式和H5的快速轉換,需要具體程式碼範例近年來,隨著行動網路的發展和智慧型手機的普及,小程式和H5成為了不可或缺的應用形式。而uniapp作為一個跨平台的開發框架,可以在一套程式碼的基礎上,快速實現小程式和H5的轉換,大大提高了開發效率。本文將介紹uniapp如何實現小程式和H5的快速轉換,並給出具體的程式碼範例。一、uniapp簡介unia

Windows101909目前被認為是最為穩定可靠的版本之一,然而令人感到遺憾的是,該版本的服務支援已於近期結束。而21H2則是比較穩定的版本,其實從實際情況來看,二者都是很不錯的選擇。 win101909和21h2哪個好答:1909比較穩定,21h2會比較安全。在目前的環境中,1909仍然被普遍認為是最穩定可靠的版本之一。不過Win101909版本已於2021年5月11日正式停止服務WindowsServer21h2則致力於為廣大用戶提供更多專業化的IT功能支援。 1.經過眾多用戶的實際測試反

win1121h2和22h2兩個版本相比較的話還是後者22h2更加穩定一點,22h2的功能也是更加多一點的,相較於之前的21h2,很多功能都得到的提升一起來看看吧。 win1121h2和22h2哪個穩定:答:22h2更加穩定win1121h2和22h2兩者相比較的話22h2更加穩定一些。 22h2增加了很多的功能,而且21h2的問題也在22h2中得到了改善。 22h2更新功能:開始功能表中的應用程式資料夾。開始功能表中可調整的固定區域。在工作列上拖放。焦點輔助與通知中心實現整合。新的“聚光燈”牆紙功能。新

Windows11系統中23h2版本和22h2版本分別先後於2023年和2022年發布,一般來說,系統的更新是越來越好,小編也認為23h2的版本比22h2的版本要更好一些。 win1123h2和22h2哪個更好答:win1123h2比較好。據介紹,win1123h2是22h2到下一個版本的累積的版本更新,而且它們都是相同的平台。這也意味著這兩個版本之間是沒有任何相容性問題的出現的,建議大家及時更新一下。 win1123h2版本為我們帶來了許多實用的功能,例如工作列視窗所應用的永不合併的模式。還有更加

大家最近都想要更新Win11的23H2版本,但是一小部分的用戶至今還沒有收到更新推播的訊息,可能是後台更新進度中的某個進程卡住了,過段時間就好了。 Win11更新取得不到23H2怎麼辦方法一:耐心等待如果使用者查看電腦的更新升級情況,發現它卡住了,我們可以等待一段時間,系統就會繼續更新的。方法二:清除更新的快取如果使用者之前更新過系統,而且未清除過更細膩的快取就會影響23h2的正常更新,可以手動清理一下。方法三:使用鏡像安裝推薦大家到微軟的官方網站去下載win1123h2的鏡像文件,然後執行更新該文件

工作列是這次win11系統問題很多的存在因此這次微軟即將對其進行優化和修復,下面就帶來了詳細的Win11任務欄故障將修復22H2可能回歸任務欄拖放功能詳情,快來一起了解一下吧。 Win11工作列故障將修復22H2可能回歸工作列拖放功能:1、win11系統的工作列出現了很多的問題和bug影響了很多的用戶的使用,好在這次微軟將對新的系統進行相關的優化和修復,並且讓工作列的可靠性增加。 2.在這之前將滑鼠停留在任務欄的時候,彈出的視窗會在其他的位置隨機的出現。 3.還有就是滑鼠停留在工作列角落圖示速度過快時

前不久微軟的內部測試人員發布了win10的20h2版本,很多小夥伴都不知道它更新了哪些內容,沒關係下面就給你們帶來了詳細的介紹,一起來看看吧。 win1020h2更新了什麼:1.對阻止你使用PowerShell更改ServerCore上的系統區域設定的問題進行了修復。 2.對視窗模式下調整大小或切換全螢幕視窗時導師遊戲套用出現失真問題的修復。 3.對導致lsass.exe失敗設備強制重啟的問題進行了修復。 4.對安裝了6月8日發布的windowsupdate補丁後無法列印圖形或文件的文檔問題的修復。 5

現在win101909版本已經停止了更新,因此不少用戶想要更新自己的系統版本卻不知道怎麼操作,用戶只需要進入到電腦的設定裡面找到對應的升級就可以了。 win101909怎麼更新到20h21、點選電腦開始鍵,然後點選「設定」2、再點選「更新與安全」3、在這裡找到檢查更新4、然後找到對應的版本以後再點選下載安裝,然後等待電腦自行更新就可以了。
