2013-09-09 13:55:29 +02:00
|
|
|
<?php
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
/**
|
|
|
|
* This file is part of Icinga 2 Web.
|
|
|
|
*
|
|
|
|
* Icinga 2 Web - Head for multiple monitoring backends.
|
|
|
|
* Copyright (C) 2013 Icinga Development Team
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @copyright 2013 Icinga Development Team <info@icinga.org>
|
|
|
|
* @license http://www.gnu.org/licenses/gpl-2.0.txt GPL, version 2
|
|
|
|
* @author Icinga Development Team <info@icinga.org>
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Chart\Render;
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Layout class encapsulating size, padding and margin information
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
class LayoutBox
|
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Padding index for top padding
|
|
|
|
*/
|
|
|
|
const PADDING_TOP = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Padding index for right padding
|
|
|
|
*/
|
|
|
|
const PADDING_RIGHT = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Padding index for bottom padding
|
|
|
|
*/
|
|
|
|
const PADDING_BOTTOM = 2;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Padding index for left padding
|
|
|
|
*/
|
|
|
|
const PADDING_LEFT = 3;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The height of this layout element
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
private $height;
|
2013-09-21 17:35:18 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The width of this layout element
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
private $width;
|
2013-09-21 17:35:18 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The x position of this layout
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
private $x;
|
2013-09-21 17:35:18 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The y position of this layout
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
private $y;
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* The padding of this layout
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private $padding = array(0, 0, 0, 0);
|
2013-09-09 13:55:29 +02:00
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Create this layout box
|
|
|
|
*
|
|
|
|
* Note that x, y, width and height are relative: x with 0 means leftmost, x with 100 means rightmost
|
|
|
|
*
|
|
|
|
* @param int $x The relative x coordinate
|
|
|
|
* @param int $y The relative y coordinate
|
|
|
|
* @param int $width The optional, relative width
|
|
|
|
* @param int $height The optional, relative height
|
|
|
|
*/
|
|
|
|
public function __construct($x, $y, $width = null, $height = null)
|
2013-09-09 13:55:29 +02:00
|
|
|
{
|
|
|
|
$this->height = $height ? $height : 100;
|
|
|
|
$this->width = $width ? $width : 100;
|
|
|
|
$this->x = $x;
|
|
|
|
$this->y = $y;
|
|
|
|
}
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Set a padding to all four sides uniformly
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @param int $padding The padding to set for all four sides
|
2013-09-21 17:35:18 +02:00
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
public function setUniformPadding($padding)
|
|
|
|
{
|
|
|
|
$this->padding = array($padding, $padding, $padding, $padding);
|
|
|
|
}
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Set the padding for this LayoutBox
|
|
|
|
*
|
|
|
|
* @param int $top The top side padding
|
|
|
|
* @param int $right The right side padding
|
|
|
|
* @param int $bottom The bottom side padding
|
|
|
|
* @param int $left The left side padding
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
public function setPadding($top, $right, $bottom, $left)
|
|
|
|
{
|
|
|
|
$this->padding = array($top, $right, $bottom, $left);
|
|
|
|
}
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Return a string containing the SVG transform attribute values for the padding
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @param RenderContext $ctx The context to determine the translation coordinates
|
2013-09-21 17:35:18 +02:00
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return string The transformation string
|
2013-09-21 17:35:18 +02:00
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
public function getInnerTransform(RenderContext $ctx)
|
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
list($translateX, $translateY) = $ctx->toAbsolute(
|
|
|
|
$this->padding[self::PADDING_LEFT] + $this->getX(),
|
|
|
|
$this->padding[self::PADDING_TOP] + $this->getY()
|
|
|
|
);
|
2013-09-09 13:55:29 +02:00
|
|
|
list($scaleX, $scaleY) = $ctx->paddingToScaleFactor($this->padding);
|
|
|
|
|
|
|
|
$scaleX *= $this->getWidth()/100;
|
|
|
|
$scaleY *= $this->getHeight()/100;
|
2013-09-21 17:35:18 +02:00
|
|
|
return sprintf('translate(%s, %s) scale(%s, %s)', $translateX, $translateY, $scaleX, $scaleY);
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* String representation for this Layout, for debug purposes
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return string A string containing the bounds of this LayoutBox
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
2013-09-21 17:35:18 +02:00
|
|
|
public function __toString()
|
2013-09-09 13:55:29 +02:00
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
return sprintf(
|
|
|
|
'Rectangle: x: %s y: %s, height: %s, width: %s',
|
|
|
|
$this->x,
|
|
|
|
$this->y,
|
|
|
|
$this->height,
|
|
|
|
$this->width
|
|
|
|
);
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* Return a four element array with the padding
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return array The padding of this LayoutBox
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
public function getPadding()
|
|
|
|
{
|
|
|
|
return $this->padding;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* Return the height of this LayoutBox
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return int The height of this box
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
public function getHeight()
|
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
return $this->height;
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* Return the width of this LayoutBox
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return int The width of this box
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
public function getWidth()
|
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
return $this->width;
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* Return the x position of this LayoutBox
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return int The x position of this box
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
public function getX()
|
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
return $this->x;
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* Return the y position of this LayoutBox
|
|
|
|
*
|
|
|
|
* @return int The y position of this box
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
public function getY()
|
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
return $this->y;
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
2013-09-21 17:35:18 +02:00
|
|
|
}
|