0

嗨,我面临一个问题,我有一个 svg。当我尝试更改高度和宽度以及视图框的高度和宽度时,svg 内的绘图将不适合框

这是我的 mysvg 我正在给出简短的形式

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="500pt" height="500pt" viewBox="0 0 500 500" version="1.1" xmlns="http://www.w3.org/2000/svg">
    <g transform="translate(528,270)" > 
        <g id="states" fill="green" width="500pt" height="500pt" >
            <a id="s01">
                <path d="M158.95067408594068,46.88327098850149L185.03303599629845,44.0148159910488L189.74121811302572,59.50889743727097L196.59587401503094,82.27898337817625L199.0518321008348,87.17077847298319L201.13017099189912,89.85649424407167L200.707578706067,91.7588142001174L202.6261541288344,92.6205139503571L200.33524838576966,95.29216920133321L200.7363444144292,97.59217497211156L199.80999341478454,100.8918397716738L202.09021078470892,106.20782432993735L201.64399529140977,111.17790897235179L204.03767592952832,115.96122130827978L196.3574723373462,117.09985438789514L163.47293491613115,121.08122011183377L163.22294648718562,123.55296427740802L167.13791879442175,126.6835133291724L166.871741037497,129.76735843938286L168.2485001228969,131.1400084527912L166.21795234496457,134.1137855808483L164.12121282499038,134.9547500732084L159.81791064191435,132.36796011584426L158.90469329765804,127.88713803963412L157.64560372254968,127.51168600895127L156.5390262005875,131.08669596034315L156.36678872306632,134.46030822963786L152.20800610122825,133.97284127048096L148.16895577705603,105.98121856614907L148.12136132417422,70.56398790998259L148.15893441899317,50.102043132249676L146.40831263672231,48.33943105796875Z" stroke="#FFFFFF" stroke-dasharray="1, 0" stroke-width="1.5"></path>
                <text x="162.66165594858754" y="86.92631614090374" style="">AL</text>
                <title></title>
            </a>
        </g>
    </g>
</svg>

这是当我更改宽度和高度或视图框或两者时发生的情况 在此处输入图像描述\

现在宽度高度减小但绘图保持不变

4

2 回答 2

5

假设初始高度和宽度为 1000px。

<svg height="1000" width="1000" viewBox="0 0 1000 1000">

如果要调整 svg 及其中所有元素的大小,请不要更改 viewBox 值。对于 500 像素 SVG:

<svg height="500" width="500" viewBox="0 0 1000 1000">

例子

如何使用 SVG 进行缩放和平移

于 2013-11-11T21:33:53.580 回答
1

解决方法和我昨天给你的答案一样。

svg的宽度高度没有改变

尝试按照以下步骤操作:

(1) 将 svg 的宽度和高度设置为 500,并添加preserveAspectRatio="none"到您的 svg.

<svg width="500" height="500" preserveAspectRatio="none" ...>

这可能会奇怪地拉伸您的地图,但不要担心,这只是一个临时更改,使下一步更容易。

(2) 现在调整 viewBox 直到所有地图都可见。一旦找到正确的值,就不要管 viewBox 了。您不需要进一步更改它。

(3) 删除preserveAspectRatio="none". 拉伸效果会消失。

(4) 现在您可以将 svg 的宽度和高度从 500x500 调整为您喜欢的任何尺寸。无论您如何更改宽度和高度,整个地图都应该保持可见。

于 2013-11-12T04:37:11.830 回答