Zeta Components - high quality PHP components

Zeta Components Manual :: Docs For Class ezcGraphRenderer3d

Graph::ezcGraphRenderer3d

Class ezcGraphRenderer3d

Class to transform chart primitives into image primitives. This renderer renders the charts in a isometric three dimensional view.

The class options are defined in the class ezcGraphRenderer3dOptions extending the basic renderer options in ezcGraphRendererOptions.

  1.    $graph = new ezcGraphPieChart();
  2.    $graph->palette = new ezcGraphPaletteEzRed();
  3.    $graph->title = 'Access statistics';
  4.    $graph->options->label = '%2$d (%3$.1f%%)';
  5.  
  6.    $graph->data['Access statistics'] = new ezcGraphArrayDataSet( array(
  7.        'Mozilla' => 19113,
  8.        'Explorer' => 10917,
  9.        'Opera' => 1464,
  10.        'Safari' => 652,
  11.        'Konqueror' => 474,
  12.    ) );
  13.    $graph->data['Access statistics']->highlight['Explorer'] = true;
  14.  
  15.    $graph->renderer = new ezcGraphRenderer3d();
  16.  
  17.    $graph->renderer->options->moveOut = .2;
  18.  
  19.    $graph->renderer->options->pieChartOffset = 63;
  20.  
  21.    $graph->renderer->options->pieChartGleam = .3;
  22.    $graph->renderer->options->pieChartGleamColor = '#FFFFFF';
  23.  
  24.    $graph->renderer->options->pieChartShadowSize = 5;
  25.    $graph->renderer->options->pieChartShadowColor = '#000000';
  26.  
  27.    $graph->renderer->options->legendSymbolGleam = .5;
  28.    $graph->renderer->options->legendSymbolGleamSize = .9;
  29.    $graph->renderer->options->legendSymbolGleamColor = '#FFFFFF';
  30.  
  31.    $graph->renderer->options->pieChartSymbolColor = '#55575388';
  32.  
  33.    $graph->renderer->options->pieChartHeight = 5;
  34.    $graph->renderer->options->pieChartRotation = .8;
  35.  
  36.    $graph->render( 400, 150, 'tutorial_pie_chart_3d.svg' );

Source for this file: /Graph/src/renderer/3d.php

Implements interfaces:

ezcGraphRenderer
   |
   --ezcGraphRenderer3d
Version:   //autogentag//

Member Variables

protected array $axisLabels = array()
Collect axis labels, so that the axis are drawn, when all axis spaces are known.
protected array $barPostProcessing = array()
Collects bar sides to draw them in a post processing step to simulate a simple z buffer.

array( array( 'index' => (int) // used for sorting 'context' => ezcGraphContext // context of call 'method' => (string) // method of driver to call 'parameters' => array // parameters for method call ), ... )

protected array $circleSectors = array()
Collects circle sectors to draw shadow in background of all circle sectors.
protected ezcGraphBoundings $dataBoundings = false
Boundings for the chart data
protected float $depth = false
Depth of displayed pseudo three dimensional line chart elements.
protected array $frontLines = array()
Array containing lines from the axis and grid which should be redrawn on top of the data.
protected array $linePostSymbols = array()
Array with symbols for post processing, which ensures, that the symbols are rendered topmost.
protected ezcGraphRenderer3dOptions $options
Options
protected ezcGraphBoundings $pieSegmentBoundings = false
Contains the boundings used for pie segments
protected array $pieSegmentLabels = array(
0 => array(),1=>array(),)

Pie segment labels divided into two array, containing the labels on the left and right side of the pie chart center.
protected float $xDepthFactor = false
Factor to reduce the width according to depth
protected float $yDepthFactor = false
Factor to reduce the height according to depth

Inherited Member Variables

From ezcGraphRenderer
protected ezcGraphRenderer::$driver
protected ezcGraphRenderer::$elements
protected ezcGraphRenderer::$xAxisSpace
protected ezcGraphRenderer::$yAxisSpace

Method Summary

public void drawAxis( $boundings , $start , $end , $axis , [ $labelClass = null] )
Draw axis
public void drawBackgroundImage( $boundings , $file , [ $position = 48] , [ $repeat = ezcGraph::NO_REPEAT] )
Draw background image
public void drawBar( $boundings , $context , $color , $position , $stepSize , [ $dataNumber = 1] , [ $dataCount = 1] , [ $symbol = ezcGraph::NO_SYMBOL] , [ $axisPosition = 0.] )
Draw bar
public ezcGraphBoundings drawBox( $boundings , [ $background = null] , [ $borderColor = null] , [ $borderWidth = 0] , [ $margin = 0] , [ $padding = 0] , [ $title = false] , [ $titleSize = 16] )
Draw box
protected void drawCircularBar( $context , $color , $position , $barWidth , $offset , $axisPosition , $startDepth , $midDepth , $endDepth , $symbol )
Draws a bar with a circular ground shape.
public void drawDataHighlightText( $boundings , $context , $end , [ $axisPosition = 0.] , [ $dataNumber = 1] , [ $dataCount = 1] , $font , $text , $size , [ $markLines = null] , [ $xOffset = 0] , [ $yOffset = 0] , [ $stepSize = 0.] , [ $type = ezcGraph::LINE] )
Draws a highlight textbox for a datapoint.
public void drawDataLine( $boundings , $context , $color , $start , $end , [ $dataNumber = 0] , [ $dataCount = 1] , [ $symbol = ezcGraph::NO_SYMBOL] , [ $symbolColor = null] , [ $fillColor = null] , [ $axisPosition = 0.] , [ $thickness = 1.] )
Draw data line
protected void drawDiamondBar( $context , $color , $position , $barWidth , $offset , $axisPosition , $startDepth , $midDepth , $endDepth )
Draws a bar with a diamond ground shape.
public void drawGridLine( $start , $end , $color )
Draw grid line
public void drawLegend( $boundings , $legend , [ $type = ezcGraph::VERTICAL] )
Draw legend
public void drawPieSegment( $boundings , $context , $color , [ $startAngle = .0] , [ $endAngle = 360.] , [ $label = false] , [ $moveOut = false] )
Draw pie segment
protected void drawRectangularBar( $context , $color , $position , $barWidth , $offset , $axisPosition , $startDepth , $midDepth , $endDepth )
Draws a bar with a rectangular ground shape.
public void drawStackedBar( $boundings , $context , $color , $start , $position , $stepSize , [ $symbol = ezcGraph::NO_SYMBOL] , [ $axisPosition = 0.] )
Draw stacked bar
public void drawStepLine( $start , $end , $color )
Draw step line
public void drawText( $boundings , $text , [ $align = ezcGraph::LEFT] , [ $rotation = null] )
Draw text
protected void finish( )
Call all postprocessing functions
protected void finishBars( )
Draw all collected bar elements
protected void finishCirleSectors( )
Draws the collected circle sectors
protected void finishFrontLines( )
Draw collected front lines
protected void finishLineSymbols( )
Draw the collected line symbols
protected void finishPieSegmentLabels( )
Draws the collected pie segment labels
protected ezcGraphCoordinate get3dCoordinate( $c , [ $front = 1.] )
Calculate the display coordinate from a coordinate
protected void resetRenderer( )
Reset renderer properties

Inherited Methods

From ezcGraphRenderer
protected void ezcGraphRenderer::addElementReference()
Adds a element reference for context
public abstract void ezcGraphRenderer::drawAxis()
Draw axis
protected void ezcGraphRenderer::drawAxisArrowHead()
Draw axis arrow head
public abstract void ezcGraphRenderer::drawBackgroundImage()
Draw background image
public abstract void ezcGraphRenderer::drawBar()
Draw bar
public abstract ezcGraphBoundings ezcGraphRenderer::drawBox()
Draw box
public abstract void ezcGraphRenderer::drawDataHighlightText()
Draws a highlight textbox for a datapoint.
public abstract void ezcGraphRenderer::drawDataLine()
Draw data line
public abstract void ezcGraphRenderer::drawLegend()
Draw legend
public abstract void ezcGraphRenderer::drawPieSegment()
Draw pie segment
public void ezcGraphRenderer::drawSymbol()
Draw Symbol
public abstract void ezcGraphRenderer::drawText()
Draw text
protected abstract void ezcGraphRenderer::finish()
Finish rendering
public array ezcGraphRenderer::getElementReferences()
Return all chart element references
public void ezcGraphRenderer::render()
Finally renders the image
protected void ezcGraphRenderer::resetRenderer()
Reset renderer properties
public void ezcGraphRenderer::setDriver()
Set renderers driver

Methods

drawAxis

void drawAxis( $boundings , ezcGraphCoordinate $start , ezcGraphCoordinate $end , ezcGraphChartElementAxis $axis , [ezcGraphAxisLabelRenderer $labelClass = null] )

Draw axis

Draws an axis form the provided start point to the end point. A specific angle of the axis is not required.

For the labeleing of the axis a sorted array with major steps and an array with minor steps is expected, which are build like this: array( array( 'position' => (float), 'label' => (string), ) ) where the label is optional.

The label renderer class defines how the labels are rendered. For more documentation on this topic have a look at the basic label renderer class.

Additionally it can be specified if a major and minor grid are rendered by defining a color for them. The axis label is used to add a caption for the axis.

Parameters:
Name Type Description
$boundings ezcGraphBoundings Boundings of axis
$start ezcGraphCoordinate Start point of axis
$end ezcGraphCoordinate Endpoint of axis
$axis ezcGraphChartElementAxis Axis to render
$labelClass ezcGraphAxisLabelRenderer Used label renderer
Redefinition of:
Method Description
ezcGraphRenderer::drawAxis() Draw axis

drawBackgroundImage

void drawBackgroundImage( $boundings , string $file , [int $position = 48] , [int $repeat = ezcGraph::NO_REPEAT] )

Draw background image

Draws a background image at the defined position. If repeat is set the background image will be repeated like any texture.

Parameters:
Name Type Description
$boundings ezcGraphBoundings Boundings for the background image
$file string Filename of background image
$position int Position of background image
$repeat int Type of repetition
Redefinition of:
Method Description
ezcGraphRenderer::drawBackgroundImage() Draw background image

drawBar

void drawBar( $boundings , ezcGraphContext $context , ezcGraphColor $color , ezcGraphCoordinate $position , float $stepSize , [int $dataNumber = 1] , [int $dataCount = 1] , [int $symbol = ezcGraph::NO_SYMBOL] , [float $axisPosition = 0.] )

Draw bar

Draws a bar as a data element in a line chart

Parameters:
Name Type Description
$boundings ezcGraphBoundings Chart boundings
$context ezcGraphContext Context of call
$color ezcGraphColor Color of line
$position ezcGraphCoordinate Position of data point
$stepSize float Space which can be used for bars
$dataNumber int Number of dataset
$dataCount int Count of datasets in chart
$symbol int Symbol to draw for line
$axisPosition float Position of axis for drawing filled lines
Redefinition of:
Method Description
ezcGraphRenderer::drawBar() Draw bar

drawBox

ezcGraphBoundings drawBox( $boundings , [ezcGraphColor $background = null] , [ezcGraphColor $borderColor = null] , [int $borderWidth = 0] , [int $margin = 0] , [int $padding = 0] , [mixed $title = false] , [int $titleSize = 16] )

Draw box

Box are wrapping each major chart element and draw border, background and title to each chart element.

Optionally a padding and margin for each box can be defined.

Parameters:
Name Type Description
$boundings ezcGraphBoundings Boundings of the box
$background ezcGraphColor Background color
$borderColor ezcGraphColor Border color
$borderWidth int Border width
$margin int Margin
$padding int Padding
$title mixed Title of the box
$titleSize int Size of title in the box
Redefinition of:
Method Description
ezcGraphRenderer::drawBox() Draw box

drawCircularBar

void drawCircularBar( ezcGraphContext $context , ezcGraphColor $color , ezcGraphCoordinate $position , float $barWidth , float $offset , float $axisPosition , float $startDepth , float $midDepth , float $endDepth , int $symbol )

Draws a bar with a circular ground shape.

Parameters:
Name Type Description
$context ezcGraphContext
$color ezcGraphColor
$position ezcGraphCoordinate
$barWidth float
$offset float
$axisPosition float
$startDepth float
$midDepth float
$endDepth float
$symbol int

drawDataHighlightText

void drawDataHighlightText( $boundings , ezcGraphContext $context , ezcGraphCoordinate $end , [float $axisPosition = 0.] , [int $dataNumber = 1] , [int $dataCount = 1] , ezcGraphFontOptions $font , string $text , int $size , [ezcGraphColor $markLines = null] , [int $xOffset = 0] , [int $yOffset = 0] , [float $stepSize = 0.] , [int $type = ezcGraph::LINE] )

Draws a highlight textbox for a datapoint.

A highlight textbox for line and bar charts means a box with the current value in the graph.

Parameters:
Name Type Description
$boundings ezcGraphBoundings Chart boundings
$context ezcGraphContext Context of call
$end ezcGraphCoordinate Ending point
$axisPosition float Position of axis for drawing filled lines
$dataNumber int Number of dataset
$dataCount int Count of datasets in chart
$font ezcGraphFontOptions Font used for highlight string
$text string Acutual value
$size int Size of highlight text
$markLines ezcGraphColor
$xOffset int
$yOffset int
$stepSize float
$type int
Redefinition of:
Method Description
ezcGraphRenderer::drawDataHighlightText() Draws a highlight textbox for a datapoint.

drawDataLine

void drawDataLine( $boundings , ezcGraphContext $context , ezcGraphColor $color , ezcGraphCoordinate $start , ezcGraphCoordinate $end , [int $dataNumber = 0] , [int $dataCount = 1] , [int $symbol = ezcGraph::NO_SYMBOL] , [ezcGraphColor $symbolColor = null] , [ezcGraphColor $fillColor = null] , [float $axisPosition = 0.] , [float $thickness = 1.] )

Draw data line

Draws a line as a data element in a line chart

Parameters:
Name Type Description
$boundings ezcGraphBoundings Chart boundings
$context ezcGraphContext Context of call
$color ezcGraphColor Color of line
$start ezcGraphCoordinate Starting point
$end ezcGraphCoordinate Ending point
$dataNumber int Number of dataset
$dataCount int Count of datasets in chart
$symbol int Symbol to draw for line
$symbolColor ezcGraphColor Color of the symbol, defaults to linecolor
$fillColor ezcGraphColor Color to fill line with
$axisPosition float Position of axis for drawing filled lines
$thickness float Line thickness
Redefinition of:
Method Description
ezcGraphRenderer::drawDataLine() Draw data line

drawDiamondBar

void drawDiamondBar( ezcGraphContext $context , ezcGraphColor $color , ezcGraphCoordinate $position , float $barWidth , float $offset , float $axisPosition , float $startDepth , float $midDepth , float $endDepth )

Draws a bar with a diamond ground shape.

Parameters:
Name Type Description
$context ezcGraphContext
$color ezcGraphColor
$position ezcGraphCoordinate
$barWidth float
$offset float
$axisPosition float
$startDepth float
$midDepth float
$endDepth float

drawGridLine

void drawGridLine( ezcGraphCoordinate $start , ezcGraphCoordinate $end , ezcGraphColor $color )

Draw grid line

Draw line for the grid in the chart background

Parameters:
Name Type Description
$start ezcGraphCoordinate Start point
$end ezcGraphCoordinate End point
$color ezcGraphColor Color of the grid line

drawLegend

void drawLegend( $boundings , ezcGraphChartElementLegend $legend , [int $type = ezcGraph::VERTICAL] )

Draw legend

Will draw a legend in the bounding box

Parameters:
Name Type Description
$boundings ezcGraphBoundings Bounding of legend
$legend ezcGraphChartElementLegend Legend to draw;
$type int Type of legend: Protrait or landscape
Redefinition of:
Method Description
ezcGraphRenderer::drawLegend() Draw legend

drawPieSegment

void drawPieSegment( $boundings , ezcGraphContext $context , ezcGraphColor $color , [float $startAngle = .0] , [float $endAngle = 360.] , [mixed $label = false] , [bool $moveOut = false] )

Draw pie segment

Draws a single pie segment

Parameters:
Name Type Description
$boundings ezcGraphBoundings Chart boundings
$context ezcGraphContext Context of call
$color ezcGraphColor Color of pie segment
$startAngle float Start angle
$endAngle float End angle
$label mixed Label of pie segment
$moveOut bool Move out from middle for hilighting
Redefinition of:
Method Description
ezcGraphRenderer::drawPieSegment() Draw pie segment

drawRectangularBar

void drawRectangularBar( ezcGraphContext $context , ezcGraphColor $color , ezcGraphCoordinate $position , float $barWidth , float $offset , float $axisPosition , float $startDepth , float $midDepth , float $endDepth )

Draws a bar with a rectangular ground shape.

Parameters:
Name Type Description
$context ezcGraphContext
$color ezcGraphColor
$position ezcGraphCoordinate
$barWidth float
$offset float
$axisPosition float
$startDepth float
$midDepth float
$endDepth float

drawStackedBar

void drawStackedBar( $boundings , ezcGraphContext $context , ezcGraphColor $color , ezcGraphCoordinate $start , ezcGraphCoordinate $position , float $stepSize , [int $symbol = ezcGraph::NO_SYMBOL] , [float $axisPosition = 0.] )

Draw stacked bar

Draws a stacked bar part as a data element in a line chart

Parameters:
Name Type Description
$boundings ezcGraphBoundings Chart boundings
$context ezcGraphContext Context of call
$color ezcGraphColor Color of line
$start ezcGraphCoordinate
$position ezcGraphCoordinate
$stepSize float Space which can be used for bars
$symbol int Symbol to draw for line
$axisPosition float Position of axis for drawing filled lines
Implementation of:
Method Description
ezcGraphStackedBarsRenderer::drawStackedBar() Draw stacked bar

drawStepLine

void drawStepLine( ezcGraphCoordinate $start , ezcGraphCoordinate $end , ezcGraphColor $color )

Draw step line

Draw a step (marker for label position) on a axis.

Parameters:
Name Type Description
$start ezcGraphCoordinate Start point
$end ezcGraphCoordinate End point
$color ezcGraphColor Color of the grid line

drawText

void drawText( $boundings , string $text , [int $align = ezcGraph::LEFT] , [ $rotation = null] )

Draw text

Draws the provided text in the boundings

Parameters:
Name Type Description
$boundings ezcGraphBoundings Boundings of text
$text string Text
$align int Alignement of text
$rotation ezcGraphRotation
Redefinition of:
Method Description
ezcGraphRenderer::drawText() Draw text

finish

void finish( )

Call all postprocessing functions

Redefinition of:
Method Description
ezcGraphRenderer::finish() Finish rendering

finishBars

void finishBars( )

Draw all collected bar elements

Draw all collected bar elements after sorting them depending of their position to simulate simple z buffering.

finishCirleSectors

void finishCirleSectors( )

Draws the collected circle sectors

All circle sectors are collected and drawn later to be able to render the shadows of the pie segments in the back of all pie segments, and ensure the correct drawing order for all pie segment elements.

finishFrontLines

void finishFrontLines( )

Draw collected front lines

Draw all grid and axis lines, which should be redrawn in front of the data.

finishLineSymbols

void finishLineSymbols( )

Draw the collected line symbols

Symbols for the data lines are collected and delayed to ensure that they are not covered and hidden by other data lines.

finishPieSegmentLabels

void finishPieSegmentLabels( )

Draws the collected pie segment labels

All labels are collected and drawn later to be able to partition the available space for the labels woth knowledge of the overall label count and their required size and optimal position.

get3dCoordinate

ezcGraphCoordinate get3dCoordinate( ezcGraphCoordinate $c , [float $front = 1.] )

Calculate the display coordinate from a coordinate

Calculates the display coordinate of a coordinate depending on the depth setting and the distance of the coordinate to the front of the chart.

Parameters:
Name Type Description
$c ezcGraphCoordinate Coordinate
$front float Distance to front (0 - 1)

resetRenderer

void resetRenderer( )

Reset renderer properties

Reset all renderer properties, which were calculated during the rendering process, to offer a clean environment for rerendering.

Redefinition of:
Method Description
ezcGraphRenderer::resetRenderer() Reset renderer properties
Documentation generated by phpDocumentor 1.4.3