I have a d3.js graph that is made up of rects, and I'd like this to be resizable to any aspect ratio. I've made this work by adding a this code:
var canvas = d3.select("#graph-canvas").append("svg:svg")
.attr("viewBox", "0 0 " + viewWidth + " " + viewHeight)
.attr("preserveAspectRatio", "none")
But the problem I'm having is that I don't want the text to stretch along with it. I'd actually like the text to remain a constant size, while its position adjusts to move with the dimensions of the chart. But if the text can't remain a constant size, I'd like for it to at least retain its aspect ratio.
I've tried setting the aspect ratio on the text element, but this doesn't work (I think it's an attribute meant for a viewBox).
canvas.append("svg:text")
.attr("x", function(d, i) {return xScale(i) + marginLeft;})
.attr("y", "200")
.attr("preserveAspectRatio", "xMinYMin")
.attr("font-size", "100")
.text("foo");
I've also tried attaching just normal divs, but for some reason they never show up.. Thinking this might be the right strategy though.
Something like this?
Demo: http://jsfiddle.net/g8Ms6/
<svg
version="1.1" xmlns="http://www.w3.org/2000/svg"
width="100%" height="100%">
<rect
x="10%" y="10%"
width="80%" height="80%"
stroke="black" stroke-width="1"
fill="transparent"/>
<svg
x="10%" y="10%"
width="80%" height="80%"
viewBox="0 0 100 100" preserveAspectRatio="none">
<rect x="20" y="15" width="30" height="20" fill="blue"/>
</svg>
<text
x="90%" y="90%"
font-size="20px" fill="#000"
transform="translate(-50, 20)">
Foo
</text>
</svg>