问题
i have svg file
<svg
xmlns="http://www.w3.org/2000/svg"
xml:space="preserve" width="200px"
height=""
style="shape-rendering:geometricPrecision; text-rendering:geometricPrecision; image-rendering:optimizeQuality; fill-rule:evenodd; clip-rule:evenodd"
viewBox="0 0 69.1341 93.4405"
xmlns:xlink="http://www.w3.org/1999/xlink">
...
<path class="fil3 str0" d="M49.1257 35.5851c3.029,0.890254 7.2612,0.610968 12.3164,-0.468419 -5.13373,3.85796 -12.1161,4.96333 -19.7673,5.07307"/>
...
</svg>
i am trying to convert it to vml manually and what i am getting is
<body>
...
<v:group style="position: absolute;
left: 0pt;
top: 0pt;
width: 200px;
height: 200px;
z-index: -56;"
coordsize="100000 100000"
coordorigin="0 0" id="Слой_x0020_1">
<v:shape path="m 491257,355851 nf v 30290,8903 72612,6110 123164,-4684 -51337,38580 -121161,49633 -197673,50731 e"
strokeweight="0.126615"
fill="false"
style="width: 200px;
height: 200px;"
coordorigin="-100000 -100000"
class="fil3 str0"></v:shape>
...
</body>
The problem: i am getting image in a wrong scale
The question: how to convert svg dimensions/coords to vml dimensions/coords correctly
回答1:
ok its simple
we have
<svg
xmlns="http://www.w3.org/2000/svg"
xml:space="preserve" width="200px"
height=""
style="shape-rendering:geometricPrecision; text-rendering:geometricPrecision; image-rendering:optimizeQuality; fill-rule:evenodd; clip-rule:evenodd"
viewBox="0 0 69.1341 93.4405"
xmlns:xlink="http://www.w3.org/1999/xlink">
...
<path class="fil3 str0" d="M49.1257 35.5851c3.029,0.890254 7.2612,0.610968 12.3164,-0.468419 -5.13373,3.85796 -12.1161,4.96333 -19.7673,5.07307"/>
...
</svg>
69.1341/200=0.3456705
round(0.3456705*10000)=3456
its a 3456 "some units" per pixel
in vml its equals to "width:1px;height:1px" and coordsize="3456 3456"
result
<body>
...
<v:group style="position: absolute;
left: 0pt;
top: 0pt;
width: 1px;
height: 1px;
z-index: -56;"
coordsize="1 1"
coordorigin="0 0" id="Слой_x0020_1">
<v:shape path="m 491257,355851 nf v 30290,8903 72612,6110 123164,-4684 -51337,38580 -121161,49633 -197673,50731 e"
strokeweight="0.126615"
fill="false"
style="width: 1px; height: 1px;"
coordorigin="-100000 -100000"
coordsize="3456 3456"
class="fil3 str0"></v:shape>
...
</body>
回答2:
Here is a lightweight library that will convert SVG path(s) to VML paths(s) SVG to VML conversion with Core Framework
来源:https://stackoverflow.com/questions/2811492/svg-coords-to-vml-coords