0

我使用 ReadySetRaphael 工具从 InkScape 导入了 SVG。我想对 svg 进行动画处理,并将其简化。因此,仅出于测试目的,我尝试使用 animate 方法对其进行转换。

我不断收到错误消息,说我的对象没有“动画”方法。我检查了其他 SO 答案,这些答案建议我必须克隆对象并设置最终路径,但不确定是否这样做,或者它如何适用于我?

到目前为止,这是我的 js 代码。

//code created using readysetraphael. Original svg made in inkscape.
var rsr = Raphael('rsr', '744.09448', '1052.3622');

var layer1 = rsr.set();
var path2993 = rsr.path("m 344.93716,348.36218 c 0,0 34.17415,-33.06016 -1.26571,-83.92195 -35.43985,-50.86178 39.23699,-38.14634 6.32855,-91.55121 -32.90844,-53.40487 -50.62837,-36.8748 -50.62837,-36.8748 -9.49282,-0.63577 -8.85996,-0.63577 -8.85996,-0.63577");
path2993.attr({
    id: 'path2993',
    parent: 'layer1',
    fill: 'none',
    stroke: '#cf0000',
    "stroke-width": '2.92',
    "stroke-linecap": 'butt',
    "stroke-linejoin": 'miter',
    "stroke-miterlimit": '4',
    "stroke-opacity": '1',
    "stroke-dasharray": 'none',
    "marker-start": 'none',
    "marker-mid": 'none',
    "marker-end": 'url(#TriangleInL)'
}).data('id', 'path2993');
layer1.attr({
    'id': 'layer1',
    'name': 'layer1'
});

var rsrGroups = [layer1];

//Animate svg
rsr.animate({
    transform: 's2'
}, 2000);
4

1 回答 1

1

您的代码在纸对象上拉动动画调用。作为animate()的成员Element,呼叫失败。

我假设您正在尝试为特定形状设置动画,例如path2993. 只需在相关元素上调用它:

path2993.animate({transform: 's2'}, 2000);
于 2013-02-03T10:10:41.417 回答