Source for file BaseDrawing.php
Documentation is available at BaseDrawing.php
* Copyright (c) 2006 - 2009 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
* @package PHPExcel_Worksheet
* @copyright Copyright (c) 2006 - 2009 PHPExcel (http://www.codeplex.com/PHPExcel)
* @license http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt LGPL
* @version 1.6.5, 2009-01-05
/** PHPExcel_IComparable */
require_once 'PHPExcel/IComparable.php';
/** PHPExcel_Worksheet */
require_once 'PHPExcel/Worksheet.php';
/** PHPExcel_Worksheet_Drawing_Shadow */
require_once 'PHPExcel/Worksheet/Drawing/Shadow.php';
* PHPExcel_Worksheet_BaseDrawing
* @package PHPExcel_Worksheet
* @copyright Copyright (c) 2006 - 2009 PHPExcel (http://www.codeplex.com/PHPExcel)
private static $_imageCounter = 0;
private static $_imageIndex = 0;
* @var PHPExcel_Worksheet
* @var PHPExcel_Worksheet_Drawing_Shadow
* Create a new PHPExcel_Worksheet_BaseDrawing
public function setName($pValue = '') {
* @return PHPExcel_Worksheet
* @param PHPExcel_Worksheet $pValue
* @param bool $pOverrideOld If a Worksheet has already been assigned, overwrite it and remove image from old Worksheet?
public function setWorksheet(PHPExcel_Worksheet $pValue = null, $pOverrideOld = false) {
// Add drawing to PHPExcel_Worksheet
// Remove drawing from old PHPExcel_Worksheet
while ($iterator->valid()) {
if ($iterator->current()->getHashCode() == $this->getHashCode()) {
// Set new PHPExcel_Worksheet
throw new Exception("A PHPExcel_Worksheet has already been assigned. Drawings can only exist on one PHPExcel_Worksheet.");
* Set width and height with proportional resize
* @author Vincent@luo MSN:kele_100@hotmail.com
* @example $objDrawing->setResizeProportional(true);
* @example $objDrawing->setWidthAndHeight(160,120);
$xratio = $width / $this->_width;
$yratio = $height / $this->_height;
if (($xratio * $this->_height) < $height) {
* @return PHPExcel_Worksheet_Drawing_Shadow
* @param PHPExcel_Worksheet_Drawing_Shadow $pValue
public function setShadow(PHPExcel_Worksheet_Drawing_Shadow $pValue = null) {
* @return string Hash code
* Note that this index may vary during script execution! Only reliable moment is
* while doing a write of a workbook and when changes are not allowed.
* @return string Hash index
* Note that this index may vary during script execution! Only reliable moment is
* while doing a write of a workbook and when changes are not allowed.
* @param string $value Hash index
* Implement PHP __clone to create a deep clone, not just a shallow copy.
foreach ($vars as $key => $value) {
$this->$key = clone $value;
|