HuasoFoundries/jpgraph

View on GitHub
src/graph/RadarGrid.php

Summary

Maintainability
F
6 days
Test Coverage
<?php
 
/**
* JPGraph v4.0.3
*/
 
namespace Amenadiel\JpGraph\Graph;
 
/*
* File: JPGRAPH_RADAR.PHP
* // Description: Radar plot extension for JpGraph
* // Created: 2001-02-04
* // Ver: $Id: jpgraph_radar.php 1783 2009-08-25 11:41:01Z ljp $
* //
* // Copyright (c) Asial Corporation. All rights reserved.
*/
use Amenadiel\JpGraph\Plot;
 
/**
* @class RadarGrid
* // Description: Draws grid for the radar graph
*/
class RadarGrid
{
//extends Grid {
private $type = 'solid';
private $grid_color = '#DDDDDD';
private $show = false;
private $weight = 1;
 
public function __construct()
{
// Empty
}
 
Method name "RadarGrid::SetColor" is not in camel caps format
public function SetColor($aMajColor)
{
$this->grid_color = $aMajColor;
}
 
Method name "RadarGrid::SetWeight" is not in camel caps format
public function SetWeight($aWeight)
{
$this->weight = $aWeight;
}
 
// Specify if grid should be dashed, dotted or solid
Method name "RadarGrid::SetLineStyle" is not in camel caps format
public function SetLineStyle($aType)
{
$this->type = $aType;
}
 
// Decide if both major and minor grid should be displayed
The method Show has a boolean flag argument $aShowMajor, which is a certain sign of a Single Responsibility Principle violation.
Method name "RadarGrid::Show" is not in camel caps format
public function Show($aShowMajor = true)
{
$this->show = $aShowMajor;
}
 
Function `Stroke` has a Cognitive Complexity of 12 (exceeds 5 allowed). Consider refactoring.
Method `Stroke` has 26 lines of code (exceeds 25 allowed). Consider refactoring.
Method name "RadarGrid::Stroke" is not in camel caps format
public function Stroke($img, $grid)
{
if (!$this->show) {
return;
}
 
$nbrticks = safe_count($grid[0]) / 2;
$nbrpnts = safe_count($grid);
$img->SetColor($this->grid_color);
$img->SetLineWeight($this->weight);
 
for ($i = 0; $i < $nbrticks; ++$i) {
for ($j = 0; $j < $nbrpnts; ++$j) {
$pnts[$j * 2] = $grid[$j][$i * 2];
$pnts[$j * 2 + 1] = $grid[$j][$i * 2 + 1];
}
for ($k = 0; $k < $nbrpnts; ++$k) {
Avoid variables with short names like $l. Configured minimum length is 3.
$l = ($k + 1) % $nbrpnts;
if ($this->type == 'solid') {
$img->Line($pnts[$k * 2], $pnts[$k * 2 + 1], $pnts[$l * 2], $pnts[$l * 2 + 1]);
} elseif ($this->type == 'dotted') {
$img->DashedLine($pnts[$k * 2], $pnts[$k * 2 + 1], $pnts[$l * 2], $pnts[$l * 2 + 1], 1, 6);
} elseif ($this->type == 'dashed') {
$img->DashedLine($pnts[$k * 2], $pnts[$k * 2 + 1], $pnts[$l * 2], $pnts[$l * 2 + 1], 2, 4);
} elseif ($this->type == 'longdashed') {
$img->DashedLine($pnts[$k * 2], $pnts[$k * 2 + 1], $pnts[$l * 2], $pnts[$l * 2 + 1], 8, 6);
}
}
$pnts = [];
}
}
} // @class
 
/**
* @class RadarPlot
* // Description: Plot a radarplot
*/
Similar blocks of code found in 2 locations. Consider refactoring.
Each class must be in a file by itself
class RadarPlot
{
public $mark;
public $legend = '';
public $legendcsimtarget = '';
public $legendcsimalt = '';
public $csimtargets = []; // Array of targets for CSIM
public $csimareas = ''; // Resultant CSIM area tags
public $csimalts; // ALT:s for corresponding target
private $data = [];
private $fill = false;
private $fill_color = [200, 170, 180];
private $color = [0, 0, 0];
private $weight = 1;
private $linestyle = 'solid';
 
/**
* CONSTRUCTOR.
*
* @param mixed $data
*/
public function __construct($data)
{
$this->data = $data;
$this->mark = new Plot\PlotMark();
}
 
Method name "RadarPlot::Min" is not in camel caps format
public function Min()
{
return min($this->data);
}
 
Method name "RadarPlot::Max" is not in camel caps format
public function Max()
{
return max($this->data);
}
 
Method name "RadarPlot::SetLegend" is not in camel caps format
public function SetLegend($legend)
{
$this->legend = $legend;
}
 
Method name "RadarPlot::SetLineStyle" is not in camel caps format
public function SetLineStyle($aStyle)
{
$this->linestyle = $aStyle;
}
 
Avoid variables with short names like $w. Configured minimum length is 3.
Method name "RadarPlot::SetLineWeight" is not in camel caps format
public function SetLineWeight($w)
{
$this->weight = $w;
}
 
Method name "RadarPlot::SetFillColor" is not in camel caps format
public function SetFillColor($aColor)
{
$this->fill_color = $aColor;
$this->fill = true;
}
 
The method SetFill has a boolean flag argument $f, which is a certain sign of a Single Responsibility Principle violation.
Avoid variables with short names like $f. Configured minimum length is 3.
Method name "RadarPlot::SetFill" is not in camel caps format
public function SetFill($f = true)
{
$this->fill = $f;
}
 
The method SetColor has a boolean flag argument $aFillColor, which is a certain sign of a Single Responsibility Principle violation.
Method name "RadarPlot::SetColor" is not in camel caps format
public function SetColor($aColor, $aFillColor = false)
{
$this->color = $aColor;
if ($aFillColor) {
$this->SetFillColor($aFillColor);
$this->fill = true;
}
}
 
// Set href targets for CSIM
Method name "RadarPlot::SetCSIMTargets" is not in camel caps format
public function SetCSIMTargets($aTargets, $aAlts = null)
{
$this->csimtargets = $aTargets;
$this->csimalts = $aAlts;
}
 
// Get all created areas
Method name "RadarPlot::GetCSIMareas" is not in camel caps format
public function GetCSIMareas()
{
return $this->csimareas;
}
 
Method `Stroke` has 45 lines of code (exceeds 25 allowed). Consider refactoring.
Function `Stroke` has a Cognitive Complexity of 14 (exceeds 5 allowed). Consider refactoring.
Method name "RadarPlot::Stroke" is not in camel caps format
public function Stroke($img, $pos, $scale, $startangle)
{
$nbrpnts = safe_count($this->data);
$astep = 2 * M_PI / $nbrpnts;
Avoid variables with short names like $a. Configured minimum length is 3.
$a = $startangle;
 
for ($i = 0; $i < $nbrpnts; ++$i) {
// Rotate each non null point to the correct axis-angle
Avoid variables with short names like $cs. Configured minimum length is 3.
$cs = $scale->RelTranslate($this->data[$i]);
Avoid variables with short names like $x. Configured minimum length is 3.
$x = round($cs * cos($a) + $scale->scale_abs[0]);
Avoid variables with short names like $y. Configured minimum length is 3.
$y = round($pos - $cs * sin($a));
 
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$pnts[$i * 2] = $x;
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$pnts[$i * 2 + 1] = $y;
 
// If the next point is null then we draw this polygon segment
// to the center, skip the next and draw the next segment from
// the center up to the point on the axis with the first non-null
// value and continues from that point. Some additoinal logic is necessary
// to handle the boundary conditions
if ($i < $nbrpnts - 1) {
if (is_null($this->data[$i + 1])) {
$cs = 0;
$x = round($cs * cos($a) + $scale->scale_abs[0]);
$y = round($pos - $cs * sin($a));
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$pnts[$i * 2] = $x;
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$pnts[$i * 2 + 1] = $y;
$a += $astep;
}
}
 
$a += $astep;
}
 
if ($this->fill) {
$img->SetColor($this->fill_color);
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$img->FilledPolygon($pnts);
}
 
$img->SetLineWeight($this->weight);
$img->SetColor($this->color);
$img->SetLineStyle($this->linestyle);
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$pnts[] = $pnts[0];
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$pnts[] = $pnts[1];
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$img->Polygon($pnts);
$img->SetLineStyle('solid'); // Reset line style to default
 
// Add plotmarks on top
if ($this->mark->show) {
for ($i = 0; $i < $nbrpnts; ++$i) {
if (isset($this->csimtargets[$i])) {
$this->mark->SetCSIMTarget($this->csimtargets[$i]);
$this->mark->SetCSIMAlt($this->csimalts[$i]);
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$this->mark->SetCSIMAltVal($pnts[$i * 2], $pnts[$i * 2 + 1]);
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$this->mark->Stroke($img, $pnts[$i * 2], $pnts[$i * 2 + 1]);
$this->csimareas .= $this->mark->GetCSIMAreas();
The method Stroke uses an else expression. Else clauses are basically not necessary and you can simplify the code by not using them.
} else {
Avoid using undefined variables such as '$pnts' which will lead to PHP notices.
$this->mark->Stroke($img, $pnts[$i * 2], $pnts[$i * 2 + 1]);
}
}
}
}
 
Method name "RadarPlot::GetCount" is not in camel caps format
public function GetCount()
{
return safe_count($this->data);
}
 
Method name "RadarPlot::Legend" is not in camel caps format
public function Legend($graph)
{
if ($this->legend == '') {
return;
}
if ($this->fill) {
$graph->legend->Add($this->legend, $this->fill_color, $this->mark);
The method Legend uses an else expression. Else clauses are basically not necessary and you can simplify the code by not using them.
} else {
$graph->legend->Add($this->legend, $this->color, $this->mark);
}
}
} // @class
 
/* EOF */