当前位置:网站首页>An article will take you to understand SVG gradient knowledge

An article will take you to understand SVG gradient knowledge

2020-11-06 20:42:00 Python advanced

Gradient is a smooth transition from one color to another . in addition , You can apply transitions of multiple colors to the same element .

SVG There are two main types of gradients :(Linear,Radial).

One 、SVG Linear gradient

<linearGradient> Element is used to define linear gradients .

<linearGradient> Tags must be nested in <defs> Internal .<defs> The label is definitions Abbreviation , You can define special elements such as gradients .

Linear gradients can be defined as horizontal , Vertical or angular gradients .

/*y1 and y2 equal , and x1 and x2 Different time , You can create horizontal gradients .

 When x1 and x2 equal , and y1 and y2 Different time , You can create vertical gradients .

 When x1 and x2 Different , And y1 and y2 Different time , You can create angular gradients .*/

example 1

Define the horizontal linear gradient from yellow to red ellipse .

SVG Code

<!DOCTYPE html>
<html>
<body style="background-color: aqua;">
<title> project </title>
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<defs>
<linearGradient id="grad1" x1="0%" y1="0%" x2="100%" y2="0%">
<stop offset="0%" style="stop-color:rgb(255,255,0);stop-opacity:1" />
<stop offset="100%" style="stop-color:rgb(255,0,0);stop-opacity:1" />
</linearGradient>
</defs>
<ellipse cx="200" cy="70" rx="85" ry="55" fill="url(#grad1)" />
</svg>
</body>
</html>

Running effect :

Code parsing :

  1. <linearGradient> Labeled id Property defines a unique name for the gradient .

  2. <linearGradient> Labeled X1,X2,Y1,Y2 Property defines where the gradient starts and ends .

  3. The gradient's color range can be made up of two or more colors , Each color passes through a <stop> Label to specify .offset Property defines the start and end of the gradient .

  4. Fill in the attribute to put ellipse Elements are linked to this gradient .

example 2

Define an ellipse with a vertical linear gradient from yellow to red .

SVG Code :

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<defs>
<linearGradient id="grad1" x1="0%" y1="0%" x2="0%" y2="100%">
<stop offset="0%" style="stop-color:rgb(255,255,0);stop-opacity:1" />
<stop offset="100%" style="stop-color:rgb(255,0,0);stop-opacity:1" />
</linearGradient>
</defs>
<ellipse cx="200" cy="70" rx="85" ry="55" fill="url(#grad1)" />
</svg>

Running effect :

example 3

Define an ellipse , Horizontal linear gradient from yellow to red and adds an ellipse inner text .

SVG Code :

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<defs>
<linearGradient id="grad1" x1="0%" y1="0%" x2="100%" y2="0%">
<stop offset="0%" style="stop-color:rgb(255,255,0);stop-opacity:1" />
<stop offset="100%" style="stop-color:rgb(255,0,0);stop-opacity:1" />
</linearGradient>
</defs>
<ellipse cx="200" cy="70" rx="85" ry="55" fill="url(#grad1)" /> <text fill="#000" font-size="45" font-family="Verdana"
 x="150" y="86"> SVG</text>
</svg>

Running effect :

Code parsing :

<text> Element is used to add a text .

Two 、SVG Radioactive gradients

<radialGradient> Element is used to define radioactive gradients .

<radialGradient> Tags must be nested in <defs> Internal .<defs> The label is definitions Abbreviation , It defines special elements such as gradients .

example 1

Define a radioactive gradient from white to blue ellipse .

SVG Code :

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<defs>
<radialGradient id="grad1" cx="50%" cy="50%" r="50%" fx="50%" fy="50%">
<stop offset="0%" style="stop-color:rgb(255,255,255);
     stop-opacity:0" />
<stop offset="100%" style="stop-color:rgb(0,0,255);stop-opacity:1" />
</radialGradient>
</defs>
<ellipse cx="200" cy="70" rx="85" ry="55" fill="url(#grad1)" />
</svg>

Running effect :

Code parsing :

  1. <radialGradient> Labeled id Property defines a unique name for the gradient .

  2. CX,CY and r The outermost circle and of the attribute definition Fx and Fy The innermost circle defined .

  3. The gradient color range can be made up of two or more colors . Use one for each color <stop> Tag specified .offset Property is used to define the beginning and end of the gradient .

  4. Fill in the attribute to put ellipse Elements are linked to this gradient .

example 2

Define another ellipse of radioactive gradients from white to blue .

SVG Code :

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">  <defs>    <radialGradient id="grad1" cx="20%" cy="30%" r="30%"
 fx="50%" fy="50%">     
<stop offset="0%" style="stop-color:rgb(255,255,255); stop-opacity:0" />     
<stop offset="100%" style="stop-color:rgb(0,0,255);stop-opacity:1" />    
</radialGradient>  
</defs> 
<ellipse cx="200" cy="70" rx="85" ry="55" fill="url(#grad1)" />
</svg>

Running effect :

3、 ... and 、 summary

This article is based on HTML Basics , It introduces images SVG Gradient effects in elements , Through case analysis , What should be noticed in the actual project , Parse the code . The problems encountered in the development project , All of them provide some effective solutions .

Welcome to try , Sometimes it's easy to see someone else do it , But when it comes to doing it yourself , There will always be all kinds of problems , Don't hold your eyes high or your hands low , Do it frequently , Can understand more deeply .

The code is simple , Hope to help readers to learn better SVG.

Want to learn more Python Web crawler and data mining knowledge , Go to a professional website :http://pdcfighting.com/ Want to learn more Python Web crawler and data mining knowledge , Go to a professional website :http://pdcfighting.com/

版权声明
本文为[Python advanced]所创,转载请带上原文链接,感谢