X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/51a1428cd773aa45b8da0bb9b715784c16c93c44..ba224fe1e6f6212651818538d7770690d821bfe0:/lib/MECON/PDF/Tabla.php diff --git a/lib/MECON/PDF/Tabla.php b/lib/MECON/PDF/Tabla.php index 38c5a58..595019e 100644 --- a/lib/MECON/PDF/Tabla.php +++ b/lib/MECON/PDF/Tabla.php @@ -51,18 +51,36 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { * @access protected */ var $_marco; + + /** + * Orientacion de las nuevas paginas + * @var string $orientacion + * @access protected + */ + var $_orientacion; + + /** + * Indica si el encabezado debe ir en la nuevas paginas. + * @var bool $encabezado + * @access protected; + */ + var $_encabezado; /** * Class Constructor * * @param &Object $TABLA MECON_HTML_Tabla + * @param string $orientacion Orientacion que deben tener las nuevas paginas + * que genere la tabla. * * @return void * @access public */ - function MECON_PDF_Tabla(&$TABLA) { - $this->_tabla =& $TABLA; + function MECON_PDF_Tabla($TABLA, $orientacion = null, $encabezado = true) { + $this->_tabla = $TABLA; + $this->_orientacion = $orientacion; $this->_config = include 'MECON/PDF/Tabla/medidas.php'; + $this->_encabezado = $encabezado; } /** @@ -95,13 +113,21 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { function _obtenerAlineacionTexto($row, $col, $texto, $attr, $estilo) { $at = $this->_tabla->getCellAttributes($row, $col); + + if (@$at['colspan']) { + $offset = $at['colspan']; + } + else { + $offset = 1; + } + if (@$at['align'] == 'center') { $tam = $this->_marco->strlen($texto, $estilo); - $init = $attr[$col] + ($attr[$col+1] - $attr[$col] - $tam) / 2; + $init = $attr[$col] + ($attr[$col+$offset] - $attr[$col] - $tam) / 2; } elseif (@$at['align'] == 'right') { $tam = $this->_marco->strlen($texto, $estilo); - $init = $attr[$col+1] - $tam + 1; + $init = $attr[$col+$offset] - $tam + 1; } else { $init = $attr[$col]; @@ -141,6 +167,9 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { else { $estilo = $this->_config['celda_comun']; } + if (@$clase['colspan']) { + $estilo['colspan'] = $clase['colspan']; + } return $estilo; } @@ -151,15 +180,23 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { * @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.'); + $ancho_pagina = $this->_marco->getWidth($this->_marco->refPage(), + $this->_marco->getOrientation()); + for ($row = 0; $row<$this->_tabla->getRowCount(); $row++) { + for ($i=0; $i<$this->_tabla->getColCount(); $i++ ) { + $tmp = $this->_tabla->getCellAttributes($row,$i); + if(@intval($tmp['width']) != 0) + $attr[$i] = intval($tmp['width']); + if(@count($attr) == $this->_tabla->getColCount()) + break 2; } - $attr[$i] = intval($tmp['width']); } + + if (!isset($attr)) + trigger_error ('Todas las columnas tienen que tener un ancho asignado', E_USER_ERROR); + $tmp = array_sum($attr); + $attr2[0] = 0; for ($i=1; $i_orientacion) ? $this->_orientacion : + $this->_marco->getOrientation(); + $this->_marco->newPage($this->_marco->tamanio, $tmp, $this->_encabezado); + } /** * Funcion que agrega las filas y columnas a la pagina. @@ -177,18 +225,35 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { */ function _agregarContenido() { $alto = $this->_marco->espacioDisponible; - if ($alto <= 0 ) { - $this->_marco->newPage($this->_marco->tamanio); + $orientacion = $this->_marco->getOrientation(); + if ($alto <= 0 || ($this->_orientacion && $this->_orientacion != + $orientacion) ) { + $this->_newPage(); + $orientacion = $this->_marco->getOrientation(); $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); + + //Actuo por el colspan + if (@$estilo['colspan']) { + if ($estilo['colspan'] > $this->_tabla->getColCount()) { + $estilo['colspan'] = + $this->_tabla->getColCount() - $j; + } + $ancho_columna = $attr2[$j+$estilo['colspan']] - + $attr2[$j]; + } + else { + $ancho_columna = $attr2[$j+1] - $attr2[$j]; + } + $txt = $this->_marco->wordWrap( + @$this->_tabla->getCellContents($i,$j), $ancho_columna, + $estilo); + $txtt[$j] = $txt; //Esto es para no hacer el wordWrap siempre $max = max($estilo['alto_linea'] * count($txt), $max); @@ -199,20 +264,34 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { $repetir[$i]['max'] = $max; } } - if ($alto <= 0) { - $this->_marco->newPage($this->_marco->tamanio); + $this->_newPage(); $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); + + //Actuo por el colspan + if (@$estilo['colspan']) { + if ($estilo['colspan'] > $this->_tabla->getColCount()) { + $estilo['colspan'] = + $this->_tabla->getColCount() - $jj; + } + $der = $attr2[$jj+$estilo['colspan']]; + $izq = $attr2[$jj]; + } + else { + $der = $attr2[$jj+1]; + $izq = $attr2[$jj]; + } + + $this->_marco->addRectangle($izq, $alto, $der, + $alto+$repetir[$ii]['max'], @$estilo['fill'], + null, $orientacion); $alto1 = $alto + $repetir[$ii]['max']; foreach ($repetir[$ii][$jj] as $t) { $alto1 -= $estilo['alto_linea']; @@ -222,8 +301,13 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { $estilo); $this->_marco->addText($init, $alto1 + 2, - $t, $estilo, null, $this->_marco->orientacion); + $t, $estilo, null, $orientacion); + } + + if (@$estilo['colspan']) { + $jj += $estilo['colspan'] -1; } + } } @@ -231,24 +315,43 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { $alto -= $max; for ($j = 0; $j < $this->_tabla->getColCount(); $j++) { - + $estilo = $this->_obtenerEstiloCelda($i, $j); + + //Actuo por el colspan + if (@$estilo['colspan']) { + if ($estilo['colspan'] > $this->_tabla->getColCount()) { + $estilo['colspan'] = $this->_tabla->getColCount() - 1; + } + $der = $attr2[$j+$estilo['colspan']]; + $izq = $attr2[$j]; + } + else { + $der = $attr2[$j+1]; + $izq = $attr2[$j]; + } + - $this->_marco->addRectangle($attr2[$j], $alto, - $attr2[$j+1], $alto+$max, @$estilo['fill'], null, - $this->_marco->orientacion); + $this->_marco->addRectangle($izq, $alto, $der, $alto+$max, + @$estilo['fill'], null, $orientacion); $alto1 = $alto + $max; - foreach ($txtt[$j] as $t) { - $alto1 -= $estilo['alto_linea']; + if (@$txtt[$j]) { + 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); + //Ubico el texto segun su alineacion + $init = $this->_obtenerAlineacionTexto($i, $j, $t, $attr2, + $estilo); + + $this->_marco->addText($init, $alto1 + 2, + $t, $estilo, null, $orientacion); + } } + if (@$estilo['colspan']) { + $j += $estilo['colspan']-1; + } + } } $this->_marco->espacioDisponible = $alto;