123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- <?php
- namespace PhpOffice\PhpSpreadsheet\Chart;
- class Legend
- {
- /** Legend positions */
- const XL_LEGEND_POSITION_BOTTOM = -4107; // Below the chart.
- const XL_LEGEND_POSITION_CORNER = 2; // In the upper right-hand corner of the chart border.
- const XL_LEGEND_POSITION_CUSTOM = -4161; // A custom position.
- const XL_LEGEND_POSITION_LEFT = -4131; // Left of the chart.
- const XL_LEGEND_POSITION_RIGHT = -4152; // Right of the chart.
- const XL_LEGEND_POSITION_TOP = -4160; // Above the chart.
- const POSITION_RIGHT = 'r';
- const POSITION_LEFT = 'l';
- const POSITION_BOTTOM = 'b';
- const POSITION_TOP = 't';
- const POSITION_TOPRIGHT = 'tr';
- private static $positionXLref = [
- self::XL_LEGEND_POSITION_BOTTOM => self::POSITION_BOTTOM,
- self::XL_LEGEND_POSITION_CORNER => self::POSITION_TOPRIGHT,
- self::XL_LEGEND_POSITION_CUSTOM => '??',
- self::XL_LEGEND_POSITION_LEFT => self::POSITION_LEFT,
- self::XL_LEGEND_POSITION_RIGHT => self::POSITION_RIGHT,
- self::XL_LEGEND_POSITION_TOP => self::POSITION_TOP,
- ];
- /**
- * Legend position.
- *
- * @var string
- */
- private $position = self::POSITION_RIGHT;
- /**
- * Allow overlay of other elements?
- *
- * @var bool
- */
- private $overlay = true;
- /**
- * Legend Layout.
- *
- * @var Layout
- */
- private $layout;
- /**
- * Create a new Legend.
- *
- * @param string $position
- * @param null|Layout $layout
- * @param bool $overlay
- */
- public function __construct($position = self::POSITION_RIGHT, Layout $layout = null, $overlay = false)
- {
- $this->setPosition($position);
- $this->layout = $layout;
- $this->setOverlay($overlay);
- }
- /**
- * Get legend position as an excel string value.
- *
- * @return string
- */
- public function getPosition()
- {
- return $this->position;
- }
- /**
- * Get legend position using an excel string value.
- *
- * @param string $position see self::POSITION_*
- *
- * @return bool
- */
- public function setPosition($position)
- {
- if (!in_array($position, self::$positionXLref)) {
- return false;
- }
- $this->position = $position;
- return true;
- }
- /**
- * Get legend position as an Excel internal numeric value.
- *
- * @return int
- */
- public function getPositionXL()
- {
- return array_search($this->position, self::$positionXLref);
- }
- /**
- * Set legend position using an Excel internal numeric value.
- *
- * @param int $positionXL see self::XL_LEGEND_POSITION_*
- *
- * @return bool
- */
- public function setPositionXL($positionXL)
- {
- if (!isset(self::$positionXLref[$positionXL])) {
- return false;
- }
- $this->position = self::$positionXLref[$positionXL];
- return true;
- }
- /**
- * Get allow overlay of other elements?
- *
- * @return bool
- */
- public function getOverlay()
- {
- return $this->overlay;
- }
- /**
- * Set allow overlay of other elements?
- *
- * @param bool $overlay
- *
- * @return bool
- */
- public function setOverlay($overlay)
- {
- if (!is_bool($overlay)) {
- return false;
- }
- $this->overlay = $overlay;
- return true;
- }
- /**
- * Get Layout.
- *
- * @return Layout
- */
- public function getLayout()
- {
- return $this->layout;
- }
- }
|