Coordinate system
SVG has two coordinate systems: the window coordinate system and the user coordinate system. By default, the points in the user coordinate system and the view window coordinate system are in one-to-one correspondence, with the origin at the upper left corner of the view window, the x-axis horizontally to the right, and the y-axis vertically downward; as shown in the figure below:
The window position of SVG is generally specified by CSS, and the size is set by the width and height attributes of the SVG element. However, if the SVG is stored in an embedded object (such as an object element, or other SVG element), and the document containing the SVG is Formatted with CSS or XSL, and the CSS or other specified size values of these surrounding objects can already calculate the size of the viewport, the size of the surrounding object will be used at this time.
Here we need to distinguish between the concepts of window, window coordinate system and user coordinate system:
Window: refers to the visible rectangular area on the web page. The length and width are limited. This area is generally related to the size of the surrounding objects.
View window coordinate system: It is essentially a coordinate system with an origin, x-axis and y-axis; and it extends infinitely in two directions. By default, the origin is at the upper left corner of the viewport, the x-axis is horizontally to the right, and the y-axis is vertically downward. Points in this coordinate system can be transformed.
User coordinate system : It is essentially a coordinate system with an origin, x-axis and y-axis; and it extends infinitely in two directions. By default, the origin is at the upper left corner of the viewport, the x-axis is horizontally to the right, and the y-axis is vertically downward. Points in this coordinate system can be transformed.
By default, the window coordinate system coincides with the user coordinate system, but it should be noted here that the window coordinate system belongs to the element that creates the window. After the window coordinate system is determined, the coordinate tone of the entire window is determined. However, the user coordinate system belongs to each graphic element. As long as the graphics undergoes coordinate transformation, a new user coordinate system will be created. All coordinates and dimensions in this element use this new user coordinate system.
To put it simply: the window coordinate system describes the initial coordinate profile of all elements in the window, and the user coordinate system describes the coordinate profile of each element. By default, all elements use the default coordinate system that coincides with the window coordinate system. User coordinate system.
Coordinate space transformation
Let us review the transformation of canvas user coordinates. They are implemented through translation, scaling, and rotation functions; after each transformation, subsequent drawings The graphics work unless transformed again, which is the concept of the "current" user coordinate system. Canvas has only one user coordinate system.
In SVG, the situation is completely different. SVG itself is a vector graphic element, and its two coordinate systems can essentially be counted as "user coordinate systems"; both coordinate spaces of SVG can be transformed: window space transformation and user space transformation. Window space transformation is controlled by the viewBox attribute of the relevant elements (these elements create new windows); user space transformation is controlled by the transform attribute of the graphic element. View-space transformations are applied to the corresponding entire viewport, and user-space transformations are applied to the current element and its sub-elements.
View window transformation - viewBox property
All elements that can create a window (see the next section), plus marker, pattern, and view elements, have a viewBox attribute.
The format of the viewBox attribute value is (x0, y0, u_width, u_height). Each value is separated by commas or spaces. Together they determine the area displayed by the window: the coordinates of the upper left corner of the window are set to (x0, y0 ), the width of the window is set to u_width, and the height is u_height; this transformation affects the entire window.
Don’t be confused here: the size and position of the window have been determined by the element that creates the window and the surrounding elements (for example, the window created by the outermost svg element is determined by CSS, width and height), here The viewBox actually sets which part of the view window coordinate system can be displayed in this determined area.
The setting of viewBox actually includes two transformations: scaling and translation of the view window space.
The calculation of the transformation is also very simple: take the view window of the outermost svg element as an example, assuming that the width and length of the svg are set to width, height, and the viewBox is set to (x0, y0, u_width, u_height). Then the scaling ratios of the width and height of the drawn graphics are: width/u_width, height/u_height respectively. The coordinates of the upper left corner of the window are set to (x0,y0).
Experience the difference in the results drawn by the following codes:
In daily work, one of the tasks we often need to complete is to scale a group of graphics so that it fits its parent container. We can achieve this goal by setting the viewBox attribute.
Elements that create new windows
We can nest windows at any time. When a new window is created, a new window coordinate system and user coordinate system will also be created. Of course, new clipping paths will also be created. The following is a list of elements that can create new windows:
svg: svg supports nesting.
symbol: Creates a new window when instantiated by the use element.
image: A new window will be created when referencing the svg element.
foreignObject: Create a new window to render the objects inside.
Preserve the zoom ratio - preserveAspectRatio attribute
Sometimes, especially when using viewBox, we expect the graphics to occupy the entire view window, rather than pressing in both directions Same scaling. Sometimes, we want the graphics to be scaled at a fixed ratio in both directions. You can control this using the attribute preserveAspectRatio.
This attribute is available to all elements that can create a new window, plus image, marker, pattern, and view elements. And the preserveAspectRatio attribute will only take effect after the viewBox is set on the element. If the viewBox is not set, the preserveAspectRatio attribute is ignored.
The syntax of the attribute is as follows: preserveAspectRatio="[defer]
defer: Optional parameter, only valid for image elements. If the value of the preserveAspectRatio attribute in the image element starts with "defer", it means that the image element uses the scaling ratio of the referenced image, if it is referenced If the image has no scaling, "defer" is ignored. All other elements ignore this string.
align: This parameter determines the alignment of unified scaling, and can take the following values:
none - does not force unified scaling, so that the graphics can completely fill the entire viewport.
xMinYMin - Forces uniform scaling and aligns the
xMidYMin - Forces uniform scaling, and aligns the midpoint in the X direction of the vivowBox to the midpoint of the X direction in the viewport. In short, the midpoint in the X direction is aligned, and the Y direction is the same as above.
xMaxYMin - Forces uniform scaling and aligns the
Similar to other types of values: xMinYMid, xMidYMid, xMaxYMid, xMinYMax, xMidYMax, xMaxYMax. The meanings of these combinations are similar to those above.
meetOrSlice: optional parameter, you can set the following values:
meet - the default value, scale the graphics uniformly, so that all graphics are displayed in the viewport.
slice - Scale the graphics uniformly so that the graphics fills the viewport, and the excess parts are clipped.
The following picture illustrates the effects of various fillings:
Transformation of user coordinate system - transform attribute
This type of transformation is specified by setting the transform attribute of the element. It should be noted here that the transformation of the element set by the transform attribute only affects the element and its sub-elements, and has nothing to do with other elements and does not affect other elements.
Translation - translate
Translation transformation translates the relevant coordinate value to the specified position. This transformation requires passing in the amount of translation on both axes. Look at the example:
Rotation - rotate
Rotating an element is also a very common task. We can use the rotate transformation to implement it, which requires passing in the angle parameter of the rotation. Look at the example:
skew - skew
transform also supports tilt transformation, which can be along the x-axis (tilt left and right, a positive angle is tilted to the right, which actually tilts y axis), or tilt along the y-axis (tilt up and down, a positive angle means downward tilt, which actually tilts the x-axis); this transformation requires passing in an angle parameter, which determines the angle of tilt. Look at the example below:
Scale - scale
The scaling object is completed by the scaling transformation, which accepts 2 parameters, specifying the horizontal and vertical scaling ratios respectively. If the second If two parameters are omitted, it takes the same value as the first parameter. Look at the example below:
Translation transformation [1 0 1 0 tx ty]:
Transform chain
The transform attribute supports setting multiple transformations. These transformations only need to be separated by spaces and then placed together in the attribute. The execution effect is the same as executing these transformations independently in sequence.
Values without units are considered to have "user units", which are the unit values of the current user coordinate system.
With units
The relevant units in svg are the same as in CSS: em, ex, px, pt, pc, cm, mm and in. You can also use "%" for length.
Relative measurement units: em and ex are the same as in CSS, they are relative to the font-size and x-height of the current font.
Absolute measurement unit: One px is equal to one "user unit", that is, "5px" and "5" are the same. But whether a px corresponds to a pixel depends on whether some transformation has been performed.
The other units are basically multiples of px: 1pt=1.25px, 1pc=15px, 1mm=3.543307px, 1cm=35.43307px, 1in=90px.
If the width and height of the outermost SVG element do not specify a unit (that is, "user unit"), these values will be considered to be in px.
This article is a bit confusing. In fact, just remember that "the coordinates and length of graphic elements refer to the coordinates and length of the new user coordinate system after double transformation of the window coordinate system transformation and the user coordinate system transformation." That’s it.
Practical reference:
Script index: http://msdn.microsoft.com/zh-cn/library/ff971910(v=vs.85).aspx
Development Center: https://developer.mozilla.org/en/SVG
Popular Reference: http://www.chinasvg.com/
Official documentation: http://www.w3.org/TR/SVG11/