Advertisement
Guest User

Untitled

a guest
Nov 26th, 2015
81
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.25 KB | None | 0 0
  1. <!DOCTYPE html>
  2. <meta charset="utf-8">
  3. <title>Superformula</title>
  4. <style>
  5.  
  6. path {
  7. stroke-width: 1.5px;
  8. stroke: #666;
  9. fill: #ddd;
  10. }
  11.  
  12. #controls {
  13. position: absolute;
  14. width: 240px;
  15. font: 10px sans-serif;
  16. }
  17.  
  18. #controls span,
  19. #controls label {
  20. position: relative;
  21. top: -5px;
  22. padding: 5px;
  23. display: inline-block;
  24. width: 20px;
  25. }
  26.  
  27. #controls button {
  28. font: 10px sans-serif;
  29. padding: 5px;
  30. width: 70px;
  31. }
  32.  
  33. </style>
  34. <div id="controls"></div>
  35. <script src="//d3js.org/d3.v3.min.js"></script>
  36. <script src="superformula.js"></script>
  37. <script>
  38.  
  39. var types = {
  40. asterisk: {m: 12, n1: .3, n2: 0, n3: 10, a: 1, b: 1},
  41. bean: {m: 2, n1: 1, n2: 4, n3: 8, a: 1, b: 1},
  42. butterfly: {m: 3, n1: 1, n2: 6, n3: 2, a: .6, b: 1},
  43. circle: {m: 4, n1: 2, n2: 2, n3: 2, a: 1, b: 1},
  44. clover: {m: 6, n1: .3, n2: 0, n3: 10, a: 1, b: 1},
  45. cloverFour: {m: 8, n1: 10, n2: -1, n3: -8, a: 1, b: 1},
  46. cross: {m: 8, n1: 1.3, n2: .01, n3: 8, a: 1, b: 1},
  47. diamond: {m: 4, n1: 1, n2: 1, n3: 1, a: 1, b: 1},
  48. drop: {m: 1, n1: .5, n2: .5, n3: .5, a: 1, b: 1},
  49. ellipse: {m: 4, n1: 2, n2: 2, n3: 2, a: 9, b: 6},
  50. gear: {m: 19, n1: 100, n2: 50, n3: 50, a: 1, b: 1},
  51. heart: {m: 1, n1: .8, n2: 1, n3: -8, a: 1, b: .18},
  52. heptagon: {m: 7, n1: 1000, n2: 400, n3: 400, a: 1, b: 1},
  53. hexagon: {m: 6, n1: 1000, n2: 400, n3: 400, a: 1, b: 1},
  54. malteseCross: {m: 8, n1: .9, n2: .1, n3: 100, a: 1, b: 1},
  55. pentagon: {m: 5, n1: 1000, n2: 600, n3: 600, a: 1, b: 1},
  56. rectangle: {m: 4, n1: 100, n2: 100, n3: 100, a: 2, b: 1},
  57. roundedStar: {m: 5, n1: 2, n2: 7, n3: 7, a: 1, b: 1},
  58. square: {m: 4, n1: 100, n2: 100, n3: 100, a: 1, b: 1},
  59. star: {m: 5, n1: 30, n2: 100, n3: 100, a: 1, b: 1},
  60. triangle: {m: 3, n1: 100, n2: 200, n3: 200, a: 1, b: 1}
  61. };
  62.  
  63. var format = d3.format(".4n");
  64.  
  65. var scale = d3.scale.linear()
  66. .domain([-10, 20, 1000])
  67. .range([0, 800, 1000]);
  68.  
  69. var svg = d3.select("body")
  70. .append("svg")
  71. .attr("width", 960)
  72. .attr("height", 500);
  73.  
  74. var shape = d3.superformula()
  75. .type("asterisk")
  76. .size(100000)
  77. .segments(3600);
  78.  
  79. var path = svg.append("path")
  80. .attr("class", "big")
  81. .attr("transform", "translate(480,250)")
  82. .attr("d", shape);
  83.  
  84. var control = d3.select("#controls")
  85. .selectAll("div")
  86. .data(d3.entries(types.asterisk))
  87. .enter().append("div")
  88. .attr("id", function(d) { return d.key; });
  89.  
  90. control.append("label")
  91. .text(function(d) { return d.key; });
  92.  
  93. control.append("input")
  94. .attr("type", "range")
  95. .attr("max", 1000)
  96. .attr("min", 0)
  97. .property("value", function(d) { return scale(d.value); })
  98. .on("input", function(d) {
  99. var v = scale.invert(this.value);
  100. path.attr("d", shape.param(d.key, v));
  101. d3.select(this.nextSibling).text(format(v));
  102. });
  103.  
  104. control.append("span")
  105. .text(function(d) { return format(d.value); });
  106.  
  107. d3.select("#controls")
  108. .append("div")
  109. .selectAll("button")
  110. .data(d3.entries(types))
  111. .enter().append("button")
  112. .text(function(d) { return d.key; })
  113. .on("click", function(d) {
  114. for (var param in d.value) {
  115. var control = d3.select("#" + param);
  116. control.select("input").property("value", scale(d.value[param]));
  117. control.select("span").text(format(d.value[param]));
  118. shape.param(param, d.value[param]);
  119. }
  120. path.attr("d", shape);
  121. });
  122.  
  123. </script>
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement