Я пытаюсь использовать часть SVG в качестве фона для черепицы. Однако у меня большие проблемы с тем, что он работает правильно.Как я могу создать SVG-sprite tile правильно в фоне CSS?
Я думаю, что картина будет проиллюстрировать эту проблему лучше всего: demonstration picture
Это мой CSS:
body {
background: url("tiletest.svg#svgView(viewBox(120 32 150 64))");
background-size: 30px 32px;
}
А вот код SVG я использую для демонстрации:
<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 21.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg height="100" width="360" version="1.1" id="Lager_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
viewBox="0 0 360 100" style="enable-background:new 0 0 360 100;" xml:space="preserve">
<style type="text/css">
.st0{fill:url(#SVGID_1_);}
.st1{fill:#13FF00;}
.st2{fill:#2732FF;}
</style>
<g>
<linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="9.094947e-13" y1="9.094947e-13" x2="100" y2="100">
<stop offset="0" style="stop-color:#E7FF00"/>
<stop offset="1" style="stop-color:#FF0000"/>
</linearGradient>
<rect class="st0" width="100" height="100"/>
</g>
<polygon class="st1" points="174.68,0 190.92,32.92 227.25,38.2 200.96,63.82 207.17,100 174.68,82.92 142.19,100 148.39,63.82
122.11,38.2 158.43,32.92 "/>
<circle class="st2" cx="310" cy="50" r="50"/>
</svg>
Как вы видите, полный просмотр в SVG равен 0 0 360 100, и когда я вызываю SVG в CSS, я даю ему новый viewbox 120 32 150 64, а также соответственно изменить размер фона (хотя я уверен, что это не имеет значения, так как svg, определяемый представлением, должен расширяться, чтобы заполнить контейнер независимо от размера, не так ли?).
Я пробовал играть в окне просмотра SVG с шириной и высотой с атрибутом preserveAspectRatio, и до сих пор ничего не сработало. Что я делаю не так?
может быть, например, удалить пробелы tiletest.svg # svgView (viewBox (120,32,150,64)) –
Какой браузер вы используете? идентификаторы фрагментов и т. д. не поддерживаются во всех браузерах. – Ruskin