| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883 | <?phprequire_once(PHPExcel_Settings::getChartRendererPath().'/jpgraph.php');/** * PHPExcel_Chart_Renderer_jpgraph * * Copyright (c) 2006 - 2015 PHPExcel * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA * * @category    PHPExcel * @package        PHPExcel_Chart_Renderer * @copyright    Copyright (c) 2006 - 2015 PHPExcel (http://www.codeplex.com/PHPExcel) * @license        http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt    LGPL * @version        ##VERSION##, ##DATE## */class PHPExcel_Chart_Renderer_jpgraph{    private static $width    = 640;    private static $height    = 480;    private static $colourSet = array(        'mediumpurple1',    'palegreen3',     'gold1',          'cadetblue1',        'darkmagenta',      'coral',          'dodgerblue3',    'eggplant',        'mediumblue',       'magenta',        'sandybrown',     'cyan',        'firebrick1',       'forestgreen',    'deeppink4',      'darkolivegreen',        'goldenrod2'    );    private static $markSet = array(        'diamond'  => MARK_DIAMOND,        'square'   => MARK_SQUARE,        'triangle' => MARK_UTRIANGLE,        'x'        => MARK_X,        'star'     => MARK_STAR,        'dot'      => MARK_FILLEDCIRCLE,        'dash'     => MARK_DTRIANGLE,        'circle'   => MARK_CIRCLE,        'plus'     => MARK_CROSS    );    private $chart;    private $graph;    private static $plotColour = 0;    private static $plotMark = 0;    private function formatPointMarker($seriesPlot, $markerID)    {        $plotMarkKeys = array_keys(self::$markSet);        if (is_null($markerID)) {            //    Use default plot marker (next marker in the series)            self::$plotMark %= count(self::$markSet);            $seriesPlot->mark->SetType(self::$markSet[$plotMarkKeys[self::$plotMark++]]);        } elseif ($markerID !== 'none') {            //    Use specified plot marker (if it exists)            if (isset(self::$markSet[$markerID])) {                $seriesPlot->mark->SetType(self::$markSet[$markerID]);            } else {                //    If the specified plot marker doesn't exist, use default plot marker (next marker in the series)                self::$plotMark %= count(self::$markSet);                $seriesPlot->mark->SetType(self::$markSet[$plotMarkKeys[self::$plotMark++]]);            }        } else {            //    Hide plot marker            $seriesPlot->mark->Hide();        }        $seriesPlot->mark->SetColor(self::$colourSet[self::$plotColour]);        $seriesPlot->mark->SetFillColor(self::$colourSet[self::$plotColour]);        $seriesPlot->SetColor(self::$colourSet[self::$plotColour++]);        return $seriesPlot;    }    private function formatDataSetLabels($groupID, $datasetLabels, $labelCount, $rotation = '')    {        $datasetLabelFormatCode = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex(0)->getFormatCode();        if (!is_null($datasetLabelFormatCode)) {            //    Retrieve any label formatting code            $datasetLabelFormatCode = stripslashes($datasetLabelFormatCode);        }        $testCurrentIndex = 0;        foreach ($datasetLabels as $i => $datasetLabel) {            if (is_array($datasetLabel)) {                if ($rotation == 'bar') {                    $datasetLabels[$i] = implode(" ", $datasetLabel);                } else {                    $datasetLabel = array_reverse($datasetLabel);                    $datasetLabels[$i] = implode("\n", $datasetLabel);                }            } else {                //    Format labels according to any formatting code                if (!is_null($datasetLabelFormatCode)) {                    $datasetLabels[$i] = PHPExcel_Style_NumberFormat::toFormattedString($datasetLabel, $datasetLabelFormatCode);                }            }            ++$testCurrentIndex;        }        return $datasetLabels;    }    private function percentageSumCalculation($groupID, $seriesCount)    {        //    Adjust our values to a percentage value across all series in the group        for ($i = 0; $i < $seriesCount; ++$i) {            if ($i == 0) {                $sumValues = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getDataValues();            } else {                $nextValues = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getDataValues();                foreach ($nextValues as $k => $value) {                    if (isset($sumValues[$k])) {                        $sumValues[$k] += $value;                    } else {                        $sumValues[$k] = $value;                    }                }            }        }        return $sumValues;    }    private function percentageAdjustValues($dataValues, $sumValues)    {        foreach ($dataValues as $k => $dataValue) {            $dataValues[$k] = $dataValue / $sumValues[$k] * 100;        }        return $dataValues;    }    private function getCaption($captionElement)    {        //    Read any caption        $caption = (!is_null($captionElement)) ? $captionElement->getCaption() : null;        //    Test if we have a title caption to display        if (!is_null($caption)) {            //    If we do, it could be a plain string or an array            if (is_array($caption)) {                //    Implode an array to a plain string                $caption = implode('', $caption);            }        }        return $caption;    }    private function renderTitle()    {        $title = $this->getCaption($this->chart->getTitle());        if (!is_null($title)) {            $this->graph->title->Set($title);        }    }    private function renderLegend()    {        $legend = $this->chart->getLegend();        if (!is_null($legend)) {            $legendPosition = $legend->getPosition();            $legendOverlay = $legend->getOverlay();            switch ($legendPosition) {                case 'r':                    $this->graph->legend->SetPos(0.01, 0.5, 'right', 'center');    //    right                    $this->graph->legend->SetColumns(1);                    break;                case 'l':                    $this->graph->legend->SetPos(0.01, 0.5, 'left', 'center');    //    left                    $this->graph->legend->SetColumns(1);                    break;                case 't':                    $this->graph->legend->SetPos(0.5, 0.01, 'center', 'top');    //    top                    break;                case 'b':                    $this->graph->legend->SetPos(0.5, 0.99, 'center', 'bottom');    //    bottom                    break;                default:                    $this->graph->legend->SetPos(0.01, 0.01, 'right', 'top');    //    top-right                    $this->graph->legend->SetColumns(1);                    break;            }        } else {            $this->graph->legend->Hide();        }    }    private function renderCartesianPlotArea($type = 'textlin')    {        $this->graph = new Graph(self::$width, self::$height);        $this->graph->SetScale($type);        $this->renderTitle();        //    Rotate for bar rather than column chart        $rotation = $this->chart->getPlotArea()->getPlotGroupByIndex(0)->getPlotDirection();        $reverse = ($rotation == 'bar') ? true : false;        $xAxisLabel = $this->chart->getXAxisLabel();        if (!is_null($xAxisLabel)) {            $title = $this->getCaption($xAxisLabel);            if (!is_null($title)) {                $this->graph->xaxis->SetTitle($title, 'center');                $this->graph->xaxis->title->SetMargin(35);                if ($reverse) {                    $this->graph->xaxis->title->SetAngle(90);                    $this->graph->xaxis->title->SetMargin(90);                }            }        }        $yAxisLabel = $this->chart->getYAxisLabel();        if (!is_null($yAxisLabel)) {            $title = $this->getCaption($yAxisLabel);            if (!is_null($title)) {                $this->graph->yaxis->SetTitle($title, 'center');                if ($reverse) {                    $this->graph->yaxis->title->SetAngle(0);                    $this->graph->yaxis->title->SetMargin(-55);                }            }        }    }    private function renderPiePlotArea($doughnut = false)    {        $this->graph = new PieGraph(self::$width, self::$height);        $this->renderTitle();    }    private function renderRadarPlotArea()    {        $this->graph = new RadarGraph(self::$width, self::$height);        $this->graph->SetScale('lin');        $this->renderTitle();    }    private function renderPlotLine($groupID, $filled = false, $combination = false, $dimensions = '2d')    {        $grouping = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotGrouping();        $labelCount = count($this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex(0)->getPointCount());        if ($labelCount > 0) {            $datasetLabels = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex(0)->getDataValues();            $datasetLabels = $this->formatDataSetLabels($groupID, $datasetLabels, $labelCount);            $this->graph->xaxis->SetTickLabels($datasetLabels);        }        $seriesCount = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotSeriesCount();        $seriesPlots = array();        if ($grouping == 'percentStacked') {            $sumValues = $this->percentageSumCalculation($groupID, $seriesCount);        }        //    Loop through each data series in turn        for ($i = 0; $i < $seriesCount; ++$i) {            $dataValues = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getDataValues();            $marker = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getPointMarker();            if ($grouping == 'percentStacked') {                $dataValues = $this->percentageAdjustValues($dataValues, $sumValues);            }            //    Fill in any missing values in the $dataValues array            $testCurrentIndex = 0;            foreach ($dataValues as $k => $dataValue) {                while ($k != $testCurrentIndex) {                    $dataValues[$testCurrentIndex] = null;                    ++$testCurrentIndex;                }                ++$testCurrentIndex;            }            $seriesPlot = new LinePlot($dataValues);            if ($combination) {                $seriesPlot->SetBarCenter();            }            if ($filled) {                $seriesPlot->SetFilled(true);                $seriesPlot->SetColor('black');                $seriesPlot->SetFillColor(self::$colourSet[self::$plotColour++]);            } else {                //    Set the appropriate plot marker                $this->formatPointMarker($seriesPlot, $marker);            }            $dataLabel = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotLabelByIndex($i)->getDataValue();            $seriesPlot->SetLegend($dataLabel);            $seriesPlots[] = $seriesPlot;        }        if ($grouping == 'standard') {            $groupPlot = $seriesPlots;        } else {            $groupPlot = new AccLinePlot($seriesPlots);        }        $this->graph->Add($groupPlot);    }    private function renderPlotBar($groupID, $dimensions = '2d')    {        $rotation = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotDirection();        //    Rotate for bar rather than column chart        if (($groupID == 0) && ($rotation == 'bar')) {            $this->graph->Set90AndMargin();        }        $grouping = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotGrouping();        $labelCount = count($this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex(0)->getPointCount());        if ($labelCount > 0) {            $datasetLabels = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex(0)->getDataValues();            $datasetLabels = $this->formatDataSetLabels($groupID, $datasetLabels, $labelCount, $rotation);            //    Rotate for bar rather than column chart            if ($rotation == 'bar') {                $datasetLabels = array_reverse($datasetLabels);                $this->graph->yaxis->SetPos('max');                $this->graph->yaxis->SetLabelAlign('center', 'top');                $this->graph->yaxis->SetLabelSide(SIDE_RIGHT);            }            $this->graph->xaxis->SetTickLabels($datasetLabels);        }        $seriesCount = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotSeriesCount();        $seriesPlots = array();        if ($grouping == 'percentStacked') {            $sumValues = $this->percentageSumCalculation($groupID, $seriesCount);        }        //    Loop through each data series in turn        for ($j = 0; $j < $seriesCount; ++$j) {            $dataValues = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($j)->getDataValues();            if ($grouping == 'percentStacked') {                $dataValues = $this->percentageAdjustValues($dataValues, $sumValues);            }            //    Fill in any missing values in the $dataValues array            $testCurrentIndex = 0;            foreach ($dataValues as $k => $dataValue) {                while ($k != $testCurrentIndex) {                    $dataValues[$testCurrentIndex] = null;                    ++$testCurrentIndex;                }                ++$testCurrentIndex;            }            //    Reverse the $dataValues order for bar rather than column chart            if ($rotation == 'bar') {                $dataValues = array_reverse($dataValues);            }            $seriesPlot = new BarPlot($dataValues);            $seriesPlot->SetColor('black');            $seriesPlot->SetFillColor(self::$colourSet[self::$plotColour++]);            if ($dimensions == '3d') {                $seriesPlot->SetShadow();            }            if (!$this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotLabelByIndex($j)) {                $dataLabel = '';            } else {                $dataLabel = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotLabelByIndex($j)->getDataValue();            }            $seriesPlot->SetLegend($dataLabel);            $seriesPlots[] = $seriesPlot;        }        //    Reverse the plot order for bar rather than column chart        if (($rotation == 'bar') && (!($grouping == 'percentStacked'))) {            $seriesPlots = array_reverse($seriesPlots);        }        if ($grouping == 'clustered') {            $groupPlot = new GroupBarPlot($seriesPlots);        } elseif ($grouping == 'standard') {            $groupPlot = new GroupBarPlot($seriesPlots);        } else {            $groupPlot = new AccBarPlot($seriesPlots);            if ($dimensions == '3d') {                $groupPlot->SetShadow();            }        }        $this->graph->Add($groupPlot);    }    private function renderPlotScatter($groupID, $bubble)    {        $grouping = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotGrouping();        $scatterStyle = $bubbleSize = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotStyle();        $seriesCount = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotSeriesCount();        $seriesPlots = array();        //    Loop through each data series in turn        for ($i = 0; $i < $seriesCount; ++$i) {            $dataValuesY = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex($i)->getDataValues();            $dataValuesX = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getDataValues();            foreach ($dataValuesY as $k => $dataValueY) {                $dataValuesY[$k] = $k;            }            $seriesPlot = new ScatterPlot($dataValuesX, $dataValuesY);            if ($scatterStyle == 'lineMarker') {                $seriesPlot->SetLinkPoints();                $seriesPlot->link->SetColor(self::$colourSet[self::$plotColour]);            } elseif ($scatterStyle == 'smoothMarker') {                $spline = new Spline($dataValuesY, $dataValuesX);                list($splineDataY, $splineDataX) = $spline->Get(count($dataValuesX) * self::$width / 20);                $lplot = new LinePlot($splineDataX, $splineDataY);                $lplot->SetColor(self::$colourSet[self::$plotColour]);                $this->graph->Add($lplot);            }            if ($bubble) {                $this->formatPointMarker($seriesPlot, 'dot');                $seriesPlot->mark->SetColor('black');                $seriesPlot->mark->SetSize($bubbleSize);            } else {                $marker = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getPointMarker();                $this->formatPointMarker($seriesPlot, $marker);            }            $dataLabel = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotLabelByIndex($i)->getDataValue();            $seriesPlot->SetLegend($dataLabel);            $this->graph->Add($seriesPlot);        }    }    private function renderPlotRadar($groupID)    {        $radarStyle = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotStyle();        $seriesCount = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotSeriesCount();        $seriesPlots = array();        //    Loop through each data series in turn        for ($i = 0; $i < $seriesCount; ++$i) {            $dataValuesY = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex($i)->getDataValues();            $dataValuesX = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getDataValues();            $marker = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getPointMarker();            $dataValues = array();            foreach ($dataValuesY as $k => $dataValueY) {                $dataValues[$k] = implode(' ', array_reverse($dataValueY));            }            $tmp = array_shift($dataValues);            $dataValues[] = $tmp;            $tmp = array_shift($dataValuesX);            $dataValuesX[] = $tmp;            $this->graph->SetTitles(array_reverse($dataValues));            $seriesPlot = new RadarPlot(array_reverse($dataValuesX));            $dataLabel = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotLabelByIndex($i)->getDataValue();            $seriesPlot->SetColor(self::$colourSet[self::$plotColour++]);            if ($radarStyle == 'filled') {                $seriesPlot->SetFillColor(self::$colourSet[self::$plotColour]);            }            $this->formatPointMarker($seriesPlot, $marker);            $seriesPlot->SetLegend($dataLabel);            $this->graph->Add($seriesPlot);        }    }    private function renderPlotContour($groupID)    {        $contourStyle = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotStyle();        $seriesCount = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotSeriesCount();        $seriesPlots = array();        $dataValues = array();        //    Loop through each data series in turn        for ($i = 0; $i < $seriesCount; ++$i) {            $dataValuesY = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex($i)->getDataValues();            $dataValuesX = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($i)->getDataValues();            $dataValues[$i] = $dataValuesX;        }        $seriesPlot = new ContourPlot($dataValues);        $this->graph->Add($seriesPlot);    }    private function renderPlotStock($groupID)    {        $seriesCount = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotSeriesCount();        $plotOrder = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotOrder();        $dataValues = array();        //    Loop through each data series in turn and build the plot arrays        foreach ($plotOrder as $i => $v) {            $dataValuesX = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($v)->getDataValues();            foreach ($dataValuesX as $j => $dataValueX) {                $dataValues[$plotOrder[$i]][$j] = $dataValueX;            }        }        if (empty($dataValues)) {            return;        }        $dataValuesPlot = array();        // Flatten the plot arrays to a single dimensional array to work with jpgraph        for ($j = 0; $j < count($dataValues[0]); ++$j) {            for ($i = 0; $i < $seriesCount; ++$i) {                $dataValuesPlot[] = $dataValues[$i][$j];            }        }        // Set the x-axis labels        $labelCount = count($this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex(0)->getPointCount());        if ($labelCount > 0) {            $datasetLabels = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex(0)->getDataValues();            $datasetLabels = $this->formatDataSetLabels($groupID, $datasetLabels, $labelCount);            $this->graph->xaxis->SetTickLabels($datasetLabels);        }        $seriesPlot = new StockPlot($dataValuesPlot);        $seriesPlot->SetWidth(20);        $this->graph->Add($seriesPlot);    }    private function renderAreaChart($groupCount, $dimensions = '2d')    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_line.php');        $this->renderCartesianPlotArea();        for ($i = 0; $i < $groupCount; ++$i) {            $this->renderPlotLine($i, true, false, $dimensions);        }    }    private function renderLineChart($groupCount, $dimensions = '2d')    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_line.php');        $this->renderCartesianPlotArea();        for ($i = 0; $i < $groupCount; ++$i) {            $this->renderPlotLine($i, false, false, $dimensions);        }    }    private function renderBarChart($groupCount, $dimensions = '2d')    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_bar.php');        $this->renderCartesianPlotArea();        for ($i = 0; $i < $groupCount; ++$i) {            $this->renderPlotBar($i, $dimensions);        }    }    private function renderScatterChart($groupCount)    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_scatter.php');        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_regstat.php');        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_line.php');        $this->renderCartesianPlotArea('linlin');        for ($i = 0; $i < $groupCount; ++$i) {            $this->renderPlotScatter($i, false);        }    }    private function renderBubbleChart($groupCount)    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_scatter.php');        $this->renderCartesianPlotArea('linlin');        for ($i = 0; $i < $groupCount; ++$i) {            $this->renderPlotScatter($i, true);        }    }    private function renderPieChart($groupCount, $dimensions = '2d', $doughnut = false, $multiplePlots = false)    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_pie.php');        if ($dimensions == '3d') {            require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_pie3d.php');        }        $this->renderPiePlotArea($doughnut);        $iLimit = ($multiplePlots) ? $groupCount : 1;        for ($groupID = 0; $groupID < $iLimit; ++$groupID) {            $grouping = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotGrouping();            $exploded = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotStyle();            if ($groupID == 0) {                $labelCount = count($this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex(0)->getPointCount());                if ($labelCount > 0) {                    $datasetLabels = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotCategoryByIndex(0)->getDataValues();                    $datasetLabels = $this->formatDataSetLabels($groupID, $datasetLabels, $labelCount);                }            }            $seriesCount = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotSeriesCount();            $seriesPlots = array();            //    For pie charts, we only display the first series: doughnut charts generally display all series            $jLimit = ($multiplePlots) ? $seriesCount : 1;            //    Loop through each data series in turn            for ($j = 0; $j < $jLimit; ++$j) {                $dataValues = $this->chart->getPlotArea()->getPlotGroupByIndex($groupID)->getPlotValuesByIndex($j)->getDataValues();                //    Fill in any missing values in the $dataValues array                $testCurrentIndex = 0;                foreach ($dataValues as $k => $dataValue) {                    while ($k != $testCurrentIndex) {                        $dataValues[$testCurrentIndex] = null;                        ++$testCurrentIndex;                    }                    ++$testCurrentIndex;                }                if ($dimensions == '3d') {                    $seriesPlot = new PiePlot3D($dataValues);                } else {                    if ($doughnut) {                        $seriesPlot = new PiePlotC($dataValues);                    } else {                        $seriesPlot = new PiePlot($dataValues);                    }                }                if ($multiplePlots) {                    $seriesPlot->SetSize(($jLimit-$j) / ($jLimit * 4));                }                if ($doughnut) {                    $seriesPlot->SetMidColor('white');                }                $seriesPlot->SetColor(self::$colourSet[self::$plotColour++]);                if (count($datasetLabels) > 0) {                    $seriesPlot->SetLabels(array_fill(0, count($datasetLabels), ''));                }                if ($dimensions != '3d') {                    $seriesPlot->SetGuideLines(false);                }                if ($j == 0) {                    if ($exploded) {                        $seriesPlot->ExplodeAll();                    }                    $seriesPlot->SetLegends($datasetLabels);                }                $this->graph->Add($seriesPlot);            }        }    }    private function renderRadarChart($groupCount)    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_radar.php');        $this->renderRadarPlotArea();        for ($groupID = 0; $groupID < $groupCount; ++$groupID) {            $this->renderPlotRadar($groupID);        }    }    private function renderStockChart($groupCount)    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_stock.php');        $this->renderCartesianPlotArea('intint');        for ($groupID = 0; $groupID < $groupCount; ++$groupID) {            $this->renderPlotStock($groupID);        }    }    private function renderContourChart($groupCount, $dimensions)    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_contour.php');        $this->renderCartesianPlotArea('intint');        for ($i = 0; $i < $groupCount; ++$i) {            $this->renderPlotContour($i);        }    }    private function renderCombinationChart($groupCount, $dimensions, $outputDestination)    {        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_line.php');        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_bar.php');        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_scatter.php');        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_regstat.php');        require_once(PHPExcel_Settings::getChartRendererPath().'jpgraph_line.php');        $this->renderCartesianPlotArea();        for ($i = 0; $i < $groupCount; ++$i) {            $dimensions = null;            $chartType = $this->chart->getPlotArea()->getPlotGroupByIndex($i)->getPlotType();            switch ($chartType) {                case 'area3DChart':                    $dimensions = '3d';                    // no break                case 'areaChart':                    $this->renderPlotLine($i, true, true, $dimensions);                    break;                case 'bar3DChart':                    $dimensions = '3d';                    // no break                case 'barChart':                    $this->renderPlotBar($i, $dimensions);                    break;                case 'line3DChart':                    $dimensions = '3d';                    // no break                case 'lineChart':                    $this->renderPlotLine($i, false, true, $dimensions);                    break;                case 'scatterChart':                    $this->renderPlotScatter($i, false);                    break;                case 'bubbleChart':                    $this->renderPlotScatter($i, true);                    break;                default:                    $this->graph = null;                    return false;            }        }        $this->renderLegend();        $this->graph->Stroke($outputDestination);        return true;    }    public function render($outputDestination)    {        self::$plotColour = 0;        $groupCount = $this->chart->getPlotArea()->getPlotGroupCount();        $dimensions = null;        if ($groupCount == 1) {            $chartType = $this->chart->getPlotArea()->getPlotGroupByIndex(0)->getPlotType();        } else {            $chartTypes = array();            for ($i = 0; $i < $groupCount; ++$i) {                $chartTypes[] = $this->chart->getPlotArea()->getPlotGroupByIndex($i)->getPlotType();            }            $chartTypes = array_unique($chartTypes);            if (count($chartTypes) == 1) {                $chartType = array_pop($chartTypes);            } elseif (count($chartTypes) == 0) {                echo 'Chart is not yet implemented<br />';                return false;            } else {                return $this->renderCombinationChart($groupCount, $dimensions, $outputDestination);            }        }        switch ($chartType) {            case 'area3DChart':                $dimensions = '3d';                // no break            case 'areaChart':                $this->renderAreaChart($groupCount, $dimensions);                break;            case 'bar3DChart':                $dimensions = '3d';                // no break            case 'barChart':                $this->renderBarChart($groupCount, $dimensions);                break;            case 'line3DChart':                $dimensions = '3d';                // no break            case 'lineChart':                $this->renderLineChart($groupCount, $dimensions);                break;            case 'pie3DChart':                $dimensions = '3d';                // no break            case 'pieChart':                $this->renderPieChart($groupCount, $dimensions, false, false);                break;            case 'doughnut3DChart':                $dimensions = '3d';                // no break            case 'doughnutChart':                $this->renderPieChart($groupCount, $dimensions, true, true);                break;            case 'scatterChart':                $this->renderScatterChart($groupCount);                break;            case 'bubbleChart':                $this->renderBubbleChart($groupCount);                break;            case 'radarChart':                $this->renderRadarChart($groupCount);                break;            case 'surface3DChart':                $dimensions = '3d';                // no break            case 'surfaceChart':                $this->renderContourChart($groupCount, $dimensions);                break;            case 'stockChart':                $this->renderStockChart($groupCount, $dimensions);                break;            default:                echo $chartType.' is not yet implemented<br />';                return false;        }        $this->renderLegend();        $this->graph->Stroke($outputDestination);        return true;    }    /**     * Create a new PHPExcel_Chart_Renderer_jpgraph     */    public function __construct(PHPExcel_Chart $chart)    {        $this->graph    = null;        $this->chart    = $chart;    }}
 |