vis.js is a dynamic, browser-based visualization library
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

186 lines
6.7 KiB

10 years ago
  1. <!DOCTYPE HTML>
  2. <html>
  3. <head>
  4. <meta content="text/html;charset=utf-8" http-equiv="Content-Type">
  5. <meta content="utf-8" http-equiv="encoding">
  6. <title>Graph2d | Dynamic Styling</title>
  7. <style type="text/css">
  8. body, html {
  9. font-family: sans-serif;
  10. }
  11. </style>
  12. <script src="../../dist/vis.js"></script>
  13. <link href="../../dist/vis.css" rel="stylesheet" type="text/css"/>
  14. </head>
  15. <body>
  16. <h2>Graph2d | Dynamic Styling Example</h2>
  17. <div style="width:700px; font-size:14px; text-align: justify;">
  18. This example shows how to programmatically change the styling of a group. While this can also
  19. be done in CSS, this must be statically defined, and the programmatic interface allows the
  20. user to define the look of the graph at runtime.
  21. </div>
  22. <br/>
  23. <table>
  24. <col width="500">
  25. <col width="200">
  26. <tr>
  27. <td style="padding-right: 20px; border-right: 1px solid;">
  28. <div id="visualization"></div>
  29. </td>
  30. <td style="padding-left: 5px;">
  31. <table style="font-size: 12px;">
  32. <col width="130">
  33. <col width="50">
  34. <tr>
  35. <td>Color</td>
  36. <td>
  37. <select id="color" onchange="updateStyle()">
  38. <option value="stroke:green;">green</option>
  39. <option value="stroke:red;">red</option>
  40. <option value="stroke:blue;" selected="selected">blue</option>
  41. <option value="stroke:black;">black</option>
  42. </select>
  43. </td>
  44. </tr>
  45. <tr>
  46. <td>Line Style</td>
  47. <td>
  48. <select id="line" onchange="updateStyle()">
  49. <option value="stroke-dasharray:1 0;" selected="selected">line</option>
  50. <option value="stroke-dasharray:10 10;">dash</option>
  51. <option value="stroke-dasharray:2 2;">dot</option>
  52. <option value="stroke-dasharray:10 5 2 5;">dash-dot</option>
  53. </select>
  54. </td>
  55. </tr>
  56. <tr>
  57. <td>Line thickness</td>
  58. <td>
  59. <select id="thickness" onchange="updateStyle()">
  60. <option value="stroke-width:0;">0</option>
  61. <option value="stroke-width:1;">1</option>
  62. <option value="stroke-width:2;" selected="selected">2</option>
  63. <option value="stroke-width:3;">3</option>
  64. <option value="stroke-width:4;">4</option>
  65. <option value="stroke-width:5;">5</option>
  66. <option value="stroke-width:6;">6</option>
  67. </select>
  68. </td>
  69. </tr>
  70. <tr>
  71. <td>Fill</td>
  72. <td>
  73. <select id="fill" onchange="updateStyle()">
  74. <option value="">none</option>
  75. <option value="top">top</option>
  76. <option value="bottom" selected="selected">bottom</option>
  77. </select>
  78. </td>
  79. </tr>
  80. <tr>
  81. <td>Points Shape</td>
  82. <td>
  83. <select id="points" onchange="updateStyle()">
  84. <option value="">none</option>
  85. <option value="circle">circle</option>
  86. <option value="square" selected="selected">square</option>
  87. </select>
  88. </td>
  89. </tr>
  90. <tr>
  91. <td>Points Size</td>
  92. <td>
  93. <select id="pointsize" onchange="updateStyle()">
  94. <option value="1">1</option>
  95. <option value="2">2</option>
  96. <option value="3">3</option>
  97. <option value="4">4</option>
  98. <option value="5">5</option>
  99. <option value="6" selected="selected">6</option>
  100. <option value="8">8</option>
  101. <option value="10">10</option>
  102. <option value="15">15</option>
  103. <option value="20">20</option>
  104. </select>
  105. </td>
  106. </tr>
  107. </table>
  108. </td>
  109. </tr>
  110. </table>
  111. <script type="text/javascript">
  112. var container = document.getElementById('visualization');
  113. var items = [
  114. {x: '2014-06-11', y: 10, group: 0},
  115. {x: '2014-06-12', y: 25, group: 0},
  116. {x: '2014-06-13', y: 30, group: 0},
  117. {x: '2014-06-14', y: 10, group: 0},
  118. {x: '2014-06-15', y: 15, group: 0},
  119. {x: '2014-06-16', y: 30, group: 0}
  120. ];
  121. var dataset = new vis.DataSet(items);
  122. var options = {
  123. start: '2014-06-10',
  124. end: '2014-06-18',
  125. dataAxis: {
  126. showMinorLabels: false,
  127. icons: true
  128. },
  129. legend: {left: {position: "top-left"}}
  130. };
  131. var groupData = {
  132. id: 0,
  133. content: "Group Name",
  134. options: {
  135. drawPoints: {
  136. style: 'square' // square, circle
  137. },
  138. shaded: {
  139. orientation: 'bottom' // top, bottom
  140. }
  141. }
  142. };
  143. var groups = new vis.DataSet();
  144. groups.add(groupData);
  145. var graph2d = new vis.Graph2d(container, dataset, groups, options);
  146. updateStyle();
  147. function updateStyle() {
  148. groupData.style = "";
  149. groupData.style += document.getElementById("color").value;
  150. groupData.style += document.getElementById("line").value;
  151. groupData.style += document.getElementById("thickness").value;
  152. groupData.options.drawPoints = {};
  153. groupData.options.drawPoints.style = document.getElementById("points").value;
  154. groupData.options.drawPoints.size = Number(document.getElementById("pointsize").value);
  155. if (groupData.options.drawPoints.style == "") {
  156. groupData.options.drawPoints = false;
  157. }
  158. groupData.options.shaded = {};
  159. groupData.options.shaded.orientation = document.getElementById("fill").value;
  160. if (groupData.options.shaded.orientation == "") {
  161. groupData.options.shaded = false;
  162. }
  163. var groups = new vis.DataSet();
  164. groups.add(groupData);
  165. graph2d.setGroups(groups);
  166. }
  167. </script>
  168. </body>
  169. </html>