icingaweb2/library/Icinga/Chart/Render/LayoutBox.php

218 lines
5.4 KiB
PHP

<?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.
*
* @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>
*/
// {{{ICINGA_LICENSE_HEADER}}}
namespace Icinga\Chart\Render;
/**
* Layout class encapsulating size, padding and margin information
*/
class LayoutBox
{
/**
* 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
*/
private $height;
/**
* The width of this layout element
*
* @var int
*/
private $width;
/**
* The x position of this layout
*
* @var int
*/
private $x;
/**
* The y position of this layout
*
* @var int
*/
private $y;
/**
* The padding of this layout
*
* @var array
*/
private $padding = array(0, 0, 0, 0);
/**
* 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)
{
$this->height = $height ? $height : 100;
$this->width = $width ? $width : 100;
$this->x = $x;
$this->y = $y;
}
/**
* Set a padding to all four sides uniformly
*
* @param int $padding The padding to set for all four sides
*/
public function setUniformPadding($padding)
{
$this->padding = array($padding, $padding, $padding, $padding);
}
/**
* 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
*/
public function setPadding($top, $right, $bottom, $left)
{
$this->padding = array($top, $right, $bottom, $left);
}
/**
* Return a string containing the SVG transform attribute values for the padding
*
* @param RenderContext $ctx The context to determine the translation coordinates
*
* @return string The transformation string
*/
public function getInnerTransform(RenderContext $ctx)
{
list($translateX, $translateY) = $ctx->toAbsolute(
$this->padding[self::PADDING_LEFT] + $this->getX(),
$this->padding[self::PADDING_TOP] + $this->getY()
);
list($scaleX, $scaleY) = $ctx->paddingToScaleFactor($this->padding);
$scaleX *= $this->getWidth()/100;
$scaleY *= $this->getHeight()/100;
return sprintf('translate(%s, %s) scale(%s, %s)', $translateX, $translateY, $scaleX, $scaleY);
}
/**
* String representation for this Layout, for debug purposes
*
* @return string A string containing the bounds of this LayoutBox
*/
public function __toString()
{
return sprintf(
'Rectangle: x: %s y: %s, height: %s, width: %s',
$this->x,
$this->y,
$this->height,
$this->width
);
}
/**
* Return a four element array with the padding
*
* @return array The padding of this LayoutBox
*/
public function getPadding()
{
return $this->padding;
}
/**
* Return the height of this LayoutBox
*
* @return int The height of this box
*/
public function getHeight()
{
return $this->height;
}
/**
* Return the width of this LayoutBox
*
* @return int The width of this box
*/
public function getWidth()
{
return $this->width;
}
/**
* Return the x position of this LayoutBox
*
* @return int The x position of this box
*/
public function getX()
{
return $this->x;
}
/**
* Return the y position of this LayoutBox
*
* @return int The y position of this box
*/
public function getY()
{
return $this->y;
}
}