• 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.ICONS32 = {
                '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;
            }
    
            zing-grid[loading] {
                height: 600px;
            }
        </style>
    </head>
    
    <body>
    
        <div style="padding:5px;">
            <select id="n">
                <option value="2">2</option>
                <option value="3">3</option>
                <option value="4">4</option>
                <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="90">90</option>
                <option value="180">180</option>
                <option value="270">270</option>
                <option value="360" selected="selected">360</option>
            </select> aperture, from
            <select id="ra">
                <option value="0" selected="selected">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">270</option>
                <option value="315">315</option>
            </select> deg,
            <select id="an">
                <option value="-1">no animation</option>
                <option value="0">effect 0</option>
                <option value="1">effect 1</option>
                <option value="2">effect 2</option>
                <option value="3" selected="selected">effect 3</option>
                <option value="4">effect 4</option>
            </select>,
            <select id="s">
                <option value="0">no-sequence</option>
                <option value="1" selected="selected">sequenced</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: '25%',
                        pieTransform: 'bite=10',
                        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: 40,
                                height: 40,
                                placement: 'fixed=95%;5',
                                borderRadius: 23,
                                fontSize: 27,
                                shadow: false,
                                color: '#000',
                                decimals: 0,
                                fontFamily: '"Exo 2"',
                                text: '%data-no'
                            },
                            {
                                width: 32,
                                height: 32,
                                placement: 'fixed=10%;50%',
                                backgroundColor: 'none',
                                shadow: false,
                                backgroundImage: ICONS32[aIcons[i]],
                                backgroundRepeat: 'no-repeat',
                                text: ' '
                            },
                            {
                                align: 'left',
                                placement: 'fixed=60%;50%',
                                backgroundColor: 'none',
                                shadow: false,
                                fontSize: 10,
                                text: aText[i]
                            }
                        ],
                        backgroundColor: aPalette[i],
                        gradientColors: [aPalette[i], aPalette[i], '#eee', '#eee', aPalette[i], aPalette[i]].join(' '),
                        gradientStops: [0.001, 0.40, 0.41, 0.45, 0.46, 0.99].join(' ')
                    });
                }
    
                zingchart.render({
                    id: 'zc',
                    width: 600,
                    height: 600,
                    output: 'svg',
                    data: cdata,
                    events: {
                        animation_end: function(p) {
                            if ($('#an').val() !== '-1') {
                                addElements(p);
                            }
                        },
                        load: function(p) {
                            if ($('#an').val() === '-1') {
                                addElements(p);
                            }
                        }
                    }
                });
    
            }
    
            window.addEventListener('load', function() {
    
                WebFont.load({
                    google: {
                        families: ['Exo 2']
                    },
                    active: function() {
    
                        r.addEventListener('click', function() {
                            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, oInfo.angleStart);
                                aObjects.push({
                                    id: 'sh' + i,
                                    anchor: 'c',
                                    x: aCP[0],
                                    y: aCP[1],
                                    width: (oInfo.size - iSlice) - 2,
                                    height: 20,
                                    backgroundColor: '#ccc',
                                    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,
                                height: 60,
                                fontFamily: '"Exo 2"',
                                fontSize: 47,
                                paddingLeft: 5,
                                align: 'left',
                                fontWeight: 900,
                                color: '#F14F42',
                                anchor: 'c',
                                text: iPlots
                            }, {
                                x: oInfo.x,
                                y: oInfo.y,
                                width: 1.75 * oInfo.slice * oInfo.size,
                                height: 60,
                                paddingLeft: 55,
                                fontFamily: '"Exo 2"',
                                fontSize: 11,
                                align: 'left',
                                fontWeight: 600,
                                color: '#000',
                                anchor: 'c',
                                text: 'OPTIONS<br>INFOGRAPHIC<br>TEMPLATE'
                            });
                            zingchart.exec(p.id, 'addobject', {
                                type: 'label',
                                data: aObjects
                            });
                        };
    
                        render();
    
                    }
                });
    
            });
        </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.ICONS32 = {
    	'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="2">2</option>
    		<option value="3">3</option>
    		<option value="4">4</option>
    		<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="90">90</option>
    		<option value="180">180</option>
    		<option value="270">270</option>
    		<option value="360" selected="selected">360</option>
    	</select> aperture, from 
    	<select id="ra">
    		<option value="0" selected="selected">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">270</option>
    		<option value="315">315</option>
    	</select> deg,
    	<select id="an">
    		<option value="-1">no animation</option>
    		<option value="0">effect 0</option>
    		<option value="1">effect 1</option>
    		<option value="2">effect 2</option>
    		<option value="3" selected="selected">effect 3</option>
    		<option value="4">effect 4</option>
    	</select>, 
    	<select id="s">
    		<option value="0">no-sequence</option>
    		<option value="1" selected="selected">sequenced</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 : '25%',
    			pieTransform : 'bite=10',
    			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 : 40,
    					height : 40,
    					placement : 'fixed=95%;5',
    					borderRadius : 23,
    					fontSize : 27,
    					shadow : false,
    					color : '#000',
    					decimals : 0,
    					fontFamily : '"Exo 2"',
    					text : '%data-no'
    				},
    				{
    					width : 32,
    					height : 32,
    					placement : 'fixed=10%;50%',
    					backgroundColor : 'none',
    					shadow : false,
    					backgroundImage : ICONS32[aIcons[i]],
    					backgroundRepeat : 'no-repeat',
    					text : ' '
    				},
    				{
    					align : 'left',
    					placement : 'fixed=60%;50%',
    					backgroundColor : 'none',
    					shadow : false,
    					fontSize : 10,
    					text : aText[i]
    				}
    			],
    			backgroundColor : aPalette[i],
    			gradientColors : [aPalette[i], aPalette[i], '#eee', '#eee', aPalette[i], aPalette[i]].join(' '),
    			gradientStops : [0.001, 0.40, 0.41, 0.45, 0.46, 0.99].join(' ')
    		});
    	}
    
    	zingchart.render({
    		id : 'zc',
    		width : 600,
    		height : 600,
    		output : 'svg',
    		data : cdata,
    		events : {
    			animation_end : function(p) {
    				if ($('#an').val() !== '-1') { 
    					addElements(p);
    				}
    			},
    			load : function(p) {
    				if ($('#an').val() === '-1') { 
    					addElements(p);
    				}
    			}
    		}
    	});
    
    }
    
    window.addEventListener('load', function() {
    	
    WebFont.load({
    	google : {
    		families: ['Exo 2']
    	},
    	active : function() {
    
    		r.addEventListener('click',function() {
    			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, oInfo.angleStart);
    				aObjects.push({
    					id : 'sh'+i,
    					anchor : 'c',
    					x : aCP[0],
    					y : aCP[1],
    					width : (oInfo.size - iSlice) - 2,
    					height : 20,
    					backgroundColor : '#ccc',
    					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,
    					height : 60,
    					fontFamily : '"Exo 2"',
    					fontSize : 47,
    					paddingLeft : 5,
    					align : 'left',
    					fontWeight : 900,
    					color : '#F14F42',
    					anchor : 'c',
    					text : iPlots
    				},
    				{
    					x : oInfo.x,
    					y : oInfo.y,
    					width : 1.75*oInfo.slice*oInfo.size,
    					height : 60,
    					paddingLeft : 55,
    					fontFamily : '"Exo 2"',
    					fontSize : 11,
    					align : 'left',
    					fontWeight : 600,
    					color : '#000',
    					anchor : 'c',
    					text : 'OPTIONS<br>INFOGRAPHIC<br>TEMPLATE'
    				}
    			);
    			zingchart.exec(p.id, 'addobject', {
    				type : 'label',
    				data : aObjects
    			});
    		};
    
    		render();
    
    	}
    });
    
    });