public function PHPExcel_Writer_Excel5_Workbook::addXfWriter in Loft Data Grids 6.2
Same name and namespace in other branches
- 7.2 vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/Workbook.php \PHPExcel_Writer_Excel5_Workbook::addXfWriter()
* Add a new XF writer * *
Parameters
PHPExcel_Style: * @param boolean Is it a style XF? * @return int Index to XF record
File
- vendor/
phpoffice/ phpexcel/ Classes/ PHPExcel/ Writer/ Excel5/ Workbook.php, line 253
Class
- PHPExcel_Writer_Excel5_Workbook
- PHPExcel_Writer_Excel5_Workbook
Code
public function addXfWriter($style, $isStyleXf = false) {
$xfWriter = new PHPExcel_Writer_Excel5_Xf($style);
$xfWriter
->setIsStyleXf($isStyleXf);
// Add the font if not already added
$fontIndex = $this
->_addFont($style
->getFont());
// Assign the font index to the xf record
$xfWriter
->setFontIndex($fontIndex);
// Background colors, best to treat these after the font so black will come after white in custom palette
$xfWriter
->setFgColor($this
->_addColor($style
->getFill()
->getStartColor()
->getRGB()));
$xfWriter
->setBgColor($this
->_addColor($style
->getFill()
->getEndColor()
->getRGB()));
$xfWriter
->setBottomColor($this
->_addColor($style
->getBorders()
->getBottom()
->getColor()
->getRGB()));
$xfWriter
->setTopColor($this
->_addColor($style
->getBorders()
->getTop()
->getColor()
->getRGB()));
$xfWriter
->setRightColor($this
->_addColor($style
->getBorders()
->getRight()
->getColor()
->getRGB()));
$xfWriter
->setLeftColor($this
->_addColor($style
->getBorders()
->getLeft()
->getColor()
->getRGB()));
$xfWriter
->setDiagColor($this
->_addColor($style
->getBorders()
->getDiagonal()
->getColor()
->getRGB()));
// Add the number format if it is not a built-in one and not already added
if ($style
->getNumberFormat()
->getBuiltInFormatCode() === false) {
$numberFormatHashCode = $style
->getNumberFormat()
->getHashCode();
if (isset($this->_addedNumberFormats[$numberFormatHashCode])) {
$numberFormatIndex = $this->_addedNumberFormats[$numberFormatHashCode];
}
else {
$numberFormatIndex = 164 + count($this->_numberFormats);
$this->_numberFormats[$numberFormatIndex] = $style
->getNumberFormat();
$this->_addedNumberFormats[$numberFormatHashCode] = $numberFormatIndex;
}
}
else {
$numberFormatIndex = (int) $style
->getNumberFormat()
->getBuiltInFormatCode();
}
// Assign the number format index to xf record
$xfWriter
->setNumberFormatIndex($numberFormatIndex);
$this->_xfWriters[] = $xfWriter;
$xfIndex = count($this->_xfWriters) - 1;
return $xfIndex;
}