人人商城

show.js 5.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. (function() {
  2. var width, height, largeHeader, canvas, ctx, points, target, animateHeader = true;
  3. // Main
  4. initHeader();
  5. initAnimation();
  6. addListeners();
  7. function initHeader() {
  8. width = window.innerWidth;
  9. height = window.innerHeight;
  10. target = {x: width/2, y: height/2};
  11. largeHeader = document.getElementById('large-header');
  12. largeHeader.style.height = height+'px';
  13. canvas = document.getElementById('showcanvas');
  14. canvas.width = width;
  15. canvas.height = height;
  16. ctx = canvas.getContext('2d');
  17. // create points
  18. points = [];
  19. for(var x = 0; x < width; x = x + width/20) {
  20. for(var y = 0; y < height; y = y + height/20) {
  21. var px = x + Math.random()*width/20;
  22. var py = y + Math.random()*height/20;
  23. var p = {x: px, originX: px, y: py, originY: py };
  24. points.push(p);
  25. }
  26. }
  27. // for each point find the 5 closest points
  28. for(var i = 0; i < points.length; i++) {
  29. var closest = [];
  30. var p1 = points[i];
  31. for(var j = 0; j < points.length; j++) {
  32. var p2 = points[j]
  33. if(!(p1 == p2)) {
  34. var placed = false;
  35. for(var k = 0; k < 5; k++) {
  36. if(!placed) {
  37. if(closest[k] == undefined) {
  38. closest[k] = p2;
  39. placed = true;
  40. }
  41. }
  42. }
  43. for(var k = 0; k < 5; k++) {
  44. if(!placed) {
  45. if(getDistance(p1, p2) < getDistance(p1, closest[k])) {
  46. closest[k] = p2;
  47. placed = true;
  48. }
  49. }
  50. }
  51. }
  52. }
  53. p1.closest = closest;
  54. }
  55. // assign a circle to each point
  56. for(var i in points) {
  57. var c = new Circle(points[i], 2+Math.random()*2, 'rgba(255,255,255,0.3)');
  58. points[i].circle = c;
  59. }
  60. }
  61. // Event handling
  62. function addListeners() {
  63. if(!('ontouchstart' in window)) {
  64. window.addEventListener('mousemove', mouseMove);
  65. }
  66. window.addEventListener('scroll', scrollCheck);
  67. window.addEventListener('resize', resize);
  68. }
  69. function mouseMove(e) {
  70. var posx = posy = 0;
  71. if (e.pageX || e.pageY) {
  72. posx = e.pageX;
  73. posy = e.pageY;
  74. }
  75. else if (e.clientX || e.clientY) {
  76. posx = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft;
  77. posy = e.clientY + document.body.scrollTop + document.documentElement.scrollTop;
  78. }
  79. target.x = posx;
  80. target.y = posy;
  81. }
  82. function scrollCheck() {
  83. if(document.body.scrollTop > height) animateHeader = false;
  84. else animateHeader = true;
  85. }
  86. function resize() {
  87. width = window.innerWidth;
  88. height = window.innerHeight;
  89. largeHeader.style.height = height+'px';
  90. canvas.width = width;
  91. canvas.height = height;
  92. }
  93. // animation
  94. function initAnimation() {
  95. animate();
  96. for(var i in points) {
  97. shiftPoint(points[i]);
  98. }
  99. }
  100. function animate() {
  101. if(animateHeader) {
  102. ctx.clearRect(0,0,width,height);
  103. for(var i in points) {
  104. // detect points in range
  105. if(Math.abs(getDistance(target, points[i])) < 4000) {
  106. points[i].active = 0.3;
  107. points[i].circle.active = 0.6;
  108. } else if(Math.abs(getDistance(target, points[i])) < 20000) {
  109. points[i].active = 0.1;
  110. points[i].circle.active = 0.3;
  111. } else if(Math.abs(getDistance(target, points[i])) < 40000) {
  112. points[i].active = 0.02;
  113. points[i].circle.active = 0.1;
  114. } else {
  115. points[i].active = 0;
  116. points[i].circle.active = 0;
  117. }
  118. drawLines(points[i]);
  119. points[i].circle.draw();
  120. }
  121. }
  122. requestAnimationFrame(animate);
  123. }
  124. function shiftPoint(p) {
  125. TweenLite.to(p, 1+1*Math.random(), {x:p.originX-50+Math.random()*100,
  126. y: p.originY-50+Math.random()*100, ease:Circ.easeInOut,
  127. onComplete: function() {
  128. shiftPoint(p);
  129. }});
  130. }
  131. // Canvas manipulation
  132. function drawLines(p) {
  133. if(!p.active) return;
  134. for(var i in p.closest) {
  135. ctx.beginPath();
  136. ctx.moveTo(p.x, p.y);
  137. ctx.lineTo(p.closest[i].x, p.closest[i].y);
  138. ctx.strokeStyle = 'rgba(156,217,249,'+ p.active+')';
  139. ctx.stroke();
  140. }
  141. }
  142. function Circle(pos,rad,color) {
  143. var _this = this;
  144. // constructor
  145. (function() {
  146. _this.pos = pos || null;
  147. _this.radius = rad || null;
  148. _this.color = color || null;
  149. })();
  150. this.draw = function() {
  151. if(!_this.active) return;
  152. ctx.beginPath();
  153. ctx.arc(_this.pos.x, _this.pos.y, _this.radius, 0, 2 * Math.PI, false);
  154. ctx.fillStyle = 'rgba(156,217,249,'+ _this.active+')';
  155. ctx.fill();
  156. };
  157. }
  158. // Util
  159. function getDistance(p1, p2) {
  160. return Math.pow(p1.x - p2.x, 2) + Math.pow(p1.y - p2.y, 2);
  161. }
  162. })();