SVG圍繞某一點縮放,旋轉(zhuǎn)

SVG提供了圍繞某一點旋轉(zhuǎn)的標(biāo)準(zhǔn)方法(rotate(angle, px, py),px,py代表指定點的坐標(biāo)),沒有提供圍繞某個點縮放的方法,不過這些都可以通過變換序列(多個變換連續(xù)進(jìn)行)來實現(xiàn)。

假設(shè)需要圍繞的點坐標(biāo)為(px, py),縮放倍數(shù)為fx,旋轉(zhuǎn)角度為angle,則:
實現(xiàn)圍繞該點縮放的變換序列為:
transform="translate(-px(fx-1),-py(fx-1)) scale(fs)";
實現(xiàn)圍繞該點旋轉(zhuǎn)的變換序列為:
transform="translate(px, py) rotate(angle) translate(-px, -py)";

理解為什么這兩個變換序列能達(dá)到目的的關(guān)鍵在于理解translate,scale,rotate這些變換是發(fā)生在坐標(biāo)系上而不是發(fā)生在繪制的圖形上,每發(fā)生一次變換,坐標(biāo)系都發(fā)生了改變,下一個變換的基礎(chǔ)是上一個變換發(fā)生后改變了的坐標(biāo)系。

咔咔,更詳細(xì)的動畫演示等我學(xué)會了svg動畫再說……

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容