最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to get translate property from a group? - Stack Overflow

programmeradmin6浏览0评论

I have a number of svg groups and each group has a number of children within them.

In case of a click on the group I would like to move all my groups with their children. I would like to know the translate properties of the clicked group, so I can move other groups.

I'm trying to get the translate property, but was unable to get it.

This is what I've tried:

var svg = d3.select('body').append('svg').attr({width:300,height:300});    
var group = svg.append('svg:g').attr({
    'width':100,
    'height':100,
    'transform' : 'translate(50, 50)'
});

group.append('circle').attr({'r':30});

group.on('click', function () {
    console.log(this); //how to get the translated properties?
});

Jsfiddle

I have a number of svg groups and each group has a number of children within them.

In case of a click on the group I would like to move all my groups with their children. I would like to know the translate properties of the clicked group, so I can move other groups.

I'm trying to get the translate property, but was unable to get it.

This is what I've tried:

var svg = d3.select('body').append('svg').attr({width:300,height:300});    
var group = svg.append('svg:g').attr({
    'width':100,
    'height':100,
    'transform' : 'translate(50, 50)'
});

group.append('circle').attr({'r':30});

group.on('click', function () {
    console.log(this); //how to get the translated properties?
});

Jsfiddle

Share Improve this question edited May 21, 2015 at 7:11 Robert Longson 125k27 gold badges267 silver badges253 bronze badges asked May 21, 2015 at 6:25 3gwebtrain3gwebtrain 15.3k29 gold badges141 silver badges276 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 5

You can use getAttribute e.g.

this.getAttribute("transform")

or the SVG DOM

this.transform.baseVal.getItem(0).matrix.e + ", " + this.transform.baseVal.getItem(0).matrix.f)

baseVal.numberOfItems gets you how many ponents there are to the transform and getItem(0).type gets its type i.e. 2 = translate in this case.

This alerts 50, 50 for me on Firefox.

Robert's answer already covers how to solve the problem, but here's the D3 way of doing it in addition. In particular, you can use d3.transform() to parse the value of the transform attribute:

var t = d3.transform(d3.select(this).attr("transform"));
console.log(t.translate);

Updated jsfiddle here;

发布评论

评论列表(0)

  1. 暂无评论