.my-svg-container{
display: inline-block;
position: relative;
width: 50%;
padding-bottom: 60%; /* depends on svg ratio, for my zebra height/width = 1.2 so padding-bottom = 50% * 1.2 = 60% */
vertical-align: middle; /* top | middle | bottom ... do what you want */
}
.my-svg{ /* svg into : object, img or inline */
display: block;
position: absolute;
top: 0;
left: 0;
width: 100%; /* only required for <img /> */
}
.svg file settings : I removed the width
and height
attributes and added :
preserveAspectRatio="xMinYMin meet" viewBox="0 0 800 960"
Without viewBox preserveAspectRatio has no effect
If you know a better way to do that, tell me ! @eQRoeil or eqroeil[at]gmail.com
And if you want to see my first attemps, SVG as a CSS background-image or links with SVG in <object>
, have a look.
Object <object class="my-svg" >
Image <img class="my-svg" />
Inline svg <svg class="my-svg" preserveAspectRatio= "xMinYMin meet" viewBox="0 0 800 960" >
We can add media-queries to the svg file into a <style>
tag. Then we can hide/show elements (path, circle, text...) depending on the screen size (not really the screen size but the width of the embedded svg, needs some tests and maths).
I made a ugly tag that says "You can use SVG in Responsive Web Design" on large screen, or "Use SVG in RWD" on smaller ones. Give it a try and resize your window. (And you can hide this ugly tag when it's done... ).
I used an <object>
with callback (png). This time I used position: absolute
onto the container (yes, display: inline-block
is not required...)
The zebra is red when the svg is small, then green, then blue for inside svg media-queries.
In wide screens the svg and the notes are side by side. When the line width is too small, the notes go under the svg (nothing new). The width of the svg container is changed (bigger : from 50% to 80%) at this breakpoint.
The zebra is dark gray or light gray with inline embedding, this time the fill:
color is changed with CSS MQ (the #path3087
in the source)
1414