gpt4 book ai didi

css - 如何将变换原点设置为元素上的特定点?

转载 作者:行者123 更新时间:2023-11-28 08:35:29 26 4
gpt4 key购买 nike

在这个例子中,我想从底部旋转锤子,所以有没有办法准确知道元素上特定点的正确坐标,或者我应该随机尝试不同的点吗?

svg {
width: 50%;
}

.hammer-icon {
transform-origin: 200px 50px;
transition: transform .3s ease-out;
}

.hammer:hover .hammer-icon {
transform: rotate(45deg);
}
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 -50 400 200">
<g class="hammer">
<circle class="hammer-bg" fill="#FFD466" cx="200" cy="50" r="90"></circle>
<path class="hammer-icon" fill="#FFFFFF" d="M262,32.9l-6.7-6.9c-1.4-1.4-3.6-1.4-5-0.1l-2.8,2.8l-14.6-15c-7-7.2-20.3-18.5-30.1-16.4
c-1.6,0.3-5.6,3.1-5.6,3.1l19,19.5l-26.3,25.6l-1.5-1.6c-1.4-1.4-3.6-1.4-5-0.1l-39.3,38.3c-1.4,1.4-1.4,3.6-0.1,5l14.4,14.8
c1.4,1.4,3.6,1.4,5,0.1l39.3-38.3c1.4-1.4,1.4-3.6,0.1-5l-1.5-1.6l26.3-25.6l8.3,8.5l-2.8,2.8c-1.4,1.4-1.4,3.6-0.1,5l6.7,6.9
c1.4,1.4,3.6,1.4,5,0.1l17.3-16.9C263.3,36.5,263.4,34.3,262,32.9z"></path>
</g>
</svg>

最佳答案

要使 transform-origin 点相对于元素,您需要使用 transform-box: fill-box; .

Chrome 尚不支持该属性 ( CSS transform-box - Chrome Platform Status ),但幸运的是(但错误地)如果您使用百分比而不是像素,Chrome 会相对于元素设置 transform-origin ( https://css-tricks.com/transforms-on-svg-elements/ ).

因此,要制作适用于大多数 *) 现代浏览器的内容,请使用 transform-b​​ox: fill-box;transform-origin: xx% yy%;

.hammer-icon {
transform-origin: 15% 80%;
transform-box: fill-box;
...
}

https://jsfiddle.net/L1790vzo/8

*) IE/Edge 根本不支持 SVG 元素上的 CSS 转换。
*) Chrome v64 和 Opera v51 的适当支持

关于css - 如何将变换原点设置为元素上的特定点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47397183/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com