Welcome to IOPWiki, Commander.
We are searching for new editors to keep track of Girls' Frontline 2 content, as well as veteran players to complete existing Girls' Frontline and Project Neural Cloud articles.
You can contribute without an account. Learn how to contribute and join our Discord server.

Widget:StatsGraph: Difference between revisions

Welcome to IOP Wiki. This website is maintained by the Girls' Frontline community and is free to edit by anyone.
Jump to navigation Jump to search
Removed width/height for now and fixed wrong attribute key
m Wrong variable
 
(27 intermediate revisions by the same user not shown)
Line 1: Line 1:
<includeonly><div id="<!--{$graphId|escape:'html'}-->"></div><script>function getRadianForAttribute(attr) {
<includeonly><div class="stats-graph-container"><script>
  if (attr == 1) return -60;
function calcCoordinate(degree, min, max, val) {
  if (attr == 2) return -120;
  if (attr == 3) return -180;
  if (attr == 4) return -240;
  if (attr == 5) return -300;
  return 0;
}
 
function calcCoordinate(attr, min, max, val) {
    
    
   var oldX = 0;
   var oldX = 0;
   var oldY = (max-min) == 0 ? 0 : (300 / (max-min)) * (val - min);
   var oldY = (max-min) == 0 ? 0 : -(300 / (max-min)) * (val - min);
    
    
   if (attr == 0) {
   if (degree == 0) {
     return [oldX, Math.floor(oldY)];
     return [oldX, Math.floor(oldY)];
   }
   }
    
    
   var rotate = (getRadianForAttribute(attr) * Math.PI) / 180;
   var rotate = (-degree * Math.PI) / 180;
    
    
   var newX = oldX*Math.cos(rotate)+oldY*Math.sin(rotate);
   var newX = oldX*Math.cos(rotate)+oldY*Math.sin(rotate);
Line 26: Line 18:
function buildPolygonString(data) {
function buildPolygonString(data) {
   var ret = "";
   var ret = "";
   for (var i=0;i<6;i++) {
  var degreeSpacing = 360 / data.length;
     var coord = calcCoordinate(i, data[i][1], data[i][2], data[i][3]);
   for (var i=0;i<data.length;i++) {
     var coord = calcCoordinate(degreeSpacing*i, data[i].min, data[i].max, data[i].value);
     ret += coord[0] + "," + coord[1] + " ";
     ret += coord[0] + "," + coord[1] + " ";
   }
   }
Line 34: Line 27:
}
}


function buildGraph(graphId, data) {
function buildGraph(dataComplete) {
   var svg = document.createElementNS("http://www.w3.org/2000/svg", "svg");
   var svg = document.createElementNS("http://www.w3.org/2000/svg", "svg");
   var svgNS = svg.namespaceURI;
   var svgNS = svg.namespaceURI;
   svg.setAttributeNS("http://www.w3.org/2000/xmlns/", "xmlns:xlink", "http://www.w3.org/1999/xlink");
   var svgLinkNS = "http://www.w3.org/1999/xlink";
  svg.setAttributeNS("http://www.w3.org/2000/xmlns/", "xmlns:xlink", svgLinkNS);
   svg.setAttribute('viewBox', "0 0 800 800");
   svg.setAttribute('viewBox', "0 0 800 800");
   svg.setAttribute('preserveAspectRatio', "none");
   svg.setAttribute('preserveAspectRatio', "xMidyMid meet");
  svg.setAttribute('width', "300px");
  svg.setAttribute('height', "auto");
   svg.setAttribute('version', "1.1");
   svg.setAttribute('version', "1.1");
  /* Inline styling; maybe export to common.css? */
  var style = document.createElementNS(svgNS, 'style');
  style.setAttribute('type', "text/css");
  var styleData = document.createTextNode('line.radial {stroke: #333;stroke-width: 4pt;}polygon {stroke-width: 4pt;}svg {fill: none;stroke: #777;stroke-opacity: 1;stroke-width: 1pt;}text {fill: #000;font-family: Arial, Helvetica, sans-serif;font-size: 2.5em;font-weight: normal;stroke: none;text-anchor: middle;}.unit { stroke: #f73; }');
  style.appendChild(styleData);
  svg.appendChild(style);
    
    
   /* This pretty much defines the base net lines */
   /* This pretty much defines the base net lines */
   var defs = document.createElementNS(svgNS, 'defs');
   var defs = document.createElementNS(svgNS, 'defs');
 
 
  /* Wedge id has to be unique */
  var wedgeId = "wedge-" + 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
    var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
    return v.toString(16);
  });
 
   var wedge = document.createElementNS(svgNS, 'g');
   var wedge = document.createElementNS(svgNS, 'g');
   wedge.setAttribute('id', "wedge");
   wedge.setAttribute('id', wedgeId);
 
  var directionCount = dataComplete[0].data.length;
  var degreeSpacing = 360 / directionCount;
    
    
   var radialLine = document.createElementNS(svgNS, 'line');
   var radialLine = document.createElementNS(svgNS, 'line');
   radialLine.setAttribute('class', 'radial');
   radialLine.setAttribute('class', 'radial');
   radialLine.setAttribute('y2', 325);
   radialLine.setAttribute('y2', -325);
  wedge.appendChild(radialLine);
  radialLine = document.createElementNS(svgNS, 'line');
  radialLine.setAttribute('y1', -75);
  radialLine.setAttribute('x2', -64.95);
  radialLine.setAttribute('y2', -37.5);
  wedge.appendChild(radialLine);
  radialLine = document.createElementNS(svgNS, 'line');
  radialLine.setAttribute('y1', -150);
  radialLine.setAttribute('x2', -129.9);
  radialLine.setAttribute('y2', -75);
  radialLine.setAttribute('stroke-width', "3pt");
  wedge.appendChild(radialLine);
  radialLine = document.createElementNS(svgNS, 'line');
  radialLine.setAttribute('y1', -225);
  radialLine.setAttribute('x2', -194.86);
  radialLine.setAttribute('y2', -112.5);
  wedge.appendChild(radialLine);
  radialLine = document.createElementNS(svgNS, 'line');
  radialLine.setAttribute('y1', -300);
  radialLine.setAttribute('x2', -259.81);
  radialLine.setAttribute('y2', -150);
  radialLine.setAttribute('stroke-width', "3pt");
   wedge.appendChild(radialLine);
   wedge.appendChild(radialLine);
 
  for (var lineIdx=1;lineIdx<5;lineIdx++) {
    var orientationLine = document.createElementNS(svgNS, 'line');
    var lineDistance = lineIdx * -75;
    var rotate = (degreeSpacing * Math.PI) / 180;
    orientationLine.setAttribute('y1', lineDistance);
    orientationLine.setAttribute('x2', lineDistance*Math.sin(rotate));
    orientationLine.setAttribute('y2', lineDistance*Math.cos(rotate));
    if (lineIdx % 2 == 0) {
      orientationLine.setAttribute('class', 'emphased');
    }
    wedge.appendChild(orientationLine);
  }
   defs.appendChild(wedge);
   defs.appendChild(wedge);
   svg.appendChild(defs);
   svg.appendChild(defs);
Line 88: Line 77:
   gDrawing.setAttribute('transform', 'translate(400 400)');
   gDrawing.setAttribute('transform', 'translate(400 400)');
    
    
  var degreeSpacing = 360 / data.length;
   for (var dataIdx=0; dataIdx<directionCount; dataIdx++) {
   for (var dataIdx=0; dataIdx<data.length; dataIdx++) {
     var propertyLine = document.createElementNS(svgNS, 'use');
     var propertyLine = document.createElementNS(svgNS, 'use');
     propertyLine.setAttribute('xlink:href', "#wedge");
     propertyLine.setAttributeNS(svgLinkNS, "href", "#" + wedgeId);
     propertyLine.setAttribute('transform', "rotate(" + (degreeSpacing * dataIdx) + ")");
     propertyLine.setAttribute('transform', "rotate(" + (degreeSpacing * dataIdx) + ")");
     gDrawing.appendChild(propertyLine );
     gDrawing.appendChild(propertyLine );
   }
   }
 
  for (var dataIdx=0; dataIdx<dataComplete.length; dataIdx++) {
    var polygonParams = dataComplete[dataIdx];
    var datapresentation = document.createElementNS(svgNS, 'polygon');
   
    if ('title' in polygonParams) {
      var title = document.createElementNS(svgNS, 'title');
      title.appendChild(document.createTextNode(polygonParams.title));
      datapresentation.appendChild(title);
    }
   
    if (('fill' in polygonParams) || ('stroke' in polygonParams)) {
      if ('fill' in polygonParams) datapresentation.setAttribute('fill', polygonParams.fill);
      if ('stroke' in polygonParams) datapresentation.setAttribute('stroke', polygonParams.stroke);
    } else {
      datapresentation.setAttribute('class', polygonParams.class ? polygonParams.class : "graph-orange");
    }
    datapresentation.setAttribute('points', buildPolygonString(polygonParams.data));
    gDrawing.appendChild(datapresentation);
   
    for (var labelIdx=0; labelIdx<polygonParams.data.length; labelIdx++) {
      var polygonCornerData = polygonParams.data[labelIdx];
      var rotate = (-degreeSpacing * labelIdx * Math.PI) / 180;
     
      var label = document.createElementNS(svgNS, 'text');
      label.setAttribute('x', -340*Math.sin(rotate));
      label.setAttribute('y', -340*Math.cos(rotate));
      label.setAttribute('title', titleText);
      label.appendChild(document.createTextNode(polygonCornerData.label));


  var datapresentation = document.createElementNS(svgNS, 'polygon');
      var titleText = "" + polygonCornerData.min + " <= " + polygonCornerData.value + " <= " + polygonCornerData.max;
  datapresentation.setAttribute('class', 'unit');
      var title = document.createElementNS(svgNS, 'title');
  datapresentation.setAttribute('fill', 'orange');
      title.appendChild(document.createTextNode(titleText));
  datapresentation.setAttribute('fill-opacity', 0.5);
      label.appendChild(title);
  datapresentation.setAttribute('points', buildPolygonString(data));
     
  gDrawing.appendChild(datapresentation);
      gDrawing.appendChild(label);
    }
  }
    
    
   svg.appendChild(gDrawing);
   svg.appendChild(gDrawing);
 
 
   document.getElementById(graphId).appendChild(svg);
   var container = document.currentScript.parentNode;
  container.appendChild(svg);
}
}


  var graphData = [["Acc", 11,  16,  15], // Acc
var graphData = JSON.parse(`<!--{$data|escape:'html'}-->`.replace(/&quot;/gi, '"'));
              ["Eva", 52,  90,  71], // Eva
buildGraph(graphData);</script></div></includeonly><noinclude>{{Documentation}}</noinclude>
              ["Dmg", 23,  35,  32], // Dmg
              [ "HP",141, 238, 194], // HP
              ["RoF", 64, 101,  93], // RoF
              ["Mov", 12,  12,  12]];// Mov
 
buildGraph("<!--{$graphId|escape:'html'}-->", graphData);</script></includeonly><noinclude>{{#widget:StatsGraph|graphId=singleStatsGraph}}</noinclude>

Latest revision as of 11:54, 13 December 2019

Documentation[view] [edit] [history] [purge]

Widget to create an SVG image containing a radar chart. It is configured with a JSON string.

Parameters

Parameter name Required? Default value Description
data Yes (n/a) A JSON String containing all values. Please make sure that
  • There are at least three different properties to show. Anything below won't display correctly.
  • Each property needs a Label, Min, Max and Current value.
    • Label may be an empty string.
    • Min may be 0.

See the testcases for examples how to configure the JSON string.

Usage

See the template's testcases:


Small graph using default colors
Wiki code
{{#widget:StatsGraph
|data=[
  {
    "data": [
            { "label": "RoF", "min": 12, "max": 37, "value": 14 },
            { "label": "Acc", "min": 34, "max": 68, "value": 37 },
            { "label": "Dmg", "min": 9, "max": 12, "value": 11 }
          ]
  }
]}}
Main version
Sandbox version
Error in widget StatsGraph/sandbox: Unable to load template 'wiki:StatsGraph/sandbox'
Graph showing two graphs, second graph with different color
Wiki code
{{#widget:StatsGraph
|data=[
  {
    "data": [
            { "label": "RoF", "min": 12, "max": 37, "value": 32 },
            { "label": "Acc", "min": 12, "max": 37, "value": 32 },
            { "label": "Dmg", "min": 12, "max": 37, "value": 32 }
          ]
  },
  {
    "fill": "blue",
    "stroke": "darkblue",
    "data": [
            { "label": "RoF", "min": 12, "max": 37, "value": 34 },
            { "label": "Acc", "min": 34, "max": 68, "value": 51 },
            { "label": "Dmg", "min": 9, "max": 12, "value": 9 }
          ]
  }
]}}
Main version
Sandbox version
Error in widget StatsGraph/sandbox: Unable to load template 'wiki:StatsGraph/sandbox'
Graph with more properties
Wiki code
{{#widget:StatsGraph
|data=[
  {
    "data": [
            { "label": "RoF", "min": 12, "max": 37, "value": 14 },
            { "label": "Acc", "min": 34, "max": 68, "value": 37 },
            { "label": "Dmg", "min": 9, "max": 16, "value": 11 },
            { "label": "Dmg1", "min": 9, "max": 16, "value": 12 },
            { "label": "Dmg2", "min": 9, "max": 16, "value": 13 },
            { "label": "Dmg3", "min": 9, "max": 16, "value": 14 }
          ]
  }
]}}
Main version
Sandbox version
Error in widget StatsGraph/sandbox: Unable to load template 'wiki:StatsGraph/sandbox'