103 lines
2.1 KiB
PHP
Raw Normal View History

2014-06-10 07:11:32 +07:00
<?php
/**
* This file is part of PHPWord - A pure PHP library for reading and writing
* word processing documents.
*
* PHPWord is free software distributed under the terms of the GNU Lesser
* General Public License version 3 as published by the Free Software Foundation.
*
* For the full copyright and license information, please read the LICENSE
* file that was distributed with this source code. For the full list of
* contributors, visit https://github.com/PHPOffice/PHPWord/contributors.
*
* @link https://github.com/PHPOffice/PHPWord
* @copyright 2010-2014 PHPWord contributors
* @license http://www.gnu.org/licenses/lgpl.txt LGPL version 3
*/
namespace PhpOffice\PhpWord\Element;
/**
* Chart element
*
* @since 0.12.0
*/
class Chart extends AbstractElement
{
/**
* Is part of collection
*
* @var bool
*/
protected $collectionRelation = true;
/**
* Type
*
* @var string
*/
private $type = 'pie';
/**
2014-06-12 18:15:00 +07:00
* Series
2014-06-10 07:11:32 +07:00
*
* @var array
*/
2014-06-12 18:15:00 +07:00
private $series = array();
2014-06-10 07:11:32 +07:00
/**
* Create new instance
*
* @param string $type
2014-06-12 18:15:00 +07:00
* @param array $categories
* @param array $values
2014-06-10 07:11:32 +07:00
*/
2014-06-12 18:15:00 +07:00
public function __construct($type, $categories, $values)
2014-06-10 07:11:32 +07:00
{
$this->setType($type);
2014-06-12 18:15:00 +07:00
$this->addSeries($categories, $values);
2014-06-10 07:11:32 +07:00
}
/**
* Get type
*
2014-06-11 23:04:13 +07:00
* @return string
2014-06-10 07:11:32 +07:00
*/
public function getType()
{
return $this->type;
}
/**
* Set type
*
2014-06-11 23:04:13 +07:00
* @param string $value
2014-06-10 07:11:32 +07:00
*/
public function setType($value)
{
$enum = array('pie', 'doughnut', 'line', 'bar', 'area', 'radar', 'scatter');
$this->type = $this->setEnumVal($value, $enum, 'pie');
}
/**
2014-06-12 18:15:00 +07:00
* Add series
2014-06-10 07:11:32 +07:00
*
2014-06-12 18:15:00 +07:00
* @param array $categories
* @param array $values
2014-06-10 07:11:32 +07:00
*/
2014-06-12 18:15:00 +07:00
public function addSeries($categories, $values)
2014-06-10 07:11:32 +07:00
{
2014-06-12 18:15:00 +07:00
$this->series[] = array('categories' => $categories, 'values' => $values);
2014-06-10 07:11:32 +07:00
}
/**
2014-06-12 18:15:00 +07:00
* Get series
2014-06-10 07:11:32 +07:00
*
* @return array
*/
2014-06-12 18:15:00 +07:00
public function getSeries()
2014-06-10 07:11:32 +07:00
{
2014-06-12 18:15:00 +07:00
return $this->series;
2014-06-10 07:11:32 +07:00
}
}