This is the seventh day of my participation in the August More text Challenge. For details, see:August is more challenging
This is the SVG series directory:
- Front end will know will learn | SVG see this article is enough (a)
preface
In the last article, we learned about simple SVG drawings and how to introduce SVG files. Let’s move on to positioning systems and viewboxes in SVG.
SVG positioning
The SVG element uses a coordinate system (network system), similar to Canvas. Start at the top left corner of the page, in units of px, with the X-axis square pointing to the right and the positive Y-axis pointing down.
In this example, draw a rectangle, add x and Y attributes to the rect TAB, start at the top left corner, offset 50px to the right, offset 60px down, and start drawing a rectangle with 100 width and 100 height.
<svg width="200" height="200">
<rect x="50" y="60" width="100" height="100" fill="#f06" />
<! --x = x, y = y, width = height = height -->
</svg>
Copy the code
ViewBox properties
ViewBox is an attribute in an SVG tag that allows you to specify a given set of graphic extensions to fit a particular container element.
The value of the viewBox property is a list of four parameters: min-x, min-y, width, and height, separated by Spaces or commas, specifying a rectangular area mapped to the given element in user space. Negative width and height are not allowed. 0 disables rendering of the element.
For example, if I draw a 200px radius circle in SVG, on a 400*400 canvas the circle will cover the entire canvas just enough to display it without any problems.
<svg width="200" height="200">
<circle cx="200" cy="200" r="200" fill="#f00" stroke="none"></circle>
</svg>
Copy the code
But in real development, the canvas size of the page is set according to the actual business, not necessarily just right. For example on a 200 by 200 canvas it would look like this
This is certainly not what we want, we can change the size of the circle, but in real development it might be a complex SVG? The viewBox property is designed to solve this problem.
Add viewBox property to SVG tag:
<svg width="200" height="200" viewBox="0 0 400 400">
<circle cx="200" cy="200" r="200" fill="#f00" stroke="none"></circle>
</svg>
Copy the code
In this case, the viewBox is a 400 by 400 square, and it’s not in Px, it’s in dummy units. We put a circle inside the viewBox. The radius of the circle is 200, but instead of the units of the viewBox, it becomes the virtual units of the viewBox. The length of this virtual unit varies.
We can calculate this virtual unit, 200px/400=0.5px. So multiply all the values inside the viewBox by 0.5px to get the true size.
The first two arguments refer to the overall displacement of the internal SVG, which is usually set to 0, 0. We don’t need these arguments here, so we don’t set anything.
PreserveAspectRatio attribute
This property translates directly to: Keep the aspect ratio, which is particularly related to the viewBox, and it tells you whether or not to force a consistent scaling, if you set the viewBox property, and you don’t declare this preserveAspectRatio property, the viewBox will also declare a default value for this property, xMidYMid meet.
In our example above, the width to height of the canvas is the same as the width to height ratio of the viewBox. But in real development we can’t always keep the same proportions as the canvas. At this point you need to declare the preserveAspectRatio attribute, which is also applied to the SVG tag.
Let’s take a look at what properties can be set for the first argument:
- noneInstead of mandatory uniform scaling, the graphical content of the specified element is scaled, if needed, so that the element’s boundaries exactly match the view rectangle. (Note: If the value of the first argument is
none
, the second value of the property is ignored. - xMinYMin– Force uniform scaling. will
SVG
Elements of theviewbox
The minimum value of X of the property is aligned with the minimum value of X of the view. willSVG
Elements of theviewbox
The minimum Y of the property is aligned with the minimum Y of the view. - xMidYMin– Force uniform scaling. will
SVG
Elements of theviewbox
The midpoint value of X of the property is aligned with the midpoint value of X of the view. willSVG
Elements of theviewbox
The minimum Y of the property is aligned with the minimum Y of the view. - xMaxYMin– Force uniform scaling. will
SVG
Elements of theviewbox
The minimum value of X of the attribute + the width of the element is aligned with the maximum value of X of the view. willSVG
Elements of theviewbox
The minimum Y of the property is aligned with the minimum Y of the view. - xMinYMid– Force uniform scaling. will
SVG
Elements of theviewbox
The minimum value of X of the property is aligned with the minimum value of X of the view. willSVG
Elements of theviewbox
The midpoint value of Y of the property is aligned with the midpoint value of Y of the view. - xMidYMid(Default) – Force uniform scaling. will
SVG
Elements of theviewbox
The midpoint value of X of the property is aligned with the midpoint value of X of the view. willSVG
Elements of theviewbox
The midpoint value of Y of the property is aligned with the midpoint value of Y of the view. - xMaxYMid– Force uniform scaling. will
SVG
Elements of theviewbox
The minimum value of X of the attribute + the width of the element is aligned with the maximum value of X of the view. willSVG
Elements of theviewbox
The midpoint value of Y of the property is aligned with the midpoint value of Y of the view. - xMinYMax– Force uniform scaling. will
SVG
Elements of theviewbox
The minimum value of X of the property is aligned with the minimum value of X of the view. Will SVG elementviewbox
The minimum value of Y of the attribute + the height of the element is aligned with the maximum value of Y of the view. - xMidYMax– Force uniform scaling. will
SVG
Elements of theviewbox
The midpoint value of X of the property is aligned with the midpoint value of X of the view. willSVG
Elements of theviewbox
The minimum value of Y of the attribute + the height of the element is aligned with the maximum value of Y of the view. - xMaxYMax– Force uniform scaling. will
SVG
Elements of theviewbox
The minimum value of X of the attribute + the width of the element is aligned with the maximum value of X of the view. willSVG
Elements of theviewbox
The minimum value of Y of the attribute + the height of the element is aligned with the maximum value of Y of the view.
The second argument is optional. If you want to enter the second argument, you need to use a space after the first argument to separate the two arguments.
-
Meet (default) – The graph will scale to:
- The aspect ratio will be retained
- The whole
SVG
theviewbox
It is visible within the scope of the view - Zoom in as much as possible
SVG
theviewbox
While still satisfying the other conditions.
In this case, if the aspect ratio of the graph does not match the view window, then some views will be out of viewbox (i.e. the VIEWbox view of SVG will be smaller than the visible window).
-
The slice graph will scale to:
- The aspect ratio will be retained
- The entire view window will be overwritten
viewbox
SVG
theviewbox
The properties will be narrowed down as much as possible, but still meet other criteria.
In this case, if the ASPECT ratio of the SVG viewbox does not match the visible area, then some areas of the viewbox will extend outside the view window (that is, the SVG viewbox will be larger than the visible window).
After understanding this property and its parameters, we modify the example above to make the canvas scale 1:2. Now the height of the canvas has changed and the circle is centered vertically
<svg width="200" height="400" viewBox="0 0 400 400"></svg>
<circle cx="200" cy="200" r="200" fill="#f00" stroke="none"></circle>
</svg>
Copy the code
Now that the proportions of the canvas and viewBox are different, you can see that our circle is centered. At this point we will configure the preserveAspectRatio property so that the element is left aligned. That’s the xMinxMin value.
<svg width="200" height="400" viewBox="0 0 400 400" preserveAspectRatio="xMinYMin">
<circle cx="200" cy="200" r="200" fill="#f00" stroke="none"></circle>
</svg>
Copy the code
The last
This article describes SVG positioning systems and the basic use of viewBox properties and preserveAspectRatio in SVG tags. Thanks for reading!
😀😀 Pay attention to me, don’t get lost! 😀 😀