- <!DOCTYPE html>
- <html>
-
- <head>
- <meta charset="utf-8">
- <title>ZingSoft Demo</title>
-
- <script nonce="undefined" 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 id="zc"></div>
- <script>
- ZC.LICENSE = ["569d52cefae586f634c54f86dc99e6a9", "b55b025e438fa8a98e32482b5f768ff5"];
- window.addEventListener('load', function() {
-
- var pattern = '';
- var states = ['AL', 'AK', 'AZ', 'AR', 'CA', 'CO', 'CT', 'DE', 'DC', 'FL', 'GA', 'HI', 'ID', 'IL', 'IN', 'IA', 'KS', 'KY', 'LA', 'ME', 'MD', 'MA', 'MI', 'MN', 'MS', 'MO', 'MT', 'NE', 'NV', 'NH', 'NJ', 'NM', 'NY', 'NC', 'ND', 'OH', 'OK', 'OR', 'PA', 'RI', 'SC', 'SD', 'TN', 'TX', 'UT', 'VT', 'VA', 'WA', 'WV', 'WI', 'WY'];
- var metrics = ['Schools', 'Hate Crimes', 'Housing', 'Employment', 'Adoption', 'Hospital Visits', 'Marriage'];
- var palette = ['#7EC2EB', '#833C99', '#D1028A', '#87BC38', '#0060A8', '#EFBA4D', '#CE2C20'];
- var levels = {
- '-1': 'Prohibited or banned',
- '0': 'No law or unclear',
- '0.5': 'Limited',
- '1': 'Maximum'
- };
-
- var cdata = {
- backgroundColor: '#fff',
- graphset: [{
- x: 0,
- y: 0,
- width: '100%',
- height: '100%',
- backgroundColor: 'none',
- type: 'radar',
- plotarea: {
- margin: 10
- },
- scale: {
- sizeFactor: 0.9
- },
- scaleV: {
- offsetStart: 120,
- visible: false
- },
- scaleK: {
- values: states,
- aspect: 'circle',
- ranged: true,
- guide: {
- visible: false
- },
- tick: {
- visible: false
- }
- },
- plot: {
- borderWidth: 1,
- borderColor: '#fff',
- angleSpace: 0,
- animation: {
- speed: 50,
- effect: 1,
- sequence: 1
- },
- aspect: 'piano',
- jsRule: 'plot_jsRule(0)'
- },
- tooltip: {
- padding: 10,
- fontSize: 13,
- color: '#fff',
- backgroundColor: '#333',
- text: '%plot-text in %scale-key-text: %data-level'
- },
- series: []
- },
- {
- x: 0,
- y: 0,
- width: '100%',
- height: '100%',
- backgroundColor: 'none',
- type: 'radar',
- plotarea: {
- margin: 10
- },
- scale: {
- sizeFactor: 0.275
- },
- scaleK: {
- values: ['Limited', 'Maximum'],
- aperture: 90,
- refAngle: 180,
- ranged: true,
- item: {
- fontSize: 10,
- fontWeight: 'bold',
- autoRotate: true,
- color: '#000'
- },
- guide: {
- visible: false
- },
- tick: {
- visible: false
- }
- },
- scaleV: {
- offsetStart: 10,
- visible: false
- },
- plot: {
- maxTrackers: 0,
- aspect: 'piano',
- angleSpace: 0,
- borderWidth: 0,
- jsRule: 'plot_jsRule(1)'
- },
- series: [],
- labels: [{
- flat: true,
- x: '50%',
- y: '50%',
- offsetY: 5,
- offsetX: -85,
- backgroundColor: '#ccc',
- backgroundImage: pattern,
- alpha: 0.75,
- width: 10,
- height: 10
- },
- {
- flat: true,
- x: '50%',
- y: '50%',
- fontSize: 10,
- fontWeight: 'bold',
- offsetY: 2,
- offsetX: -70,
- text: 'Prohibited or banned'
- },
- {
- flat: true,
- x: '50%',
- y: '50%',
- offsetY: 20,
- offsetX: -85,
- backgroundColor: '#ccc',
- width: 10,
- height: 10
- },
- {
- flat: true,
- x: '50%',
- y: '50%',
- offsetY: 17,
- offsetX: -70,
- fontSize: 10,
- fontWeight: 'bold',
- text: 'No law or unclear'
- }
- ]
- },
- {
- x: 0,
- y: 0,
- width: '100%',
- height: '100%',
- backgroundColor: 'none',
- type: 'radar',
- title: {
- text: 'Rights by type',
- y: '50%',
- offsetY: 40
- },
- plotarea: {
- margin: 10
- },
- scale: {
- sizeFactor: 0.275
- },
- scaleK: {
- visible: false,
- },
- scaleV: {
- offsetStart: 15,
- offsetEnd: 5,
- values: metrics,
- labels: metrics,
- maxItems: metrics.length,
- itemsOverlap: true,
- refLine: {
- visible: false
- },
- item: {
- fontSize: 10,
- fontWeight: 'bold',
- color: '#000'
- },
- guide: {
- visible: false
- },
- tick: {
- visible: false
- }
- }
- }
- ]
- };
-
- window.plot_jsRule = function(p, chart) {
- var obj = {};
- switch (p.value) {
- case -1:
- obj = {
- backgroundColor: '#ccc',
- backgroundImage: pattern,
- alpha: 0.75
- };
- break;
- case 0:
- obj = {
- backgroundColor: '#ccc'
- };
- break;
- case 0.5:
- obj = {
- backgroundColor: palette[p.plotindex],
- alpha: 0.35
- };
- break;
- case 1:
- obj = {
- backgroundColor: palette[p.plotindex],
- alpha: 1
- };
- break;
- }
- return obj;
- };
-
- for (var m = 0; m < metrics.length; m++) {
- var values = [],
- dataLevels = [];
- for (var s = 0; s < states.length; s++) {
- /*
- -1 = Prohibited or banned
- 0 = No law or unclear
- 0.5 = Limited
- 1 = Maximum
- */
- var r = Math.random(),
- v = 0;
- if (r >= 0 && r < 0.2) {
- v = -1;
- } else if (r >= 0.2 && r < 0.4) {
- v = 0;
- } else if (r >= 0.4 && r < 0.7) {
- v = 0.5;
- } else {
- v = 1;
- }
- values.push(v);
- dataLevels.push(levels[v]);
- }
- cdata.graphset[0].series.push({
- values: values,
- text: metrics[m],
- dataLevel: dataLevels
- });
- cdata.graphset[1].series.push({
- values: [0.5, 1],
- text: metrics[m]
- });
- }
-
- zingchart.render({
- id: 'zc',
- width: 640,
- height: 640,
- output: 'svg',
- data: cdata
- });
-
- });
- </script>
- </body>
-
- </html>
- <!DOCTYPE html>
- <html>
-
- <head>
- <meta charset="utf-8">
- <title>ZingSoft Demo</title>
-
- <script src="https://cdn.zingchart.com/zingchart.min.js"></script>
- </head>
-
- <body>
- <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;
- }
- window.addEventListener('load', function() {
-
- var pattern = '';
- var states = ['AL', 'AK', 'AZ', 'AR', 'CA', 'CO', 'CT', 'DE', 'DC', 'FL', 'GA', 'HI', 'ID', 'IL', 'IN', 'IA', 'KS', 'KY', 'LA', 'ME', 'MD', 'MA', 'MI', 'MN', 'MS', 'MO', 'MT', 'NE', 'NV', 'NH', 'NJ', 'NM', 'NY', 'NC', 'ND', 'OH', 'OK', 'OR', 'PA', 'RI', 'SC', 'SD', 'TN', 'TX', 'UT', 'VT', 'VA', 'WA', 'WV', 'WI', 'WY'];
- var metrics = ['Schools', 'Hate Crimes', 'Housing', 'Employment', 'Adoption', 'Hospital Visits', 'Marriage'];
- var palette = ['#7EC2EB', '#833C99', '#D1028A', '#87BC38', '#0060A8', '#EFBA4D', '#CE2C20'];
- var levels = {
- '-1': 'Prohibited or banned',
- '0': 'No law or unclear',
- '0.5': 'Limited',
- '1': 'Maximum'
- };
-
- var cdata = {
- backgroundColor: '#fff',
- graphset: [{
- x: 0,
- y: 0,
- width: '100%',
- height: '100%',
- backgroundColor: 'none',
- type: 'radar',
- plotarea: {
- margin: 10
- },
- scale: {
- sizeFactor: 0.9
- },
- scaleV: {
- offsetStart: 120,
- visible: false
- },
- scaleK: {
- values: states,
- aspect: 'circle',
- ranged: true,
- guide: {
- visible: false
- },
- tick: {
- visible: false
- }
- },
- plot: {
- borderWidth: 1,
- borderColor: '#fff',
- angleSpace: 0,
- animation: {
- speed: 50,
- effect: 1,
- sequence: 1
- },
- aspect: 'piano',
- jsRule: 'plot_jsRule(0)'
- },
- tooltip: {
- padding: 10,
- fontSize: 13,
- color: '#fff',
- backgroundColor: '#333',
- text: '%plot-text in %scale-key-text: %data-level'
- },
- series: []
- },
- {
- x: 0,
- y: 0,
- width: '100%',
- height: '100%',
- backgroundColor: 'none',
- type: 'radar',
- plotarea: {
- margin: 10
- },
- scale: {
- sizeFactor: 0.275
- },
- scaleK: {
- values: ['Limited', 'Maximum'],
- aperture: 90,
- refAngle: 180,
- ranged: true,
- item: {
- fontSize: 10,
- fontWeight: 'bold',
- autoRotate: true,
- color: '#000'
- },
- guide: {
- visible: false
- },
- tick: {
- visible: false
- }
- },
- scaleV: {
- offsetStart: 10,
- visible: false
- },
- plot: {
- maxTrackers: 0,
- aspect: 'piano',
- angleSpace: 0,
- borderWidth: 0,
- jsRule: 'plot_jsRule(1)'
- },
- series: [],
- labels: [{
- flat: true,
- x: '50%',
- y: '50%',
- offsetY: 5,
- offsetX: -85,
- backgroundColor: '#ccc',
- backgroundImage: pattern,
- alpha: 0.75,
- width: 10,
- height: 10
- },
- {
- flat: true,
- x: '50%',
- y: '50%',
- fontSize: 10,
- fontWeight: 'bold',
- offsetY: 2,
- offsetX: -70,
- text: 'Prohibited or banned'
- },
- {
- flat: true,
- x: '50%',
- y: '50%',
- offsetY: 20,
- offsetX: -85,
- backgroundColor: '#ccc',
- width: 10,
- height: 10
- },
- {
- flat: true,
- x: '50%',
- y: '50%',
- offsetY: 17,
- offsetX: -70,
- fontSize: 10,
- fontWeight: 'bold',
- text: 'No law or unclear'
- }
- ]
- },
- {
- x: 0,
- y: 0,
- width: '100%',
- height: '100%',
- backgroundColor: 'none',
- type: 'radar',
- title: {
- text: 'Rights by type',
- y: '50%',
- offsetY: 40
- },
- plotarea: {
- margin: 10
- },
- scale: {
- sizeFactor: 0.275
- },
- scaleK: {
- visible: false,
- },
- scaleV: {
- offsetStart: 15,
- offsetEnd: 5,
- values: metrics,
- labels: metrics,
- maxItems: metrics.length,
- itemsOverlap: true,
- refLine: {
- visible: false
- },
- item: {
- fontSize: 10,
- fontWeight: 'bold',
- color: '#000'
- },
- guide: {
- visible: false
- },
- tick: {
- visible: false
- }
- }
- }
- ]
- };
-
- window.plot_jsRule = function(p, chart) {
- var obj = {};
- switch (p.value) {
- case -1:
- obj = {
- backgroundColor: '#ccc',
- backgroundImage: pattern,
- alpha: 0.75
- };
- break;
- case 0:
- obj = {
- backgroundColor: '#ccc'
- };
- break;
- case 0.5:
- obj = {
- backgroundColor: palette[p.plotindex],
- alpha: 0.35
- };
- break;
- case 1:
- obj = {
- backgroundColor: palette[p.plotindex],
- alpha: 1
- };
- break;
- }
- return obj;
- };
-
- for (var m = 0; m < metrics.length; m++) {
- var values = [],
- dataLevels = [];
- for (var s = 0; s < states.length; s++) {
- /*
- -1 = Prohibited or banned
- 0 = No law or unclear
- 0.5 = Limited
- 1 = Maximum
- */
- var r = Math.random(),
- v = 0;
- if (r >= 0 && r < 0.2) {
- v = -1;
- } else if (r >= 0.2 && r < 0.4) {
- v = 0;
- } else if (r >= 0.4 && r < 0.7) {
- v = 0.5;
- } else {
- v = 1;
- }
- values.push(v);
- dataLevels.push(levels[v]);
- }
- cdata.graphset[0].series.push({
- values: values,
- text: metrics[m],
- dataLevel: dataLevels
- });
- cdata.graphset[1].series.push({
- values: [0.5, 1],
- text: metrics[m]
- });
- }
-
- zingchart.render({
- id: 'zc',
- width: 640,
- height: 640,
- output: 'svg',
- data: cdata
- });
-
- });