data:image/s3,"s3://crabby-images/fe065/fe065da59249aed25af9b0343d10fbc65f2e49a6" alt="Mastering SVG"
stroke-opacity
The stroke-opacity attribute does what you might expect. It sets the opacity of a stroked object. The following sample sets three different opacities on three separate rectangles. You can see stroke interact not just with the background of the page, but with the fill of the rectangle as well, as stroke is centered on the edge of the rectangle and part of it covers the filled-in area:
<svg width="400" height="300" viewBox="0 0 400 300"
xmlns="http://www.w3.org/2000/svg">
<rect x="50" y="20" width="300" height="50" fill="none"
stroke="#000000" stroke-width="20" stroke-opacity=".25"></rect>
<rect x="50" y="100" width="300" height="50" fill="none"
stroke="#000000" stroke-width="20" stroke-opacity=".5"></rect>
<rect x="50" y="180" width="300" height="50" fill="none"
stroke="#000000" stroke-width="20" stroke-opacity="1"></rect>
</svg>
The output of the preceding code can be seen in the following screenshot:
data:image/s3,"s3://crabby-images/7a63f/7a63f9c4c37827663e3968a31239a6ab0567aba3" alt=""
Now that we've looked at the different options for strokes, it's time to look at some of the other options for fills. These are the paint server elements that we mentioned before. You've already encountered one of them, linearGradient. You'll also learn about two others that are commonly used, radialGradient and pattern.