查看效果:http://keleyi.com/keleyi/phtml/html5/33.htm

.NET版本:http://keleyi.com/a/bjac/66mql4bc.htm

完整HTML文件代码:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>使用javascript生成的植物显示过程特效 - 柯乐义</title><base target="_blank" />
<style>html, body {background: black;}a{color:white;text-decoration:none}
.hovertreefrme{height:700px;width:760px;border:solid 1px red; }
</style>
</head>
<body>
<div class="hovertreefrme"><div><a href="http://keleyi.com">首页</a> <a href="http://keleyi.com/a/bjae/4d3jagcj.htm">原文</a> <a href="http://keleyi.com/keleyi/phtml/">特效库</a> <a href="http://hovertree.com">HoverTree</a> <a href="http://keleyi.com/a/bjac/66mql4bc.htm">参考</a></div>
<canvas id="hovertree"></canvas>
</div>
<script>
(function () {
var H, W, animationCurve, keleyicanvas, colorStops, getColors, i, k, lut, maxDraws, numDraws, pMax, rand, render, row, speed, step, styles, transformations, v, xRange, xSpan, yRange, ySpan, _i, _len, _ref; speed = 1; W = 350; H = 500; transformations = [
[
(function (x, y) {
return 0;
}), (function (x, y) {
return 0.16 * y;
}), 1
], [
(function (x, y) {
return 0.2 * x - 0.26 * y;
}), (function (x, y) {
return 0.23 * x + 0.22 * y + 1.6;
}), 7
], [
(function (x, y) {
return -0.15 * x + 0.28 * y;
}), (function (x, y) {
return 0.26 * x + 0.24 * y + 0.44;
}), 7
], [
(function (x, y) {
return 0.85 * x + 0.04 * y;
}), (function (x, y) {
return -0.04 * x + 0.85 * y + 1.6;
}), 85
]
]; maxDraws = 200000; xRange = [-2.182, 2.6558]; yRange = [0, 9.9983]; keleyicanvas = document.getElementById("hover"+"tree"); keleyicanvas.width = W; keleyicanvas.height = H; styles = {
position: "absolute",
top: "400px",
left: "300px",
margin: "-" + (~~(H / 2)) + "px 0 0 -" + (~~(W / 2)) + "px"
}; colorStops = [[0, "rgba(255,255,255,1)"], [1000, "rgba(253,253,52,0.6)"], [5000, "rgba(0,171,56,0.7)"], [10000, "rgba(168,210,110,0.7)"], [20000, "rgba(246,243,27,0.6)"], [40000, "rgba(138,215,39,0.7)"], [65000, "rgba(243,205,8,0.5)"], [90000, "rgba(150,204,104,0.4)"], [125000, "rgba(137,230,101,0.5)"], [150000, "rgba(246,243,27,0.5)"], [190000, "rgba(255,255,255,0.8)"]]; animationCurve = function (frame) {
if (frame < 1000) return 25;
if (frame < 5000) return 50;
if (frame < 10000) return 75;
if (frame < 20000) return 100;
if (frame < 40000) return 150;
if (frame < 65000) return 250;
if (frame < 90000) return 400;
if (frame < 150000) return 600;
if (frame < 190000) return 400;
if (frame < 200000) return 100;
}; lut = {}; numDraws = 0; pMax = 0; for (_i = 0, _len = transformations.length; _i < _len; _i++) {
row = transformations[_i];
for (i = pMax, _ref = row[2] + pMax - 1; pMax <= _ref ? i <= _ref : i >= _ref; pMax <= _ref ? i++ : i--) {
lut[i] = [row[0], row[1]];
}
pMax += row[2];
} getColors = function () {
var colors;
colors = colorStops.slice();
return function () {
var colorStop;
if (!(colors[0] && numDraws >= colors[0][0])) return;
colorStop = colors.shift();
return ctx.fillStyle = colorStop[1];
};
}; for (k in styles) {
v = styles[k];
keleyicanvas.style[k] = v;
} window.ctx = keleyicanvas.getContext("2d"); xSpan = xRange[1] - xRange[0]; ySpan = yRange[1] - yRange[0]; window.updateColor = getColors(); render = function () {
var drawsPerFrame, f, i, iter, x, y, _ref2, _ref3;
if (numDraws > maxDraws) return;
updateColor();
drawsPerFrame = speed * animationCurve(numDraws);
for (i = 0; 0 <= drawsPerFrame ? i <= drawsPerFrame : i >= drawsPerFrame; 0 <= drawsPerFrame ? i++ : i--) {
iter = 0;
_ref2 = [rand(xRange[0], xRange[1]), rand(yRange[0], yRange[1])], x = _ref2[0], y = _ref2[1];
while (iter++ < 50) {
f = lut[~~rand(0, pMax)];
_ref3 = [f[0](x, y), f[1](x, y)], x = _ref3[0], y = _ref3[1];
}
x = W * (x - xRange[0]) / xSpan;
y = H * (1 - y / ySpan);
ctx.fillRect(x, y, 1, 1);
}
return numDraws += drawsPerFrame;
}; window.onclick = function () {
numDraws = 0;
window.updateColor = getColors();
return ctx.clearRect(0, 0, W, H);
}; rand = function (a, b) {
return (b - a) * Math.random() + a;
}; window.requestAnimationFrame || (window.requestAnimationFrame = (function () {
var prefix, r, _j, _len2, _ref2;
_ref2 = ['webkit', 'moz', 'ms', 'o'];
for (_j = 0, _len2 = _ref2.length; _j < _len2; _j++) {
prefix = _ref2[_j];
if (r = window["" + prefix + "RequestAnimationFrame"]) return r;
}
return function (callback) {
return window.setTimeout(callback, 1000 / 60);
};
})()); (step = function () {
return requestAnimationFrame(step) && render();
})(); }).call(this); </script>
</body>
</html>

web前端汇总 : http://www.cnblogs.com/jihua/p/webfront.html

使用javascript生成的植物显示过程特效的更多相关文章

  1. JavaScript + CSS3 实现的海报画廊特效

    原文:JavaScript + CSS3 实现的海报画廊特效 这是慕课网上<CSS3+JS 实现超炫的散列画廊特效>的源代码,我修改了一些 bug 和调优了一些细节,并把学习过程中并不了解 ...

  2. javascript生成表格增删改查 JavaScript动态改变表格单元格内容 动态生成表格 JS获取表格任意单元格 javascript如何动态删除表格某一行

    jsp页面表格布局Html代码 <body onload="show()"> <center> <input type="text" ...

  3. 【原创】网站抓包HttpWebRequest不返回Javascript生成的Cookie的解决办法

    前言: 最近在做中国移动爬虫的过程中,首先遇到的就是 在某个请求中,有一个名为“WT_PFC"的cookie键值是由前端JavaScript生成的,没有进入到HttpWebResponse中 ...

  4. javascript生成自定义的arcgis simpletoolbar

    javascript生成自定义的arcgis simpletoolbar 最近在学习ARCGIS for Javascript过程中,在ESRI的在线帮助上看见了这样一个示例,查看源码后,觉得左侧工具 ...

  5. 使用JavaScript生成二维码教程-附qrcodejs中文文档

    使用javascript生成二维码 依赖jquery 需要使用到的库 https://github.com/davidshimjs/qrcodejs DIV <div id="qrco ...

  6. 浅谈移动端 View 的显示过程

    作者:个推安卓开发工程师 一七 随着科技的发展,各种移动端早已成为人们日常生活中不可或缺的部分,人们使用移动端产品工作.社交.娱乐……移动端界面的流畅性已经成为影响用户体验的重要因素之一.那么你是否思 ...

  7. JQuery实现密码有短暂的显示过程和实现 input hint效果

    目录: 一.实现目的 二.问题思考 三.解决办法 1.输入用户名 2.输入密码短暂显示 一.实现目的 这几天做项目的时候,客户要求在文本框输入密码的时候,要求密码有短暂的显示过程,如下图: 二.问题思 ...

  8. 第一百八十七节,jQuery,知问前端--cookie 插件,注册成功后生成cookie,显示登录状态

    jQuery,知问前端--cookie 插件 学习要点: 1.使用 cookie 插件 2.注册直接登录 Cookie 是网站用来在客户端保存识别用户的一种小文件.一般来用库可以保存用户登 录信息.购 ...

  9. 修改u-boot的开机logo及显示过程【转】

    本文转载自;http://blog.csdn.net/voice_shen/article/details/6789424 [ u-boot: Git://git.denx.de/u-boot.git ...

随机推荐

  1. jQuery Colorbox弹窗插件使用教程小结、属性设置详解

    jQuery Colorbox是一款弹出层,内容播放插件,效果极佳,当然我主要是用来弹出图片啦. jQuery Colorbox不仅有弹性动画效果,淡入淡出效果,幻灯片播放,宽度自定义,还能够ajax ...

  2. 使H1 H2等标签不换行

    在网页优化中,经常要使用H标签对关键字进行优化, 可是如果是一行文字中的某个词加上了H1标记,就会换行. 可以使用下面的方法,H标签就不会强制换行了. <style type="tex ...

  3. AngularJS之高级Route【三】(八)

    前言 我们知道默认的路由提供(Route Provider)在复杂的应用程序中是不太适合应用场景,它存在诸多限制,所以在Angular 1.2之后此时我们不得不将路由提供作为一个单独的模块当我们需要使 ...

  4. ECMAScript5之Object

    在ECMAScript5中对Object新增的些方法,以前没注意的同志们,嘻嘻,下面我们再一起来边看边学. 1.Object之create Create单词意为创造嘛,作为Object的静态方法,不言 ...

  5. Oracle常用函数

    前一段时间学习Oracle 时做的学习笔记,整理了一下,下面是分享的Oracle常用函数的部分笔记,以后还会分享其他部分的笔记,请大家批评指正. 1.Oracle 数据库中的to_date()函数的使 ...

  6. Ubuntu杂记——Ubuntu下Eclipse安装Maven问题

    转:在线安装maven插件问题:Cannot complete the install because one or more required items could not be found. 使 ...

  7. HTML5 Audio/Video 标签,属性,方法,事件汇总

    HTML5 Audio/Video 标签,属性,方法,事件汇总 (转) 2011-06-28 13:16:48   <audio> 标签属性:src:音乐的URLpreload:预加载au ...

  8. 构建自己的PHP框架--实现Model类(1)

    在之前的博客中,我们定义了ORM的接口,以及决定了使用PDO去实现.最后我们提到会有一个Model类实现ModelInterface接口. 现在我们来实现这个接口,如下: <?php names ...

  9. 浅谈2D游戏设计模式3 - 冒险地图之美(1)

    冒险岛之所以能长久的存在,很大一部分原因是因为它的美工设计的非常的精细,以及独特,那么独特以及美究竟体现在哪些方面呢? 今天我就带大家来分析几幅地图吧. 好吧,我们就拿上面这幅美景来分析吧. 1.阳光 ...

  10. Android之使用个推实现三方应用的推送功能

    PS:用了一下个推.感觉实现第三方应用的推送功能还是比较简单的.官方文档写的也非常的明确. 学习内容: 1.使用个推实现第三方应用的推送.      所有的配置我最后会给一个源代码,内部有相关的配置和 ...