[SVG] for the beauty of the front page, I choose to learn SVG
Blog description
The information involved in this article comes from the Internet and personal summary, which means the summary of personal learning and experience. If there is any infringement, please contact me to delete it. Thank you!
explain
In the process of self-study before, SVG has always been very profound and dare not touch, but it will come to this step if you want to understand. No matter how difficult the technology seems, it is accumulated by simple knowledge points.
What is SVG?
- SVG means Scalable Vector Graphics.
- It uses XML format to define images.
- When the SVG image is enlarged or the size is changed, the graphics quality will not be lost.
- SVG is the standard of the World Wide Web Consortium.
- SVG is integrated with W3C standards such as DOM and XSL.
Generally speaking, SVG is a file defined by XML. Because it is vector graphics, its graphics quality is very high.
Because SVG is an XML file, SVG images can be created with any text editor, but complex graphics still have to use graphics editing tools
Advantages of SVG
- SVG can be read and modified by many tools (such as Notepad).
- SVG is smaller and more compressible than JPEG and GIF images.
- SVG is scalable.
- SVG images can be printed with high quality at any resolution.
- The SVG can be enlarged without degradation of image quality.
- The text in the SVG image is optional and searchable (very suitable for making maps).
- SVG is an open standard.
- SVG files are pure XML.
Svg's main competitor is flash. Compared with flash, the biggest advantage of SVG is its compatibility with other standards, such as XSL and DOM. Flash is a private technology that is not open source.
A small example
Sample code
<?xml version="1.0" standalone="no"?> <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> <svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="red" /> </svg>
effect
Code parsing
- The first line of < XML > contains the XML declaration.
- The standalone attribute specifies whether the SVG file is "independent" or contains a reference to an external file. standalone="no" means that the SVG document will reference an external file - in this case, a DTD file.
- < SVG > and < / SVG > represent SVG code, equivalent to start tag and end tag, which are root elements.
- The width and height properties set the width and height of this SVG document.
- The version attribute defines the SVG version used.
- The xmlns attribute defines the SVG namespace.
- < circle > is used to create a circle. The cx and cy attributes define the x and y coordinates of the center of the circle. If these two properties are ignored, the dot is set to (0, 0). The r attribute defines the radius of the circle.
- The stroke and stroke width properties control how the outline of the shape is displayed. We set the outline of the circle to 2px wide with a black border.
- The fill property sets the color within the shape. We set the fill color to red.
- The close tag closes the SVG element and the document itself.
Note: all opening labels must have closing labels!
How to use SVG in HTML?
SVG files can be embedded in HTML documents in five ways: < img >, < embedded >, < Object >, < iframe >, and directly embedded in HTML code.
Use < img > tags
It is introduced as a picture and background
Syntax:
<img src="circle1.svg" alt=""/>
Use the < embedded > tag
- Advantage: all major browsers support and allow the use of scripts
- Disadvantages: not recommended in HTML4 and XHTML (but allowed in HTML5)
Syntax:
<embed src="circle1.svg" type="image/svg+xml" />
Use < Object > tag
- Advantages: all major browsers support and support HTML4, XHTML and HTML5 standards
- Disadvantages: scripts are not allowed.
Syntax:
<object data="circle1.svg" type="image/svg+xml"></object>
Use < iframe > tags
- Advantage: all major browsers support and allow the use of scripts
- Disadvantages: not recommended in HTML4 and XHTML (but allowed in HTML5)
Syntax:
<iframe src="circle1.svg"></iframe>
Embed SVG code directly in HTML
- Advantages: easy operation and dynamic adjustment
- Disadvantages: HTML pages are too verbose and not coding friendly
Syntax:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="red" /> </svg>
Basic shape of SVG
Rectangle < rect >
Example 1:
Normal rectangle
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <rect width="300" height="100" style="fill:rgb(122,122,0);stroke-width:2;stroke:rgb(0,0,0)" /> </svg>
effect:
Code parsing:
- The width and height attributes of the rect element define the height and width of the rectangle
- The style property is used to define CSS properties
- The fill property of CSS defines the fill color of the rectangle (rgb value, color name, or hexadecimal value)
- The stroke width property of CSS defines the width of the rectangular border
- The stroke property of CSS defines the color of the rectangular border
Example 2:
Transparency of fills and borders
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <rect x="50" y="20" width="150" height="150" style="fill:blue;stroke:red;stroke-width:5;fill-opacity:0.5;stroke-opacity:0.5" /> </svg>
effect:
Code parsing:
- The X attribute defines the left position of the rectangle (for example, x="0" defines that the distance from the rectangle to the left of the browser window is 0px)
- The Y attribute defines the top position of the rectangle (for example, y="0" defines that the distance from the rectangle to the top of the browser window is 0px)
- The fill opacity property of CSS defines the fill color transparency (legal range: 0 - 1)
- The stroke opacity property of CSS defines the transparency of outline color (legal range: 0 - 1)
Example 3:
Transparency of the entire element
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="500px" height="500px"> <rect x="50" y="20" width="150" height="150" style="fill:blue;stroke:pink;stroke-width:5;opacity:0.4" /> </svg>
effect:
Code parsing:
- The CSS opacity property defines the transparent value of the element (range: 0 to 1).
Example 4:
Rounded rectangle
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="500px" height="500px"> <rect x="50" y="20" rx="20" ry="20" width="150" height="160" style="fill:red;stroke:black;stroke-width:1;opacity:0.5" /> </svg>
effect:
Code parsing:
- The rx and ry attributes round the rectangle.
Circular < circle >
Example:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <circle cx="100" cy="50" r="40" stroke="red" stroke-width="2" fill="blue" /> </svg>
effect:
Code parsing:
- The circle label can be used to create a circle
- The cx and cy attributes define the x and y coordinates of the dot. If cx and cy are omitted, the center of the circle is set to (0, 0)
- The r attribute defines the radius of the circle
Ellipse < ellipse >
Example:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="500" height="500"> <ellipse cx="300" cy="80" rx="100" ry="50" style="fill:red;stroke:purple;stroke-width:2" /> </svg>
effect:
Code parsing:
- The ellipse tag can be used to create an ellipse
- The x coordinate of the center of the ellipse defined by the CX attribute
- y coordinate of the ellipse center defined by CY attribute
- Horizontal radius defined by RX attribute
- The vertical radius defined by the RY attribute
Line < line >
Example:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <line x1="0" y1="0" x2="200" y2="200" style="stroke:black;stroke-width:5" /> </svg>
effect:
Code parsing:
- The line label can be used to create a line
- The x1 attribute defines the beginning of the line on the x axis
- The y1 attribute defines the beginning of the line on the y axis
- The x2 attribute defines the end of the line on the x axis
- The y2 attribute defines the end of the line on the y axis
Polyline < polyline >
Example 1:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <polyline points="20,20 40,25 60,40 80,10 120,140 200,180" style="fill:none;stroke:black;stroke-width:3" /> </svg>
effect:
Code parsing:
- polyline is used to create any shape with only lines
- Points is a collection of points
Example 2:
Draw a five pointed star
<svg style="height:300px;width:300px;" xmlns="http://www.w3.org/2000/svg" version="1.1"> <polyline points="100 10,40 180,190 60,10 60,160 180" style="fill:blue;stroke:blue;stroke-width:1" /> </svg>
effect:
Code parsing:
Fill in the blanks is used because the segments are not closed
Polygon < polygon >
Example 1:
<svg height="210" width="500"> <polygon points="200,10 250,190 160,210" style="fill:red;stroke:purple;stroke-width:1"/> </svg>
effect:
Code parsing:
- polygon labels are used to create shapes with no less than three edges
- Points is a collection of points
Example 2:
Draw a five pointed star
<svg style="height:300px;width:300px;" xmlns="http://www.w3.org/2000/svg" version="1.1"> <polygon points="100 10,40 180,190 60,10 60,160 180" style="fill:none;stroke:black;stroke-width:5"/> </svg>
effect:
Code parsing:
The last point will close automatically, which is also a difference from polyline
Path < Path >
Path data:
- M = moveto
- L = lineto
- H = horizontal lineto
- V = vertical lineto
- C = curveto
- S = smooth curveto
- Q = quadratic Bézier curve
- T = smooth quadratic Bézier curveto
- A = elliptical Arc
- Z = closepath
Example:
Draw a triangle
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <path d="M150 0 L75 200 L205 270 Z" /> </svg>
effect:
Code parsing:
A path is defined, which starts at position 150 0, reaches position 75 200, then starts there to 205 270, and finally closes the path at 150 0.
summary
The basic part of SVG has been introduced, but the application of path has just begun. We will talk about path in detail later. Of course, there are some "advanced" properties of SVG.
In fact, all the way down, we found that the operation of SVG is roughly similar to the principle of using PS, AI and other drawing tools, which is also helpful for us to understand the drawing of such graphics.
thank
Universal network
And hard-working themselves, Personal blog,GitHub test,GitHub
The official account - the son of the Mo, a small program - little blog