_colorIndex = 0x7FFF; $this->_font = $font; } /** * Set the color index * * @param int $colorIndex */ public function setColorIndex($colorIndex) { $this->_colorIndex = $colorIndex; } /** * Get font record data * * @return string */ public function writeFont() { $font_outline = 0; $font_shadow = 0; $icv = $this->_colorIndex; // Index to color palette if ($this->_font->getSuperScript()) { $sss = 1; } else if ($this->_font->getSubScript()) { $sss = 2; } else { $sss = 0; } $bFamily = 0; // Font family $bCharSet = PHPExcel_Shared_Font::getCharsetFromFontName($this->_font->getName()); // Character set $record = 0x31; // Record identifier $reserved = 0x00; // Reserved $grbit = 0x00; // Font attributes if ($this->_font->getItalic()) { $grbit |= 0x02; } if ($this->_font->getStrikethrough()) { $grbit |= 0x08; } if ($font_outline) { $grbit |= 0x10; } if ($font_shadow) { $grbit |= 0x20; } $data = pack("vvvvvCCCC", $this->_font->getSize() * 20, $grbit, $icv, $this->_mapBold($this->_font->getBold()), $sss, $this->_mapUnderline($this->_font->getUnderline()), $bFamily, $bCharSet, $reserved ); $data .= PHPExcel_Shared_String::UTF8toBIFF8UnicodeShort($this->_font->getName()); $length = strlen($data); $header = pack("vv", $record, $length); return($header . $data); } /** * Map to BIFF5-BIFF8 codes for bold * * @param boolean $bold * @return int */ private function _mapBold($bold) { if ($bold) { return 0x2BC; } return 0x190; } /** * Map underline * * @param string * @return int */ private function _mapUnderline($underline) { switch ($underline) { case PHPExcel_Style_Font::UNDERLINE_NONE: return 0x00; case PHPExcel_Style_Font::UNDERLINE_SINGLE: return 0x01; case PHPExcel_Style_Font::UNDERLINE_DOUBLE: return 0x02; case PHPExcel_Style_Font::UNDERLINE_SINGLEACCOUNTING: return 0x21; case PHPExcel_Style_Font::UNDERLINE_DOUBLEACCOUNTING: return 0x22; default: return 0x00; } } }