X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/53dea79e14a592c07d0211cb7a7d93949c231fe1..409294316ffb829e4fb995ce023b7ca279204771:/lib/MECON/PDF/Tabla.php diff --git a/lib/MECON/PDF/Tabla.php b/lib/MECON/PDF/Tabla.php index cd1d7d4..876c704 100644 --- a/lib/MECON/PDF/Tabla.php +++ b/lib/MECON/PDF/Tabla.php @@ -24,25 +24,222 @@ Autor: Martin Marrese $Id$ -----------------------------------------------------------------------------*/ -require_once 'MECON/PDF/Marco.php'; +require_once 'MECON/PDF/Contenido.php'; /** * Libreria que permite agregar una tabla a un pdf. */ -class MECON_PDF_Tabla extends MECON_PDF_Marco { - +class MECON_PDF_Tabla extends MECON_PDF_Contenido { + + /** + * Configuracion + * @var array $config + * @access protected + */ + var $_config; + + /** + * Objeto MECON_HTML_Tabla. + * @var &Object $tabla MECON_HTML_Tabla + * @access protected + */ + var $_tabla; + + /** + * Objeto MECON_PDF_Marco + * @var &Object $marco + * @access protected + */ + var $_marco; + /** - * Funcion que envia el archivo a pantalla (para que el usuario haga un - * download) + * Class Constructor * - * @return string + * @param &Object $TABLA MECON_HTML_Tabla + * + * @return void * @access public */ - function display() { - $this->_pdf->newPage($this->_tamanio); - $this->buildPage(); - $this->_pdf->display(); + function MECON_PDF_Tabla(&$TABLA) { + $this->_tabla =& $TABLA; + $this->_config = include 'MECON/PDF/Tabla/medidas.php'; } + /** + * Funcion que agrega el contenido de la tabla que se este utilizando al + * PDF. + * + * @param &Object $MARCO MECON_PDF_Marco + * + * @return void + * @access public + */ + function toPDF(&$MARCO) { + $this->_marco =& $MARCO; + $this->_agregarContenido(); + } + + /** + * Funcion que devuelve la posicion X en donde se debe escribir un texto + * segun su ubicacion en la celda + * + * @param int $row Indicador de la fila + * @param int $col Indicador de la columna + * @param string $texto Texto a escribir + * @param array $attr Atributos internos de la celda + * @param array $estilo Estilo del texto + * + * @return int + * @access protected + */ + function _obtenerAlineacionTexto($row, $col, $texto, $attr, $estilo) { + + $at = $this->_tabla->getCellAttributes($row, $col); + if (@$at['align'] == 'center') { + $tam = $this->_marco->strlen($texto, $estilo); + $init = $attr[$col] + ($attr[$col+1] - $attr[$col] - $tam) / 2; + } + elseif (@$at['align'] == 'right') { + $tam = $this->_marco->strlen($texto, $estilo); + $init = $attr[$col+1] - $tam + 1; + } + else { + $init = $attr[$col]; + } + return $init + 1; + } + + /** + * Funcion que devuelve el estilo de la celda segun la configuracion. + * + * @param int $row Indicador de la fila + * @param int $col Indicador de la columna + * + * @return array + * @access protected + */ + function _obtenerEstiloCelda($row, $col) { + $clase = $this->_tabla->getCellAttributes($row, $col); + if (@$clase['cabecera'] || @$clase['oscura']) { + $estilo = $this->_config['celda_cabecera']; + } + elseif (@$clase['titulo'] || @$clase['clara']) { + $estilo = $this->_config['celda_titulo']; + } + else { + $estilo = $this->_config['celda_comun']; + } + return $estilo; + } + + /** + * Funcion que calcula el ancho de las columnas de la tabla. + * + * @return array + * @access protected + */ + function _obtenerAnchoColumnas() { + $ancho_pagina = $this->_marco->getWidth($this->_marco->orientacion); + for ($i=0; $i<$this->_tabla->getColCount(); $i++ ) { + $tmp = $this->_tabla->getCellAttributes(0,$i); + if (is_null(@$tmp['width'])) { + die ('Todas las columnas deben tener asignado un ancho.'); + } + $attr[$i] = intval($tmp['width']); + } + $tmp = array_sum($attr); + $attr2[0] = 0; + for ($i=1; $i_marco->espacioDisponible; + if ($alto <= 0 ) { + $this->_marco->newPage($this->_marco->tamanio); + $alto = $this->_marco->espacioDisponible; + } + + $attr2 = $this->_obtenerAnchoColumnas(); + for ($i = 0; $i < $this->_tabla->getRowCount(); $i++) { + $max = 0; + for ($j = 0; $j < $this->_tabla->getColCount(); $j++) { + $estilo = $this->_obtenerEstiloCelda($i, $j); + $txt = $this->_marco->wordWrap($this->_tabla->getCellContents($i,$j), + $attr2[$j+1] - $attr2[$j], $estilo); + $txtt[$j] = $txt; //Esto es para no hacer el wordWrap siempre + $max = max($estilo['alto_linea'] * count($txt), $max); + + $rep = array (); + $rep = $this->_tabla->getCellAttributes($i, $j); + if (@$rep['cabecera'] || @$rep['titulo']) { + $repetir[$i][$j] = $txt; + $repetir[$i]['max'] = $max; + } + } + + if ($alto <= 0) + { + $this->_marco->newPage($this->_marco->tamanio); + $alto = $this->_marco->espacioDisponible; + + foreach ($repetir as $ii => $value) { + $alto -= $repetir[$ii]['max']; + for ($jj = 0; $jj < $this->_tabla->getColCount(); $jj++) { + $estilo = $this->_obtenerEstiloCelda($ii, $jj); + $this->_marco->addRectangle($attr2[$jj], $alto, + $attr2[$jj+1], $alto+$repetir[$ii]['max'], + @$estilo['fill'], null, $this->_marco->orientacion); + + $alto1 = $alto + $repetir[$ii]['max']; + foreach ($repetir[$ii][$jj] as $t) { + $alto1 -= $estilo['alto_linea']; + + //Ubico el texto segun su alineacion + $init = $this->_obtenerAlineacionTexto($ii, $jj, $t, $attr2, + $estilo); + + $this->_marco->addText($init, $alto1 + 2, + $t, $estilo, null, $this->_marco->orientacion); + } + } + } + + } + + $alto -= $max; + for ($j = 0; $j < $this->_tabla->getColCount(); $j++) { + + $estilo = $this->_obtenerEstiloCelda($i, $j); + + $this->_marco->addRectangle($attr2[$j], $alto, + $attr2[$j+1], $alto+$max, @$estilo['fill'], null, + $this->_marco->orientacion); + + $alto1 = $alto + $max; + foreach ($txtt[$j] as $t) { + $alto1 -= $estilo['alto_linea']; + + //Ubico el texto segun su alineacion + $init = $this->_obtenerAlineacionTexto($i, $j, $t, $attr2, + $estilo); + + $this->_marco->addText($init, $alto1 + 2, + $t, $estilo, null, $this->_marco->orientacion); + } + } + } + $this->_marco->espacioDisponible = $alto; + } } ?> \ No newline at end of file