TweenMax+svg实现贝塞尔曲线动画图表效果代码
代码语言:html
所属分类:动画
代码描述:TweenMax+svg实现贝塞尔曲线动画图表效果代码
代码标签: TweenMax svg 贝塞尔 曲线 动画 图表
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<style>
body,
html {
margin: 0;
width: 100%;
height: 100%;
position: relative;
background: #212938;
}
#parent {
width: 300px;
height: 300px;
position: absolute;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%) scale(1.5);
}
.graph-grid {
opacity: 0.6;
stroke: #C4CCFC;
stroke-width: 1;
stroke-linecap: round;
}
.graph-lines {
stroke: #EDBF6E;
stroke-width: 2;
stroke-linecap: round;
}
.graph-points circle,
.graph-bezier circle {
/*stroke: #40ACBA;*/
stroke: #EDBF6E;
stroke-width: 2;
fill: #212938;
}
.graph-bezier line {
stroke: #ED5E8F;
stroke-width: 2;
stroke-linecap: round;
}
h1 {
position: fixed;
top: 50px;
left: 50px;
font-family: monospace;
font-weight: 100;
color: #EDBF6E;
}
</style>
</head>
<body>
<!-- partial:index.partial.html -->
<div id="parent"></div>
<h1 id="lambda"></h1>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/TweenMax.min.js"></script>
<script>
// Amount of points:
var points = 9;
var speed = 5; // seconds
function Graph(parent) {
this.parent = document.getElementById(parent);
this.init = function() {
this.parent.innerHTML = '';
this.svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
this.parent.appendChild(this.svg);
this.svg.style.width = this.parent.offsetWidth;
this.svg.style.height = this.parent.offsetHeight;
this.svg.grid = document.createElementNS('http://www.w3.org/2000/svg', 'g');
this.svg.lines = document.createElementNS('http://www.w3.org/2000/svg', 'g');
this.svg.points = document.createElementNS('http://www.w3.org/2000/svg', 'g');
this.svg.bezier = document.createElementNS('http://www.w3.org/2000/svg', 'g');
this.svg.grid.setAttribute('class', 'graph-grid');
this.svg.lines.setAttribute('class', 'graph-lines');
this.svg.points.setAttribute('class', 'graph-points');
this.svg.bezier.setAttribute('class', 'graph-bezier')
this.svg.appendChild(this.svg.grid);
this.svg.appendChild(this.svg.lines);
this.svg.appendChild(this.svg.points);
this.svg.appendChild(this.svg.bezier);
}
this.points = [];
this.lines = [];
this.init();
}
/**
* Create a grid based on the min/max/step values
*/
Graph.prototype.createGrid = function() {
for (var i = 1; i < this.data.x.max; i = i + this.data.x..........完整代码请登录后点击上方下载按钮下载查看
网友评论0