`player.animate( [ {transform: "rotate(10)"`?
Я пытаюсь использовать веб-анимацию / JS (но не CSS!) Для преобразования SVG.
Я не могу получить transform: rotate(10)
работать - не знаю почему.
В примере playerT
(масштаб) и playerT3
(strokeWidth) хорошо, но playerT2
кажется, ничего не делает - почему?
<svg width="400" height="400" style="border:1px solid #00f">
<path id="triangle" d="M0,0L30,30L50,10z" stroke="#f00" stroke-width="3" />
<script type="text/ecmascript">
<![CDATA[
var triangle=document.getElementById("triangle");
var playerT=triangle.animate(
[{transform: 'scale(1)'},
{transform: 'scale(5)'}],
{duration:1000, delay:0,iterations: Infinity});
var playerT2=triangle.animate(
[{transform: 'rotate(10)'},
{transform: 'rotate(20)'}],
{duration:1000, delay:0,iterations: Infinity});
var playerT3=triangle.animate(
[{strokeWidth:3},
{strokeWidth:0}],
{duration:1000, delay:0,iterations: Infinity});
]]>
</script>
</svg>
JSFiddle находится здесь: https://jsfiddle.net/45cbhLqL/
PS: могу ли я вместо этого использовать матрицу преобразования (если нужно)?
1 ответ
Решение
Вы должны указать единицу измерения в функции поворота (градусы, радианы и т. Д.), В которой работает ваш код: https://jsfiddle.net/45cbhLqL/1/
var playerT=triangle.animate(
[{transform: 'rotate(10deg)'},
{transform: 'rotate(20deg)'}],
{duration:1000, delay:0,iterations: Infinity});