You are here

Chart.php in Loft Data Grids 6.2

File

vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart.php
View source
<?php

/**
 * PHPExcel
 *
 * Copyright (c) 2006 - 2014 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
 * @copyright	Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel)
 * @license		http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL
 * @version		##VERSION##, ##DATE##
 */

/**
 * PHPExcel_Chart
 *
 * @category	PHPExcel
 * @package		PHPExcel_Chart
 * @copyright	Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel)
 */
class PHPExcel_Chart {

  /**
   * Chart Name
   *
   * @var string
   */
  private $_name = '';

  /**
   * Worksheet
   *
   * @var PHPExcel_Worksheet
   */
  private $_worksheet = null;

  /**
   * Chart Title
   *
   * @var PHPExcel_Chart_Title
   */
  private $_title = null;

  /**
   * Chart Legend
   *
   * @var PHPExcel_Chart_Legend
   */
  private $_legend = null;

  /**
   * X-Axis Label
   *
   * @var PHPExcel_Chart_Title
   */
  private $_xAxisLabel = null;

  /**
   * Y-Axis Label
   *
   * @var PHPExcel_Chart_Title
   */
  private $_yAxisLabel = null;

  /**
   * Chart Plot Area
   *
   * @var PHPExcel_Chart_PlotArea
   */
  private $_plotArea = null;

  /**
   * Plot Visible Only
   *
   * @var boolean
   */
  private $_plotVisibleOnly = true;

  /**
   * Display Blanks as
   *
   * @var string
   */
  private $_displayBlanksAs = '0';

  /**
   * Chart Asix Y as
   *
   * @var PHPExcel_Chart_Axis
   */
  private $_yAxis = null;

  /**
   * Chart Asix X as
   *
   * @var PHPExcel_Chart_Axis
   */
  private $_xAxis = null;

  /**
   * Chart Major Gridlines as
   *
   * @var PHPExcel_Chart_GridLines
   */
  private $_majorGridlines = null;

  /**
   * Chart Minor Gridlines as
   *
   * @var PHPExcel_Chart_GridLines
   */
  private $_minorGridlines = null;

  /**
   * Top-Left Cell Position
   *
   * @var string
   */
  private $_topLeftCellRef = 'A1';

  /**
   * Top-Left X-Offset
   *
   * @var integer
   */
  private $_topLeftXOffset = 0;

  /**
   * Top-Left Y-Offset
   *
   * @var integer
   */
  private $_topLeftYOffset = 0;

  /**
   * Bottom-Right Cell Position
   *
   * @var string
   */
  private $_bottomRightCellRef = 'A1';

  /**
   * Bottom-Right X-Offset
   *
   * @var integer
   */
  private $_bottomRightXOffset = 10;

  /**
   * Bottom-Right Y-Offset
   *
   * @var integer
   */
  private $_bottomRightYOffset = 10;

  /**
   * Create a new PHPExcel_Chart
   */
  public function __construct($name, PHPExcel_Chart_Title $title = null, PHPExcel_Chart_Legend $legend = null, PHPExcel_Chart_PlotArea $plotArea = null, $plotVisibleOnly = true, $displayBlanksAs = '0', PHPExcel_Chart_Title $xAxisLabel = null, PHPExcel_Chart_Title $yAxisLabel = null, PHPExcel_Chart_Axis $xAxis = null, PHPExcel_Chart_Axis $yAxis = null, PHPExcel_Chart_GridLines $majorGridlines = null, PHPExcel_Chart_GridLines $minorGridlines = null) {
    $this->_name = $name;
    $this->_title = $title;
    $this->_legend = $legend;
    $this->_xAxisLabel = $xAxisLabel;
    $this->_yAxisLabel = $yAxisLabel;
    $this->_plotArea = $plotArea;
    $this->_plotVisibleOnly = $plotVisibleOnly;
    $this->_displayBlanksAs = $displayBlanksAs;
    $this->_xAxis = $xAxis;
    $this->_yAxis = $yAxis;
    $this->_majorGridlines = $majorGridlines;
    $this->_minorGridlines = $minorGridlines;
  }

  /**
   * Get Name
   *
   * @return string
   */
  public function getName() {
    return $this->_name;
  }

  /**
   * Get Worksheet
   *
   * @return PHPExcel_Worksheet
   */
  public function getWorksheet() {
    return $this->_worksheet;
  }

  /**
   * Set Worksheet
   *
   * @param	PHPExcel_Worksheet	$pValue
   * @throws	PHPExcel_Chart_Exception
   * @return PHPExcel_Chart
   */
  public function setWorksheet(PHPExcel_Worksheet $pValue = null) {
    $this->_worksheet = $pValue;
    return $this;
  }

  /**
   * Get Title
   *
   * @return PHPExcel_Chart_Title
   */
  public function getTitle() {
    return $this->_title;
  }

  /**
   * Set Title
   *
   * @param	PHPExcel_Chart_Title $title
   * @return	PHPExcel_Chart
   */
  public function setTitle(PHPExcel_Chart_Title $title) {
    $this->_title = $title;
    return $this;
  }

  /**
   * Get Legend
   *
   * @return PHPExcel_Chart_Legend
   */
  public function getLegend() {
    return $this->_legend;
  }

  /**
   * Set Legend
   *
   * @param	PHPExcel_Chart_Legend $legend
   * @return	PHPExcel_Chart
   */
  public function setLegend(PHPExcel_Chart_Legend $legend) {
    $this->_legend = $legend;
    return $this;
  }

  /**
   * Get X-Axis Label
   *
   * @return PHPExcel_Chart_Title
   */
  public function getXAxisLabel() {
    return $this->_xAxisLabel;
  }

  /**
   * Set X-Axis Label
   *
   * @param	PHPExcel_Chart_Title $label
   * @return	PHPExcel_Chart
   */
  public function setXAxisLabel(PHPExcel_Chart_Title $label) {
    $this->_xAxisLabel = $label;
    return $this;
  }

  /**
   * Get Y-Axis Label
   *
   * @return PHPExcel_Chart_Title
   */
  public function getYAxisLabel() {
    return $this->_yAxisLabel;
  }

  /**
   * Set Y-Axis Label
   *
   * @param	PHPExcel_Chart_Title $label
   * @return	PHPExcel_Chart
   */
  public function setYAxisLabel(PHPExcel_Chart_Title $label) {
    $this->_yAxisLabel = $label;
    return $this;
  }

  /**
   * Get Plot Area
   *
   * @return PHPExcel_Chart_PlotArea
   */
  public function getPlotArea() {
    return $this->_plotArea;
  }

  /**
   * Get Plot Visible Only
   *
   * @return boolean
   */
  public function getPlotVisibleOnly() {
    return $this->_plotVisibleOnly;
  }

  /**
   * Set Plot Visible Only
   *
   * @param boolean $plotVisibleOnly
   * @return PHPExcel_Chart
   */
  public function setPlotVisibleOnly($plotVisibleOnly = true) {
    $this->_plotVisibleOnly = $plotVisibleOnly;
    return $this;
  }

  /**
   * Get Display Blanks as
   *
   * @return string
   */
  public function getDisplayBlanksAs() {
    return $this->_displayBlanksAs;
  }

  /**
   * Set Display Blanks as
   *
   * @param string $displayBlanksAs
   * @return PHPExcel_Chart
   */
  public function setDisplayBlanksAs($displayBlanksAs = '0') {
    $this->_displayBlanksAs = $displayBlanksAs;
  }

  /**
   * Get yAxis
   *
   * @return PHPExcel_Chart_Axis
   */
  public function getChartAxisY() {
    if ($this->_yAxis !== NULL) {
      return $this->_yAxis;
    }
    return new PHPExcel_Chart_Axis();
  }

  /**
   * Get xAxis
   *
   * @return PHPExcel_Chart_Axis
   */
  public function getChartAxisX() {
    if ($this->_xAxis !== NULL) {
      return $this->_xAxis;
    }
    return new PHPExcel_Chart_Axis();
  }

  /**
   * Get Major Gridlines
   *
   * @return PHPExcel_Chart_GridLines
   */
  public function getMajorGridlines() {
    if ($this->_majorGridlines !== NULL) {
      return $this->_majorGridlines;
    }
    return new PHPExcel_Chart_GridLines();
  }

  /**
   * Get Minor Gridlines
   *
   * @return PHPExcel_Chart_GridLines
   */
  public function getMinorGridlines() {
    if ($this->_minorGridlines !== NULL) {
      return $this->_minorGridlines;
    }
    return new PHPExcel_Chart_GridLines();
  }

  /**
   * Set the Top Left position for the chart
   *
   * @param	string	$cell
   * @param	integer	$xOffset
   * @param	integer	$yOffset
   * @return PHPExcel_Chart
   */
  public function setTopLeftPosition($cell, $xOffset = null, $yOffset = null) {
    $this->_topLeftCellRef = $cell;
    if (!is_null($xOffset)) {
      $this
        ->setTopLeftXOffset($xOffset);
    }
    if (!is_null($yOffset)) {
      $this
        ->setTopLeftYOffset($yOffset);
    }
    return $this;
  }

  /**
   * Get the top left position of the chart
   *
   * @return array	an associative array containing the cell address, X-Offset and Y-Offset from the top left of that cell
   */
  public function getTopLeftPosition() {
    return array(
      'cell' => $this->_topLeftCellRef,
      'xOffset' => $this->_topLeftXOffset,
      'yOffset' => $this->_topLeftYOffset,
    );
  }

  /**
   * Get the cell address where the top left of the chart is fixed
   *
   * @return string
   */
  public function getTopLeftCell() {
    return $this->_topLeftCellRef;
  }

  /**
   * Set the Top Left cell position for the chart
   *
   * @param	string	$cell
   * @return PHPExcel_Chart
   */
  public function setTopLeftCell($cell) {
    $this->_topLeftCellRef = $cell;
    return $this;
  }

  /**
   * Set the offset position within the Top Left cell for the chart
   *
   * @param	integer	$xOffset
   * @param	integer	$yOffset
   * @return PHPExcel_Chart
   */
  public function setTopLeftOffset($xOffset = null, $yOffset = null) {
    if (!is_null($xOffset)) {
      $this
        ->setTopLeftXOffset($xOffset);
    }
    if (!is_null($yOffset)) {
      $this
        ->setTopLeftYOffset($yOffset);
    }
    return $this;
  }

  /**
   * Get the offset position within the Top Left cell for the chart
   *
   * @return integer[]
   */
  public function getTopLeftOffset() {
    return array(
      'X' => $this->_topLeftXOffset,
      'Y' => $this->_topLeftYOffset,
    );
  }
  public function setTopLeftXOffset($xOffset) {
    $this->_topLeftXOffset = $xOffset;
    return $this;
  }
  public function getTopLeftXOffset() {
    return $this->_topLeftXOffset;
  }
  public function setTopLeftYOffset($yOffset) {
    $this->_topLeftYOffset = $yOffset;
    return $this;
  }
  public function getTopLeftYOffset() {
    return $this->_topLeftYOffset;
  }

  /**
   * Set the Bottom Right position of the chart
   *
   * @param	string	$cell
   * @param	integer	$xOffset
   * @param	integer	$yOffset
   * @return PHPExcel_Chart
   */
  public function setBottomRightPosition($cell, $xOffset = null, $yOffset = null) {
    $this->_bottomRightCellRef = $cell;
    if (!is_null($xOffset)) {
      $this
        ->setBottomRightXOffset($xOffset);
    }
    if (!is_null($yOffset)) {
      $this
        ->setBottomRightYOffset($yOffset);
    }
    return $this;
  }

  /**
   * Get the bottom right position of the chart
   *
   * @return array	an associative array containing the cell address, X-Offset and Y-Offset from the top left of that cell
   */
  public function getBottomRightPosition() {
    return array(
      'cell' => $this->_bottomRightCellRef,
      'xOffset' => $this->_bottomRightXOffset,
      'yOffset' => $this->_bottomRightYOffset,
    );
  }
  public function setBottomRightCell($cell) {
    $this->_bottomRightCellRef = $cell;
    return $this;
  }

  /**
   * Get the cell address where the bottom right of the chart is fixed
   *
   * @return string
   */
  public function getBottomRightCell() {
    return $this->_bottomRightCellRef;
  }

  /**
   * Set the offset position within the Bottom Right cell for the chart
   *
   * @param	integer	$xOffset
   * @param	integer	$yOffset
   * @return PHPExcel_Chart
   */
  public function setBottomRightOffset($xOffset = null, $yOffset = null) {
    if (!is_null($xOffset)) {
      $this
        ->setBottomRightXOffset($xOffset);
    }
    if (!is_null($yOffset)) {
      $this
        ->setBottomRightYOffset($yOffset);
    }
    return $this;
  }

  /**
   * Get the offset position within the Bottom Right cell for the chart
   *
   * @return integer[]
   */
  public function getBottomRightOffset() {
    return array(
      'X' => $this->_bottomRightXOffset,
      'Y' => $this->_bottomRightYOffset,
    );
  }
  public function setBottomRightXOffset($xOffset) {
    $this->_bottomRightXOffset = $xOffset;
    return $this;
  }
  public function getBottomRightXOffset() {
    return $this->_bottomRightXOffset;
  }
  public function setBottomRightYOffset($yOffset) {
    $this->_bottomRightYOffset = $yOffset;
    return $this;
  }
  public function getBottomRightYOffset() {
    return $this->_bottomRightYOffset;
  }
  public function refresh() {
    if ($this->_worksheet !== NULL) {
      $this->_plotArea
        ->refresh($this->_worksheet);
    }
  }
  public function render($outputDestination = null) {
    $libraryName = PHPExcel_Settings::getChartRendererName();
    if (is_null($libraryName)) {
      return false;
    }

    //	Ensure that data series values are up-to-date before we render
    $this
      ->refresh();
    $libraryPath = PHPExcel_Settings::getChartRendererPath();
    $includePath = str_replace('\\', '/', get_include_path());
    $rendererPath = str_replace('\\', '/', $libraryPath);
    if (strpos($rendererPath, $includePath) === false) {
      set_include_path(get_include_path() . PATH_SEPARATOR . $libraryPath);
    }
    $rendererName = 'PHPExcel_Chart_Renderer_' . $libraryName;
    $renderer = new $rendererName($this);
    if ($outputDestination == 'php://output') {
      $outputDestination = null;
    }
    return $renderer
      ->render($outputDestination);
  }

}

Classes

Namesort descending Description
PHPExcel_Chart PHPExcel_Chart