• Edit
  • Download
  • <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="utf-8">
      <title>ZingSoft Demo</title>
      <style>
        * {
          font-family: 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans';
          font-size: 12px;
        }
      </style>
      <link href="https://fonts.googleapis.com/css?family=Exo+2" rel="stylesheet">
      <script src="https://ajax.googleapis.com/ajax/libs/webfont/1.6.26/webfont.js"></script>
    
      <script>
        window.ICONS24 = {
          'ic00': '',
          'ic01': '',
          'ic02': '',
          'ic03': '',
          'ic04': '',
          'ic05': '',
          'ic06': '',
          'ic07': '',
          'ic08': '',
          'ic09': '',
          'ic10': '',
          'ic11': ''
        };
      </script>
    
      <script src="https://cdn.zingchart.com/zingchart.min.js"></script>
      <style>
        html,
        body {
          height: 100%;
          width: 100%;
          margin: 0;
          padding: 0;
        }
    
        #myChart {
          height: 100%;
          width: 100%;
          min-height: 150px;
        }
    
        .zc-ref {
          display: none;
        }
      </style>
    </head>
    
    <body>
    
      <div style="padding:5px;">
        <select id="n">
    		<option value="5">5</option>
    		<option value="6">6</option>
    		<option value="7">7</option>
    		<option value="8">8</option>
    		<option value="9">9</option>
    		<option value="10">10</option>
    		<option value="11">11</option>
    		<option value="12" selected="selected">12</option>
    	</select> elements,
        <select id="a">
    		<option value="180">180</option>
    		<option value="270">270</option>
    		<option value="360" selected="selected">360</option>
    	</select> aperture, starting at
        <select id="ra">
    		<option value="0">0</option>
    		<option value="45">45</option>
    		<option value="90">90</option>
    		<option value="135">135</option>
    		<option value="180">180</option>
    		<option value="225">225</option>
    		<option value="270" selected="selected">270</option>
    		<option value="315">315</option>
    	</select> degrees, with
        <select id="an">
    		<option value="-1" selected="selected">no animation</option>
    		<option value="0">effect 0</option>
    		<option value="1">effect 1</option>
    		<option value="2">effect 2</option>
    		<option value="3">effect 3</option>
    		<option value="4">effect 4</option>
    	</select>,
        <select id="s">
    		<option value="0" selected="selected">non-sequenced</option>
    		<option value="1">in sequence</option>
    	</select>
        <button id="r">Render</button>
      </div>
    
      <div id="zc"></div>
    
      <script>
        ZC.LICENSE = ["569d52cefae586f634c54f86dc99e6a9", "b55b025e438fa8a98e32482b5f768ff5"];
        var aPalette = [
          '#F6842E', '#FBAC33', '#8AC340', '#46B863', '#41BC9F', '#29C2EC',
          '#387EC3', '#5253A3', '#764199', '#962871', '#C87F8A', '#F14F42'
        ];
        var aIcons = [
          'ic00', 'ic01', 'ic02', 'ic03', 'ic04', 'ic05',
          'ic06', 'ic07', 'ic08', 'ic09', 'ic10', 'ic11'
        ];
        var aText = [
          'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
          'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
          'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
          'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
          'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
          'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.'
        ];
        var aTooltipText = [
          'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum',
          'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum'
        ];
    
        var render = function() {
    
          var cdata = {
            resources: [{
              type: 'css',
              url: 'https://fonts.googleapis.com/css?family=Exo+2'
            }],
            type: 'pie',
            plotarea: {
              margin: 0
            },
            scaleR: {
              aperture: parseInt(a.value, 10),
              refAngle: parseInt(ra.value, 10)
            },
            plot: {
              detach: false,
              borderWidth: 0,
              borderColor: '#fff',
              slice: '19%',
              pieTransform: 'fold=60',
              hoverState: {
                visible: false
              }
            },
            series: []
          };
    
          if (an.value !== '-1') {
            cdata['plot'].animation = {
              speed: 200,
              method: 0,
              effect: parseInt(an.value, 10),
              sequence: parseInt(s.value, 10)
            };
          }
    
          var items = parseInt(n.value, 10);
    
          for (var i = 0; i < items; i++) {
            var no = i + 1;
            cdata['series'].push({
              values: [1],
              tooltipText: aTooltipText[i],
              dataNo: ((no <= 9) ? '0' + no : no),
              valueBox: [{
                  width: 48,
                  height: 48,
                  placement: 'fixed=90%;75%',
                  borderRadius: 23,
                  borderWidth: 0,
                  fontSize: 6,
                  shadow: false,
                  color: '#4B4B4B',
                  decimals: 0,
                  fontFamily: '"Exo 2"',
                  text: '<span style="font-size:27px">%data-no</span><br><span style="font-size:9px;color:' + aPalette[i] + '">\u2002\u2002OPTION</span>'
                },
                {
                  width: 24,
                  height: 24,
                  placement: 'fixed=80%;6',
                  backgroundColor: 'none',
                  shadow: false,
                  backgroundImage: ICONS24[aIcons[i]],
                  backgroundRepeat: 'no-repeat',
                  text: ' '
                },
                {
                  align: 'left',
                  placement: 'fixed=55%;50%',
                  backgroundColor: 'none',
                  shadow: false,
                  fontSize: 9,
                  text: aText[i]
                }
              ],
              backgroundColor: aPalette[i],
              gradientColors: ['#eee', '#eee', aPalette[i], aPalette[i]].join(' '),
              gradientStops: [0.001, 0.30, 0.31, 0.35, 0.36, 0.5].join(' ')
            });
          }
    
          zingchart.render({
            id: 'zc',
            width: 600,
            height: 600,
            output: 'svg',
            data: cdata,
            events: {
              animation_end: function(p) {
                if (an.value !== '-1') {
                  addElements(p);
                }
              },
              load: function(p) {
                if (an.value === '-1') {
                  addElements(p);
                }
              }
            }
          });
        }
    
        window.addEventListener('load', function() {
    
          WebFont.load({
            google: {
              families: ['Exo 2']
            },
            active: function() {
    
              r.addEventListener('click', function() {
                render();
              });
              render();
    
              var _cpoint_ = function(iX, iY, iR, iAngle) {
                return [iX + iR * Math.cos(iAngle * 2 * Math.PI / 360), iY + iR * Math.sin(iAngle * 2 * Math.PI / 360)];
              }
    
              window.addElements = function(p) {
                var iPlots = zingchart.exec(p.id, 'getplotlength');
                var aObjects = [],
                  oInfo;
                for (var i = 0; i < iPlots; i++) {
                  oInfo = zingchart.exec(p.id, 'getobjectinfo', {
                    object: 'node',
                    plotindex: i,
                    nodeindex: 0
                  });
                  var iSlice = oInfo.size * oInfo.slice;
                  var aCP = _cpoint_(oInfo.x, oInfo.y, (iSlice + oInfo.size) / 2 - 4, oInfo.angleStart);
    
                  aObjects.push({
                    id: 'sh' + i,
                    anchor: 'c',
                    x: aCP[0],
                    y: aCP[1],
                    width: (oInfo.size - iSlice) - 2,
                    height: 10,
                    backgroundColor: '#eee',
                    angle: oInfo.angleStart,
                    gradientColors: 'rgba(0,0,0,0) rgba(0,0,0,0) rgba(100,100,100,0.5) rgba(100,100,100,0.4) rgba(100,100,100,0.3) rgba(100,100,100,0.2) rgba(100,100,100,0.1) rgba(100,100,100,0)',
                    gradientStops: '0.01 0.5 0.51 0.6 0.7 0.8 0.9 0.99'
                  });
                }
    
                aObjects.push({
                  x: oInfo.x,
                  y: oInfo.y,
                  width: 1.75 * oInfo.slice * oInfo.size,
                  fontFamily: '"Exo 2"',
                  fontSize: 14,
                  align: 'center',
                  fontWeight: 600,
                  color: '#000',
                  anchor: 'c',
                  text: 'INFOGRAPHIC<br>TEMPLATE'
                });
    
                zingchart.exec(p.id, 'addobject', {
                  type: 'label',
                  data: aObjects
                });
              };
    
            }
    
          });
    
        });
      </script>
    </body>
    
    </html>
    <!DOCTYPE html>
    <html>
    
    <head>
      <meta charset="utf-8">
      <title>ZingSoft Demo</title>
      <style>
        * {
          font-family: 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans';
          font-size: 12px;
        }
      </style>
      <link href="https://fonts.googleapis.com/css?family=Exo+2" rel="stylesheet">
      <script src="https://ajax.googleapis.com/ajax/libs/webfont/1.6.26/webfont.js"></script>
    
      <script>
        window.ICONS24 = {
          'ic00': '',
          'ic01': '',
          'ic02': '',
          'ic03': '',
          'ic04': '',
          'ic05': '',
          'ic06': '',
          'ic07': '',
          'ic08': '',
          'ic09': '',
          'ic10': '',
          'ic11': ''
        };
      </script>
    
      <script src="https://cdn.zingchart.com/zingchart.min.js"></script>
    </head>
    
    <body>
    
      <div style="padding:5px;">
        <select id="n">
    		<option value="5">5</option>
    		<option value="6">6</option>
    		<option value="7">7</option>
    		<option value="8">8</option>
    		<option value="9">9</option>
    		<option value="10">10</option>
    		<option value="11">11</option>
    		<option value="12" selected="selected">12</option>
    	</select> elements,
        <select id="a">
    		<option value="180">180</option>
    		<option value="270">270</option>
    		<option value="360" selected="selected">360</option>
    	</select> aperture, starting at
        <select id="ra">
    		<option value="0">0</option>
    		<option value="45">45</option>
    		<option value="90">90</option>
    		<option value="135">135</option>
    		<option value="180">180</option>
    		<option value="225">225</option>
    		<option value="270" selected="selected">270</option>
    		<option value="315">315</option>
    	</select> degrees, with
        <select id="an">
    		<option value="-1" selected="selected">no animation</option>
    		<option value="0">effect 0</option>
    		<option value="1">effect 1</option>
    		<option value="2">effect 2</option>
    		<option value="3">effect 3</option>
    		<option value="4">effect 4</option>
    	</select>,
        <select id="s">
    		<option value="0" selected="selected">non-sequenced</option>
    		<option value="1">in sequence</option>
    	</select>
        <button id="r">Render</button>
      </div>
    
      <div id="zc"></div>
    
    </body>
    
    </html>
    html,
    body {
      height: 100%;
      width: 100%;
      margin: 0;
      padding: 0;
    }
    
    #myChart {
      height: 100%;
      width: 100%;
      min-height: 150px;
    }
    
    .zc-ref {
      display: none;
    }
    var aPalette = [
      '#F6842E', '#FBAC33', '#8AC340', '#46B863', '#41BC9F', '#29C2EC',
      '#387EC3', '#5253A3', '#764199', '#962871', '#C87F8A', '#F14F42'
    ];
    var aIcons = [
      'ic00', 'ic01', 'ic02', 'ic03', 'ic04', 'ic05',
      'ic06', 'ic07', 'ic08', 'ic09', 'ic10', 'ic11'
    ];
    var aText = [
      'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
      'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
      'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
      'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
      'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.',
      'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.', 'Lorem ipsum<br>dolor sit amet,<br>consectetur<br>adipiscing elit.'
    ];
    var aTooltipText = [
      'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum',
      'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum', 'Lorem ipsum'
    ];
    
    var render = function() {
    
      var cdata = {
        resources: [{
          type: 'css',
          url: 'https://fonts.googleapis.com/css?family=Exo+2'
        }],
        type: 'pie',
        plotarea: {
          margin: 0
        },
        scaleR: {
          aperture: parseInt(a.value, 10),
          refAngle: parseInt(ra.value, 10)
        },
        plot: {
          detach: false,
          borderWidth: 0,
          borderColor: '#fff',
          slice: '19%',
          pieTransform: 'fold=60',
          hoverState: {
            visible: false
          }
        },
        series: []
      };
    
      if (an.value !== '-1') {
        cdata['plot'].animation = {
          speed: 200,
          method: 0,
          effect: parseInt(an.value, 10),
          sequence: parseInt(s.value, 10)
        };
      }
    
      var items = parseInt(n.value, 10);
    
      for (var i = 0; i < items; i++) {
        var no = i + 1;
        cdata['series'].push({
          values: [1],
          tooltipText: aTooltipText[i],
          dataNo: ((no <= 9) ? '0' + no : no),
          valueBox: [{
              width: 48,
              height: 48,
              placement: 'fixed=90%;75%',
              borderRadius: 23,
              borderWidth: 0,
              fontSize: 6,
              shadow: false,
              color: '#4B4B4B',
              decimals: 0,
              fontFamily: '"Exo 2"',
              text: '<span style="font-size:27px">%data-no</span><br><span style="font-size:9px;color:' + aPalette[i] + '">\u2002\u2002OPTION</span>'
            },
            {
              width: 24,
              height: 24,
              placement: 'fixed=80%;6',
              backgroundColor: 'none',
              shadow: false,
              backgroundImage: ICONS24[aIcons[i]],
              backgroundRepeat: 'no-repeat',
              text: ' '
            },
            {
              align: 'left',
              placement: 'fixed=55%;50%',
              backgroundColor: 'none',
              shadow: false,
              fontSize: 9,
              text: aText[i]
            }
          ],
          backgroundColor: aPalette[i],
          gradientColors: ['#eee', '#eee', aPalette[i], aPalette[i]].join(' '),
          gradientStops: [0.001, 0.30, 0.31, 0.35, 0.36, 0.5].join(' ')
        });
      }
    
      zingchart.render({
        id: 'zc',
        width: 600,
        height: 600,
        output: 'svg',
        data: cdata,
        events: {
          animation_end: function(p) {
            if (an.value !== '-1') {
              addElements(p);
            }
          },
          load: function(p) {
            if (an.value === '-1') {
              addElements(p);
            }
          }
        }
      });
    }
    
    window.addEventListener('load', function() {
    
      WebFont.load({
        google: {
          families: ['Exo 2']
        },
        active: function() {
    
          r.addEventListener('click', function() {
            render();
          });
          render();
    
          var _cpoint_ = function(iX, iY, iR, iAngle) {
            return [iX + iR * Math.cos(iAngle * 2 * Math.PI / 360), iY + iR * Math.sin(iAngle * 2 * Math.PI / 360)];
          }
    
          window.addElements = function(p) {
            var iPlots = zingchart.exec(p.id, 'getplotlength');
            var aObjects = [],
              oInfo;
            for (var i = 0; i < iPlots; i++) {
              oInfo = zingchart.exec(p.id, 'getobjectinfo', {
                object: 'node',
                plotindex: i,
                nodeindex: 0
              });
              var iSlice = oInfo.size * oInfo.slice;
              var aCP = _cpoint_(oInfo.x, oInfo.y, (iSlice + oInfo.size) / 2 - 4, oInfo.angleStart);
    
              aObjects.push({
                id: 'sh' + i,
                anchor: 'c',
                x: aCP[0],
                y: aCP[1],
                width: (oInfo.size - iSlice) - 2,
                height: 10,
                backgroundColor: '#eee',
                angle: oInfo.angleStart,
                gradientColors: 'rgba(0,0,0,0) rgba(0,0,0,0) rgba(100,100,100,0.5) rgba(100,100,100,0.4) rgba(100,100,100,0.3) rgba(100,100,100,0.2) rgba(100,100,100,0.1) rgba(100,100,100,0)',
                gradientStops: '0.01 0.5 0.51 0.6 0.7 0.8 0.9 0.99'
              });
            }
    
            aObjects.push({
              x: oInfo.x,
              y: oInfo.y,
              width: 1.75 * oInfo.slice * oInfo.size,
              fontFamily: '"Exo 2"',
              fontSize: 14,
              align: 'center',
              fontWeight: 600,
              color: '#000',
              anchor: 'c',
              text: 'INFOGRAPHIC<br>TEMPLATE'
            });
    
            zingchart.exec(p.id, 'addobject', {
              type: 'label',
              data: aObjects
            });
          };
    
        }
    
      });
    
    });