目录

SVG 学习<一>基础图形及线段

SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组

SVG 学习<三>渐变

SVG 学习<四> 基础API

SVG 学习<五> SVG动画

SVG 学习<六> SVG的transform

SVG 学习<七> SVG的路径——path(1)直线命令、弧线命令

SVG 学习<八> SVG的路径——path(2)贝塞尔曲线命令、光滑贝塞尔曲线命令

(转)利用 SVG 和 CSS3 实现有趣的边框动画

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

SVG的视窗,视野和全局(世界)

SVG全局(世界)是无穷大的(SVG的全局并不局限于html的范围);

例:

    <svg width="100%" height="100%" style="border: solid 1px red;">
<circle cx="100" cy="100" fill="green" r="200" />
</svg>

上述代码绘制了一个半径为200px的圆,圆心坐标为100 * 100,SVG标签(视窗)占满整个浏览器。但从下图中可以看到圆形还是有一部分在屏幕之外,所以SVG的全局(世界)是无穷大且不受任何元素的影响。

SVG的视野(viewbox)是观察全局(世界)的一个矩形区域,可定义。

例:

    <svg width="500px" height="400px" viewbox="-15 -20 80 80" style="border: solid 1px red;display: block;margin-left:200px;">
<circle cx="0" cy="0" fill="green" r="20" />
</svg>

通过viewbox属性来调整SVG视野;

viewbox=" x y width height "   x:左上角横坐标,y:左上角纵坐标,width:宽度,height:高度;

viewbox的参数可以自己动手做几个demo体会这些参数的作用;

SVG标签的 width height可自定义大小,这就是SVG的视窗。SVG视窗可以理解为在页面中定义一片区域用来渲染SVG元素。

例:

    <svg width="500px" height="400px" style="border: solid 1px red;display: block;margin-left:200px;">
<circle cx="100" cy="100" fill="green" r="200" />
</svg>

同样还是刚才那个圆,现在将SVG标签的左边距调整200像素。发现圆心相对于SVG视窗的位置没变,但相对于屏幕左上角的位置变了。所以说SVG视窗是页面中用来渲染SVG元素的。

小结:SVG全局(世界)可以理解为景,SVG视野可以理解为相片视野,SVG视窗可以理解为相片本身。

SVG分组——g标签

g标签在svg标签内使用,功能用来对图形,文字,线段进行分组。

分组可以对一组SVG元素统一调整 填充色,笔触色,坐标等属性。

g标签下所有子标签都将继承g标签的属性;

g标签可嵌套使用;

可通过定义transform属性改变坐标;

HTML代码

    <svg class="svg">
<g class="g_1">
<rect x="20" y="20"/><rect x="240" y="20" />
</g>
<g class="g_2">
<circle cx="100" cy="200" /><circle cx="220" cy="200" />
</g>
</svg>

CSS代码

.g_1{
stroke:rgb(0,0,0);
stroke-width:2px;
fill:rgb(0,255,255);
}
rect{ width:200px; height:100px; }
.g_2{
stroke:rgb(220,17,20);
stroke-width:2px;
fill:rgb(255,255,255);
}
circle{ r:50px; }

g标签可以对一组图形,文字或线段的笔触色,填充色,笔触宽度进行统一定义

SVG超链接——图形,线段也能链接

HTML代码

    <svg class="svg">
<a xlink:href="http://www.baidu.com" target="_blank">
<circle class="circle" />
</a>
</svg>

CSS代码

.circle{ cx:100px;cy:100px;fill:rgb(0,0,255);stroke-width:;stroke:rgb(0,255,0);r:80px; }

svg标签中可加入a标签,但href属性前必须加上xlink,svg是xhtml元素超链接必须加上xlink。

同理,svg中的a标签可以包含任何svg元素。

SVG的stroke属性(SVG的画笔)

stroke : 定义笔触颜色;

stroke-width : 定义笔触宽度;

stroke-linecap : 定义线段两端样式;

stroke-dasharray : 定义虚线样式;

HTML代码

    <svg class="svg">
<g fill="none">
<line stroke="rgb(255,0,0)" stroke-width="5" x1="2" y1="5" x2="202" y2="5"/>
<line stroke="rgb(0,255,0)" stroke-width="10" x1="2" y1="25" x2="202" y2="25"/>
<line stroke="rgb(0,0,255)" stroke-width="15" x1="2" y1="55" x2="202" y2="55"/>
</g>
</svg>

HTML代码

    <svg class="svg">
<g fill="none" stroke="rgb(0,255,221)" stroke-width="50">
<line stroke-linecap="butt" x1="50" y1="50" x2="552" y2="50"/>
<line stroke-linecap="round" x1="50" y1="150" x2="552" y2="150"/>
<line stroke-linecap="square" x1="50" y1="250" x2="552" y2="250"/>
</g>
</svg>

HTML代码

    <svg class="svg">
<g fill="none" stroke="rgb(0,255,221)" stroke-width="10">
<line stroke-dasharray="2,2" x1="50" y1="50" x2="552" y2="50"/>
<line stroke-dasharray="20,20" x1="50" y1="150" x2="552" y2="150"/>
<line stroke-dasharray="20,10,30,10,20,30" x1="50" y1="250" x2="552" y2="250"/>
<line stroke-dasharray="5,20,10,20,15,20,20,20,25,20,30,20,35" x1="50" y1="350" x2="552" y2="350"/>
</g>
</svg>

stroke-dasharray定义虚线方式,建议值为规律性数列。

SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组的更多相关文章

  1. SVG 学习<八> SVG的路径——path(2)贝塞尔曲线命令、光滑贝塞尔曲线命令

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  2. SVG 学习<七> SVG的路径——path(1)直线命令、弧线命令

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  3. SVG 学习<六> SVG的transform

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  4. SVG 学习<五> SVG动画

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  5. SVG 学习<四> 基础API

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  6. SVG 学习<三>渐变

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  7. SVG 学习<一>基础图形及线段

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  8. SVG Stroke属性

    一.stroke属性介绍 SVG提供了一个范围广泛stroke属性,用于描述轮廓,其中包括 stroke 指定颜色 stroke-width 指定宽度 stroke-linecap 指定端点样式 st ...

  9. SVG学习笔录(二)

    一.svg动画SMIL SVG采用的是使用文本来定义图形,这种文档结构非常适合于创建动画.要改变图形的位置.大小和颜色,只需要调整相应的属性就可以了.事实上,SVG有为各种事件处理而专门设计的属性,甚 ...

随机推荐

  1. python编码encode decode(解惑)

    关于python 字符串编码一直没有搞清楚,今天总结了一下. Python 字符串类型 Python有两种字符串类型:str 与 unicode. 字符串实例 # -*- coding: utf-8 ...

  2. Flume 拦截器(interceptor)详解

    flume 拦截器(interceptor)1.flume拦截器介绍拦截器是简单的插件式组件,设置在source和channel之间.source接收到的事件event,在写入channel之前,拦截 ...

  3. hadoop行业技术创新解决方案

    如今有很多公司都在努力挖掘他们拥有的大量数据,包括结构化.非结构化.半结构化以及二进制数据等,来探索对数据的深入利用. 大多数公司估计他们只分析了已有数据的12%,剩余88%还没有被充分利用.大量的数 ...

  4. RedHat7安装vmware虚拟机启动报错

    提示错误如下: Kernel Headers for version 3.10.0-229.14.1.el7.x86_64 were not found.If you.... 安装kernel dev ...

  5. 【设计模式】JDK源码中用到的设计模式

    https://blog.csdn.net/angjunqiang/article/details/42061453 https://blog.csdn.net/baiye_xing/article/ ...

  6. mybatis源码阅读心得

    第一天阅读源码及创建时序图.(第一次用prosson画时序图,挺丑..) 1.  调用 SqlSessionFactoryBuilder 对象的 build(inputStream) 方法: 2.   ...

  7. python slave status 2

    #!/usr/bin/env python import MySQLdbimport contextlib @contextlib.contextmanagerdef mysql(Host,Port, ...

  8. Jquery模板-----JsRender

    重新排版与堂堂88 先看下简单示例: <script type="type='text/html'" id="jianren"> <div c ...

  9. 不可小视的String字符串

    String印象 String是java中的无处不在的类,使用也很简单.初学java,就已经有字符串是不可变的盖棺定论,解释通常是:它是final的. 不过,String是有字面量这一说法的,这是其他 ...

  10. tomcat源码 StandardService

    在执行StandardServer的initInternal的时候会执行StandardService#init,然后会调到initInternal protected void startInter ...