• Edit
  • Download
  • <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="utf-8">
      <title>ZingSoft Demo</title>
      <style>
        #table {
          margin-top: 20px;
          padding: 10px;
          background-color: #F7F7F7;
          visibility: hidden;
        }
    
        #table h3 {
          margin: 0px 10px;
          border-bottom: 1px solid black;
        }
    
        .row {
          margin: 5px 0px;
        }
    
        .column {
          background-color: #2196F3;
          border-radius: 4px;
          display: inline-block;
          font-size: 20px;
          color: #FFF;
          padding: 2px 8px;
          margin: 0px 10px;
          width: 30%;
          text-align: center;
        }
      </style>
    
      <script nonce="undefined" src="https://cdn.zingchart.com/zingchart.min.js"></script>
      <style></style>
    </head>
    
    <body>
      <div id='myChart'></div>
      <div id="table"></div>
      <script>
        ZC.LICENSE = ["569d52cefae586f634c54f86dc99e6a9", "b55b025e438fa8a98e32482b5f768ff5"];
        var myConfig = {
          type: "bubble",
          backgroundColor: '#F7F7F7',
          title: {
            text: 'Points Along A Sin Wave'
          },
          plot: {
            selectionMode: "none", // turn off normal selection
            marker: {
              borderWidth: 0,
              size: 1,
              alpha: .85,
            },
            selectedMarker: {
              size: 3
            },
            hoverMarker: {
              size: 2
            },
            tooltip: {
              backgroundColor: '#FFF',
              fontColor: '#000',
              fontSize: 14,
              borderRadius: 4,
              borderWidth: 1,
              borderColor: '#000',
              text: '%t: %v',
              selectedState: {
                _text: 'hi' // selected nodes can have special text
              }
            }
          },
          plotarea: {
            margin: 'dynamic'
          },
          scaleX: {
            visible: false,
          },
          scaleY: {
            minValue: -2,
            maxValue: 2,
            step: 1,
            guide: {
              visible: false
            },
            lineColor: '#90CAF9',
            lineWidth: 2,
            refLine: {
              lineColor: '#90CAF9',
              lineWidth: 2
            },
            item: {
              fontColor: '#90CAF9',
              fontSize: 14
            },
            tick: {
              lineColor: '#90CAF9'
            }
          },
          // This styling will be pushed during the next build.
          // You can style the mask background, border and line color
          selectionTool: {
            mask: {
              borderWidth: 2,
              borderColor: 'red',
              backgroundColor: 'yellow',
              alpha: .5
            }
          },
          series: [{
              // Lets create some random values that look cool
              values: (function() {
                var aV = [];
                var len = 1000;
                var x = 0;
                while (len--) {
                  x = (Math.random() * 10).toFixed(3) - 0;
                  aV.push([
                    x,
                    (Math.sin(x) - x * (len % 2 ? 0.1 : -0.1) * Math.random()).toFixed(3) - 0
                  ]);
                }
                return aV.sort();
              })(),
              backgroundColor: '#F48FB1',
              text: 'Sin Wave One',
              marker: {
                backgroundColor: '#F48FB1'
              }
            },
            {
              // Lets create some random values that look cool
              values: (function() {
                var aV = [];
                var len = 2000;
                var x = 0;
                while (len--) {
                  x = (Math.random() * 10).toFixed(3) - 0;
                  aV.push([
                    x,
                    (Math.cos(x) - x * (len % 2 ? 0.1 : -0.1) * Math.random()).toFixed(3) - 0
                  ]);
                }
                return aV.sort();
              })(),
              backgroundColor: '#F48FB1',
              text: 'Sin Wave Two',
              marker: {
                backgroundColor: '#CE93D8'
              }
            }
          ]
        };
    
        /* Special callback function for this dragging module.
         * You can use this information to display selected data.
         * You can use this information to update the chart etc...
         */
        zingchart.bind(null, 'zingchart.plugins.selection-tool.selection', function(e) {
          var table = document.getElementById('table');
          var header = document.createElement('h3');
          var Column = function() {
            var column = document.createElement('div');
            column.classList.add('column');
            return column;
          }
    
          var Row = function() {
            var row = document.createElement('div');
            row.classList.add('row');
            return row;
          }
    
          // clear table and set header
          table.innerHTML = '';
          header.innerHTML = 'Selected State Logistics';
          table.appendChild(header);
    
          // define variables for creating grid
          var totalMinValue = 10000;
          var totalMaxValue = 0;
          var sumValues = 0;
          var row;
          var column1;
          var column2;
          var column3;
    
          // loop through plots and grab information
          for (var key in e.nodes) {
    
            // Get global min and max values from plots
            if (e.nodes[key].value < totalMinValue)
              totalMinValue = e.nodes[key].value;
    
            if (e.nodes[key].value > totalMaxValue)
              totalMaxValue = e.nodes[key].value;
    
            sumValues += e.nodes[key].value;
          }
    
          // append a new total value row
          row = Row();
          column1 = Column();
          column2 = Column();
          column3 = Column();
          column1.innerHTML = 'SumValues: ' + sumValues.toFixed(3);
          column2.innerHTML = 'MinValue: ' + totalMinValue.toFixed(3);
          column3.innerHTML = 'MaxValue: ' + totalMaxValue.toFixed(3);
          row.appendChild(column1);
          row.appendChild(column2);
          row.appendChild(column3);
          table.appendChild(row);
    
          // render the table visible
          table.style.visibility = 'visible';
        });
    
    
        /* Lets create a place to store our function. Typically it is not recomended
         * to modify the zingchart object. This is for advanced users. It is good
         * practice to keep all your charting stuff together, in this case your 
         * custom functions within the zingchart object! This will also help with
         * name collisions within the window object.
         *
         * BE WARNED: you can overwrite stuff in the zingchart object if you are
         * not careful. This will mess stuff up.
         */
        zingchart.insert_company_name_customFncs = {};
        zingchart.insert_company_name_customFncs.clearSelection = function(e) {
          zingchart.exec(e.id, 'clearselection');
        }
    
        // Load the selection-tool and render the chart once the module is loaded
        zingchart.loadModules('selection-tool', function() {
          zingchart.render({
            id: 'myChart',
            // defined data this way since context menu needs to be defined in root (above graphset)
            data: {
              gui: {
                contextMenu: {
                  customItems: [{
                    text: 'Clear Selection',
                    function: 'zingchart.insert_company_name_customFncs.clearSelection()',
                    id: 'clearSelection'
                  }]
                }
              },
              graphset: [myConfig]
            },
            height: 400,
            width: '100%',
            modules: 'selection-tool'
          });
        });
      </script>
    </body>
    
    </html>
    <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="utf-8">
      <title>ZingSoft Demo</title>
      <style>
        #table {
          margin-top: 20px;
          padding: 10px;
          background-color: #F7F7F7;
          visibility: hidden;
        }
    
        #table h3 {
          margin: 0px 10px;
          border-bottom: 1px solid black;
        }
    
        .row {
          margin: 5px 0px;
        }
    
        .column {
          background-color: #2196F3;
          border-radius: 4px;
          display: inline-block;
          font-size: 20px;
          color: #FFF;
          padding: 2px 8px;
          margin: 0px 10px;
          width: 30%;
          text-align: center;
        }
      </style>
    
      <script src="https://cdn.zingchart.com/zingchart.min.js"></script>
    </head>
    
    <body>
      <div id='myChart'></div>
      <div id="table"></div>
    </body>
    
    </html>
    
          
    var myConfig = {
      type: "bubble",
      backgroundColor: '#F7F7F7',
      title: {
        text: 'Points Along A Sin Wave'
      },
      plot: {
        selectionMode: "none", // turn off normal selection
        marker: {
          borderWidth: 0,
          size: 1,
          alpha: .85,
        },
        selectedMarker: {
          size: 3
        },
        hoverMarker: {
          size: 2
        },
        tooltip: {
          backgroundColor: '#FFF',
          fontColor: '#000',
          fontSize: 14,
          borderRadius: 4,
          borderWidth: 1,
          borderColor: '#000',
          text: '%t: %v',
          selectedState: {
            _text: 'hi' // selected nodes can have special text
          }
        }
      },
      plotarea: {
        margin: 'dynamic'
      },
      scaleX: {
        visible: false,
      },
      scaleY: {
        minValue: -2,
        maxValue: 2,
        step: 1,
        guide: {
          visible: false
        },
        lineColor: '#90CAF9',
        lineWidth: 2,
        refLine: {
          lineColor: '#90CAF9',
          lineWidth: 2
        },
        item: {
          fontColor: '#90CAF9',
          fontSize: 14
        },
        tick: {
          lineColor: '#90CAF9'
        }
      },
      // This styling will be pushed during the next build.
      // You can style the mask background, border and line color
      selectionTool: {
        mask: {
          borderWidth: 2,
          borderColor: 'red',
          backgroundColor: 'yellow',
          alpha: .5
        }
      },
      series: [{
          // Lets create some random values that look cool
          values: (function() {
            var aV = [];
            var len = 1000;
            var x = 0;
            while (len--) {
              x = (Math.random() * 10).toFixed(3) - 0;
              aV.push([
                x,
                (Math.sin(x) - x * (len % 2 ? 0.1 : -0.1) * Math.random()).toFixed(3) - 0
              ]);
            }
            return aV.sort();
          })(),
          backgroundColor: '#F48FB1',
          text: 'Sin Wave One',
          marker: {
            backgroundColor: '#F48FB1'
          }
        },
        {
          // Lets create some random values that look cool
          values: (function() {
            var aV = [];
            var len = 2000;
            var x = 0;
            while (len--) {
              x = (Math.random() * 10).toFixed(3) - 0;
              aV.push([
                x,
                (Math.cos(x) - x * (len % 2 ? 0.1 : -0.1) * Math.random()).toFixed(3) - 0
              ]);
            }
            return aV.sort();
          })(),
          backgroundColor: '#F48FB1',
          text: 'Sin Wave Two',
          marker: {
            backgroundColor: '#CE93D8'
          }
        }
      ]
    };
    
    /* Special callback function for this dragging module.
     * You can use this information to display selected data.
     * You can use this information to update the chart etc...
     */
    zingchart.bind(null, 'zingchart.plugins.selection-tool.selection', function(e) {
      var table = document.getElementById('table');
      var header = document.createElement('h3');
      var Column = function() {
        var column = document.createElement('div');
        column.classList.add('column');
        return column;
      }
    
      var Row = function() {
        var row = document.createElement('div');
        row.classList.add('row');
        return row;
      }
    
      // clear table and set header
      table.innerHTML = '';
      header.innerHTML = 'Selected State Logistics';
      table.appendChild(header);
    
      // define variables for creating grid
      var totalMinValue = 10000;
      var totalMaxValue = 0;
      var sumValues = 0;
      var row;
      var column1;
      var column2;
      var column3;
    
      // loop through plots and grab information
      for (var key in e.nodes) {
    
        // Get global min and max values from plots
        if (e.nodes[key].value < totalMinValue)
          totalMinValue = e.nodes[key].value;
    
        if (e.nodes[key].value > totalMaxValue)
          totalMaxValue = e.nodes[key].value;
    
        sumValues += e.nodes[key].value;
      }
    
      // append a new total value row
      row = Row();
      column1 = Column();
      column2 = Column();
      column3 = Column();
      column1.innerHTML = 'SumValues: ' + sumValues.toFixed(3);
      column2.innerHTML = 'MinValue: ' + totalMinValue.toFixed(3);
      column3.innerHTML = 'MaxValue: ' + totalMaxValue.toFixed(3);
      row.appendChild(column1);
      row.appendChild(column2);
      row.appendChild(column3);
      table.appendChild(row);
    
      // render the table visible
      table.style.visibility = 'visible';
    });
    
    
    /* Lets create a place to store our function. Typically it is not recomended
     * to modify the zingchart object. This is for advanced users. It is good
     * practice to keep all your charting stuff together, in this case your 
     * custom functions within the zingchart object! This will also help with
     * name collisions within the window object.
     *
     * BE WARNED: you can overwrite stuff in the zingchart object if you are
     * not careful. This will mess stuff up.
     */
    zingchart.insert_company_name_customFncs = {};
    zingchart.insert_company_name_customFncs.clearSelection = function(e) {
      zingchart.exec(e.id, 'clearselection');
    }
    
    // Load the selection-tool and render the chart once the module is loaded
    zingchart.loadModules('selection-tool', function() {
      zingchart.render({
        id: 'myChart',
        // defined data this way since context menu needs to be defined in root (above graphset)
        data: {
          gui: {
            contextMenu: {
              customItems: [{
                text: 'Clear Selection',
                function: 'zingchart.insert_company_name_customFncs.clearSelection()',
                id: 'clearSelection'
              }]
            }
          },
          graphset: [myConfig]
        },
        height: 400,
        width: '100%',
        modules: 'selection-tool'
      });
    });