01.svg的嵌入.html

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="author" content="李可">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>svg的嵌入方式</title>
</head> <body>
<h1>svg的6种嵌入方式</h1>
<!-- svg、图片、背景、iframe、object、embed 、--> <!-- 直接写svg -->
<svg width="200" height="200" viewBox="0 0 200 200" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<circle cx="100" cy="100" r="20" fill="red" />
</svg> <!-- img -->
<img src="svg.svg" alt=""> <!-- background -->
<div style="width:200px;height:200px;display:inline-block;background-image:url('svg.svg')"></div> <!-- iframe -->
<iframe src="svg.svg"></iframe> <!-- embed pluginspage下插件-->
<embed src="svg.svg" width="200" height="200" type="image/svg+xml" pluginspage="http://www.adobe.com/svg/viewer/install/"/> <!-- object codebase下插件-->
<object data="svg.svg" width="200" height="200" type="image/svg+xml" codebase="http://www.adobe.com/svg/viewer/install/"/>
</body> </html>

运行

02.svg基本图形.html

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="author" content="李可">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>6种基本图形</title>
</head> <body>
<!-- 起点 终点 对应的x,y像定位后的left top值-->
<!-- 6种基本图形line, rect, ellipse, circle, polyline, polygon-->
<!-- points'空格'或者'逗号' 像path(路径)/polyline(折线)/polygon(多边形)都用到多点(points)-->
<!-- 折线 不闭合。多边形闭合-->
<svg width="1000" height="1000" viewBox="0 0 1000 1000" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <!-- 线 起点 终点 -->
<line x1="0" y1="0" x2="100" y2="100" stroke="black" stroke-width="2"/> <!-- 矩形 起点(左上角) 宽高 -->
<rect x="100" y="0" width="150" height="100"/> <!-- 圆 中心点 半径 -->
<circle cx="300" cy="50" r="50" /> <!-- 椭圆 中心点 x y半径-->
<ellipse cx="425" cy="50" rx="75" ry="50"/> <!-- 折线 多个点(逗号或者空格) -->
<!-- 多条线连接起来角,没有棱角 -->
<polyline points="500 0 600 50 550 100" fill='none' stroke="black" stroke-width="20"/>
<line x1="500" y1="100" x2="600" y2="150" stroke="black" stroke-width="20"/>
<line x1="600" y1="150" x2="550" y2="200" stroke="black" stroke-width="20"/> <!-- (首尾闭合的折线) 多边形 多点(逗号或者空格) -->
<polygon points="600,0,700,50,650,100" fill='none' stroke="black" stroke-width="2"/>
</svg> </body> </html>

运行

03.svg基本样式.html

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="author" content="李可">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>基本样式</title>
</head> <body>
<!--
位置(x,y,r)的属性不能写到style里面,其余可以 width height rect拥有这样的属性
fill="red" 默认填充黑色色(常用transparent,none)
stroke="black" 边框色
stroke-width="2" 边框宽
-->
<!--拿circle举例子-->
<svg width="1000" height="1000" viewBox="0 0 1000 1000" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<!-- 圆 中心点 半径 -->
<circle cx="50" cy="50" r="50" fill="red" stroke="black" stroke-width="2"/>
<circle cx="50" cy="150" r="50" style="fill:transparent; stroke:black; stroke-width:2;"/>
</svg> </body> </html>

运行

04.svg用js操作.html

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="author" content="李可">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>js操作svg</title>
</head> <body>
<script>
let getTag = (name, attrs) => {
let svg = document.createElementNS('http://www.w3.org/2000/svg', name);
for (var attr in attrs) {
//这里全部使用属性,并没有使用样式
svg.setAttribute(attr, attrs[attr])
}
return svg;
}
let svg = getTag('svg', { xmlns: 'http://www.w3.org/2000/svg', 'xmlns:xlink': "http://www.w3.org/1999/xlink", version: "1.1", width: '100%', height: '100%', viewBox: "0 0 1000 1000", });
document.querySelector('body').appendChild(svg);
let line = getTag('line', { x1: 0, y1: 0, x2: 100, y2: 100, stroke: 'green', 'stroke-width': 5 });
document.querySelector('svg').appendChild(line);
let rect = getTag('rect', { x: 100, y: 0,width: 150, height: 100, fill: 'none',stroke: 'green', 'stroke-width': 5 });
document.querySelector('svg').appendChild(rect);
let circle = getTag('circle', { cx:"300", cy:"50", r:"50" ,fill: 'none',stroke: 'green', 'stroke-width': 5 });
document.querySelector('svg').appendChild(circle);
let ellipse = getTag('ellipse', { cx:"425", cy:"50" ,rx:"75" ,ry:"50", fill: 'none',stroke: 'green', 'stroke-width': 5 });
document.querySelector('svg').appendChild(ellipse);
let polyline = getTag('polyline', { points:"500 0 600 50 550 100", fill: 'none',stroke: 'green', 'stroke-width': 5 });
document.querySelector('svg').appendChild(polyline);
let polygon = getTag('polygon', { points:"600,0,700,50,650,100", fill: 'none',stroke: 'green', 'stroke-width': 5 });
document.querySelector('svg').appendChild(polygon);
111
</script>
</body> </html>

运行

05.svg结构标签g.html

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="author" content="李可">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>js操作svg</title>
</head> <body>
<svg width="1000" height="1000">
<!-- 圆 中心点 半径 -->
<circle cx="100" cy="100" r="50" fill="none" stroke="black" stroke-width="2" />
<circle cx="100" cy="100" r="60" fill="none" stroke="black" stroke-width="2" />
<circle cx="100" cy="100" r="70" fill="none" stroke="black" stroke-width="2" /> <!--
将公用的属性抽离出来赋值给g标签
但是: 标签特有的放到g标签上不起作用。
比如circle的 cx cy r line的x1
g标签内全部是circle也不能抽离cx cy r等
-->
<g stroke="black" stroke-width="2" fill="none">
<circle cx="300" cy="100" r="50" />
<circle cx="300" cy="100" r="60" />
<circle cx="300" cy="100" r="70" /> <line x1="300" y1="100" x2="400" y2="200" />
</g> <!--
但是这些不能抽离的属性大部分是跟位置有关
使用transform变换来代替
-->
<g transform="translate(600,100)"stroke="black" stroke-width="2" fill="none">
<circle r="50" />
<circle r="60" />
<circle r="70" />
<line x1="300" y1="100" x2="400" y2="200" />
</g>
<!--
这时line是基于transform之后的距离再移动
-->
<g transform="translate(800,100)"stroke="black" stroke-width="2" fill="none">
<circle r="50" />
<circle r="60" />
<circle r="70" />
<line x1="0" y1="0" x2="100" y2="0" />
</g>
</svg>
</body> </html>

运行

可视化:svg相关基础的更多相关文章

  1. 数据可视化-svg入门基础(二)

    接上一篇:数据可视化-svg入门基础(一),基础一主要是介绍了svg概念,元素样式设置等. svg是(scalable vector graphic)伸缩矢量图像. 一.目录 (1)图形元素 (2)文 ...

  2. SVG相关学习(一)SVG基础

    SVG 相关学习 SVG SVG 指可伸缩矢量图形 (Scalable Vector Graphics) SVG viewBox <svg width="500" heigh ...

  3. iOS蓝牙开发(二)蓝牙相关基础知识

    原文链接: http://liuyanwei.jumppo.com/2015/07/17/ios-BLE-1.html iOS蓝牙开发(一)蓝牙相关基础知识: 蓝牙常见名称和缩写 MFI ====== ...

  4. Linux 相关基础笔记

    html,body { } .CodeMirror { height: auto } .CodeMirror-scroll { } .CodeMirror-lines { padding: 4px 0 ...

  5. linux设备驱动归纳总结(二):模块的相关基础概念【转】

    本文转载自:http://blog.chinaunix.net/uid-25014876-id-59415.html linux设备驱动归纳总结(二):模块的相关基础概念 系统平台:Ubuntu 10 ...

  6. linux设备驱动归纳总结(一)内核的相关基础概念【转】

    本文转载自:http://blog.chinaunix.net/uid-25014876-id-59413.html linux设备驱动归纳总结(一):内核的相关基础概念 xxxxxxxxxxxxxx ...

  7. 深入理解mysql之BDB系列(1)---BDB相关基础知识

        深入理解mysql之BDB系列(1) ---BDB相关基础知识 作者:杨万富   一:BDB体系结构 1.1.BDB体系结构 BDB总体的体系结构如图1.1所看到的,包括五个子系统(见图1.1 ...

  8. SVG的基础使用

    SVG的基础使用: <%@ page language="java" contentType="text/html; charset=UTF-8" pag ...

  9. 【RAC】RAC相关基础知识

    [RAC]RAC相关基础知识 1.CRS简介    从Oracle 10G开始,oracle引进一套完整的集群管理解决方案—-Cluster-Ready Services,它包括集群连通性.消息和锁. ...

随机推荐

  1. HashMap/HashSet,hashCode,哈希表

    hash code.equals和“==”三者的关系 1) 对象相等则hashCode一定相等: 2) hashCode相等对象未必相等. == 是比较地址是否相等,JAVA中声明变量都是引用嘛,不同 ...

  2. 我的Java设计模式-建造者模式

    在未上大学之前,一直有个梦想"I have a dream!",就是能成为一位汽车工程师,一直幻想着开着自己设计的汽车飞奔在公路上,迷倒了万千少女.咳咳~~虽然现在没实现我的dre ...

  3. 如何在WDM中使用xp系统的DMA用来处理数据

    最近做了一款pci的视频采集卡(H264压缩),由于数据传输量比较大,所有想采用dma来传输数据,刚开始感觉很简单,后来感觉还是困难重重. DMA 验证监控直接内存访问 (DMA) 的使用.随着 Wi ...

  4. JAVA之编码---->CSV在文本下是正常的,用EXCEL打开是乱码的问题

    JAVA之编码---->CSV在文本下是正常的,用EXCEL打开是乱码的问题 在JAVA下输出文件流,保存成CSV(用UTF-8)文件,怎么处理用EXCEL下是乱码,但是在记事本等其他软件都是正 ...

  5. Oracle 子程序参数模式,IN,OUT,IN OUT

    IN :用于传入参数. 在调用过程的时候,实参传到该过程中. 在过程内部,形参只读且不能更改. 在过程执行完毕,返回调用环境时候,实参到的值也不会改变 --带IN参数的过程,赋值. create or ...

  6. Web站点错误提示页面和默认访问页面设置

    1.asp.net 定制简单的错误处理页面 通常web应用程序在发布后,为了给用户一个友好界面和使用体验,都会在错误发生时跳转至一个自定义的错误页面,而不是asp.net向用户暴露出来的详细的异常列表 ...

  7. WPF自学入门(一)WPF-XAML基本知识

    一.基本概念 1.XAML是派生自XML的可扩展应用程序标记语言(Extensible Application Markup Language)由微软创造应用在WPF,Silverlight等开发技术 ...

  8. OpenStack_I版 5.Nova部署

    Nova安装 创建配置存放目录,日志存放目录,执行文件目录,虚拟机目录  Nova配置修改 生成主配置文件 创建Nova数据库 同步Nova数据库 验证 Nova连接RabbitMQ配置修改  key ...

  9. angular路由操作

    在单页面应用程序中比如angular应用,我们需要根据url的变化(即:不同的请求),来分配不同的资源.根据请求的URL来决定执行哪个模块,这个过程叫路由,同时,我们需要设计路由规则. 下面给出一个简 ...

  10. eclipse远程调试Tomcat方法(测试成功并且说说遇到的坑)

    转自:http://blog.csdn.net/afgasdg/article/details/9236877 PS:文中容易引起歧义的地方已经做了修改:另外,本人参照以下步骤操作,结果无法调试,后来 ...