0byt3m1n1
Path:
/
data
/
applications
/
aps
/
mantis
/
1.2.7-0
/
standard
/
htdocs
/
library
/
ezc
/
Graph
/
src
/
element
/
[
Home
]
File: text.php
<?php /** * File containing the ezcGraphChartElementText class * * @package Graph * @version 1.5 * @copyright Copyright (C) 2005-2009 eZ Systems AS. All rights reserved. * @license http://ez.no/licenses/new_bsd New BSD License */ /** * Chart element to display texts in a chart * * Chart elements can be understood as widgets or layout container inside the * chart. The actual transformation to images happens inside the renderers. * They represent all elements inside the chart and contain mostly general * formatting options, while the renderer itself might define additional * formatting options for some chart elments. You can find more about the * general formatting options for chart elements in the base class * ezcGraphChartElement. * * The text element can only be placed at the top or the bottom of the chart. * Beside the common options it has only one additional option defining the * maximum height used for the text box. The actaully required height is * calculated based on the assigned text size. * * <code> * $chart = new ezcGraphPieChart(); * $chart->data['example'] = new ezcGraphArrayDataSet( array( * 'Foo' => 23, * 'Bar' => 42, * ) ); * * $chart->title = 'Some pie chart'; * * // Use at maximum 5% of the chart height for the title. * $chart->title->maxHeight = .05; * * $graph->render( 400, 250, 'title.svg' ); * </code> * * @property float $maxHeight * Maximum percent of bounding used to display the text. * * @version 1.5 * @package Graph * @mainclass */ class ezcGraphChartElementText extends ezcGraphChartElement { /** * Constructor * * @param array $options Default option array * @return void * @ignore */ public function __construct( array $options = array() ) { $this->properties['maxHeight'] = .1; parent::__construct( $options ); } /** * __set * * @param mixed $propertyName * @param mixed $propertyValue * @throws ezcBaseValueException * If a submitted parameter was out of range or type. * @throws ezcBasePropertyNotFoundException * If a the value for the property options is not an instance of * @return void */ public function __set( $propertyName, $propertyValue ) { switch ( $propertyName ) { case 'maxHeight': if ( !is_numeric( $propertyValue ) || ( $propertyValue < 0 ) || ( $propertyValue > 1 ) ) { throw new ezcBaseValueException( $propertyName, $propertyValue, '0 <= float <= 1' ); } $this->properties['maxHeight'] = (float) $propertyValue; break; default: parent::__set( $propertyName, $propertyValue ); break; } } /** * Render the text * * @param ezcGraphRenderer $renderer Renderer * @param ezcGraphBoundings $boundings Boundings for the axis * @return ezcGraphBoundings Remaining boundings */ public function render( ezcGraphRenderer $renderer, ezcGraphBoundings $boundings ) { $height = (int) min( round( $this->properties['maxHeight'] * ( $boundings->y1 - $boundings->y0 ) ), $this->properties['font']->maxFontSize + $this->padding * 2 + $this->margin * 2 ); switch ( $this->properties['position'] ) { case ezcGraph::TOP: $textBoundings = new ezcGraphBoundings( $boundings->x0, $boundings->y0, $boundings->x1, $boundings->y0 + $height ); $boundings->y0 += $height + $this->properties['margin']; break; case ezcGraph::BOTTOM: $textBoundings = new ezcGraphBoundings( $boundings->x0, $boundings->y1 - $height, $boundings->x1, $boundings->y1 ); $boundings->y1 -= $height + $this->properties['margin']; break; } $textBoundings = $renderer->drawBox( $textBoundings, $this->properties['background'], $this->properties['border'], $this->properties['borderWidth'], $this->properties['margin'], $this->properties['padding'] ); $renderer->drawText( $textBoundings, $this->properties['title'], ezcGraph::CENTER | ezcGraph::MIDDLE ); return $boundings; } } ?>