2013-09-09 13:55:29 +02:00
|
|
|
<?php
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Chart;
|
|
|
|
|
2014-07-09 18:04:03 +02:00
|
|
|
use DOMElement;
|
|
|
|
use Icinga\Chart\Palette;
|
|
|
|
use Icinga\Chart\Primitive\Canvas;
|
|
|
|
use Icinga\Chart\Primitive\Drawable;
|
|
|
|
use Icinga\Chart\Primitive\Rect;
|
|
|
|
use Icinga\Chart\Primitive\Text;
|
|
|
|
use Icinga\Chart\Render\LayoutBox;
|
|
|
|
use Icinga\Chart\Render\RenderContext;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Drawable for creating a Graph Legend on the bottom of a graph.
|
|
|
|
*
|
|
|
|
* Usually used by the GridChart class internally.
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
class Legend implements Drawable
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* Internal counter for unnamed label identifiers
|
2013-09-09 13:55:29 +02:00
|
|
|
*
|
2013-09-21 17:35:18 +02:00
|
|
|
* @var int
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
2013-09-21 17:35:18 +02:00
|
|
|
private $internalCtr = 0;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
2013-09-21 17:35:18 +02:00
|
|
|
* Content of this legend
|
2013-09-09 13:55:29 +02:00
|
|
|
*
|
2013-09-21 17:35:18 +02:00
|
|
|
* @var array
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
2013-09-21 17:35:18 +02:00
|
|
|
private $dataset = array();
|
2013-09-09 13:55:29 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the content to be displayed by this legend
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @param array $dataset An array of datasets in the form they are provided to the graphing implementation
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
public function addDataset(array $dataset)
|
|
|
|
{
|
|
|
|
if (!isset($dataset['label'])) {
|
|
|
|
$dataset['label'] = 'Dataset ' . (++$this->internalCtr);
|
|
|
|
}
|
2013-09-21 17:35:18 +02:00
|
|
|
if (!isset($dataset['color'])) {
|
|
|
|
return;
|
|
|
|
}
|
2013-09-09 13:55:29 +02:00
|
|
|
$this->dataset[$dataset['color']] = $dataset['label'];
|
|
|
|
}
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Render the legend to an SVG object
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @param RenderContext $ctx The context to use for rendering this legend
|
2013-09-21 17:35:18 +02:00
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return DOMElement The SVG representation of this legend
|
2013-09-21 17:35:18 +02:00
|
|
|
*/
|
|
|
|
public function toSvg(RenderContext $ctx)
|
2013-09-09 13:55:29 +02:00
|
|
|
{
|
2014-02-18 18:35:34 +01:00
|
|
|
$outer = new Canvas('legend', new LayoutBox(0, 0, 100, 100));
|
2013-09-21 17:35:18 +02:00
|
|
|
$outer->getLayout()->setPadding(2, 2, 2, 2);
|
|
|
|
$nrOfColumns = 4;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
$topstep = 10 / $nrOfColumns + 2;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
$top = 0;
|
|
|
|
$left = 0;
|
|
|
|
$lastLabelEndPos = -1;
|
2013-09-09 13:55:29 +02:00
|
|
|
foreach ($this->dataset as $color => $text) {
|
2015-01-13 18:25:19 +01:00
|
|
|
$leftstep = 100 / $nrOfColumns + strlen($text);
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
// Make sure labels don't overlap each other
|
|
|
|
while ($lastLabelEndPos >= $left) {
|
|
|
|
$left += $leftstep;
|
|
|
|
}
|
|
|
|
// When a label is longer than the available space, use the next line
|
|
|
|
if ($left + strlen($text) > 100) {
|
|
|
|
$top += $topstep;
|
|
|
|
$left = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$colorBox = new Rect($left, $top, 2, 2);
|
2013-09-25 16:32:28 +02:00
|
|
|
$colorBox->setFill($color)->setStrokeWidth(2);
|
|
|
|
$colorBox->keepRatio();
|
2013-09-09 13:55:29 +02:00
|
|
|
$outer->addElement($colorBox);
|
2013-09-21 17:35:18 +02:00
|
|
|
|
|
|
|
$textBox = new Text($left+5, $top+2, $text);
|
|
|
|
$textBox->setFontSize('2em');
|
2013-09-09 13:55:29 +02:00
|
|
|
$outer->addElement($textBox);
|
2013-09-21 17:35:18 +02:00
|
|
|
|
|
|
|
// readjust layout
|
|
|
|
$lastLabelEndPos = $left + strlen($text);
|
|
|
|
$left += $leftstep;
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
|
|
|
$svg = $outer->toSvg($ctx);
|
|
|
|
return $svg;
|
|
|
|
}
|
|
|
|
}
|