X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/e8763947c5e4e45c3804097424f8c670b4160001..59ef1bb1bc43dce4e8add06eac8e56ea9a043661:/lib/MECON/PDF/Tabla.php diff --git a/lib/MECON/PDF/Tabla.php b/lib/MECON/PDF/Tabla.php index 94a278d..595019e 100644 --- a/lib/MECON/PDF/Tabla.php +++ b/lib/MECON/PDF/Tabla.php @@ -59,6 +59,13 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { */ var $_orientacion; + /** + * Indica si el encabezado debe ir en la nuevas paginas. + * @var bool $encabezado + * @access protected; + */ + var $_encabezado; + /** * Class Constructor * @@ -69,10 +76,11 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { * @return void * @access public */ - function MECON_PDF_Tabla($TABLA, $orientacion = null) { + 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; } /** @@ -177,15 +185,18 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { for ($row = 0; $row<$this->_tabla->getRowCount(); $row++) { for ($i=0; $i<$this->_tabla->getColCount(); $i++ ) { $tmp = $this->_tabla->getCellAttributes($row,$i); - if (is_null(@$tmp['width'])) { - $attr[$i] = 0; - } - else { + if(@intval($tmp['width']) != 0) $attr[$i] = intval($tmp['width']); - } + if(@count($attr) == $this->_tabla->getColCount()) + break 2; } } + + 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->_marco->newPage($this->_marco->tamanio, $tmp, $this->_encabezado); } /** @@ -221,9 +232,7 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { $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++) { @@ -231,9 +240,9 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { //Actuo por el colspan if (@$estilo['colspan']) { - if ($estilo['colspan'] >= $this->_tabla->getColCount()) { + if ($estilo['colspan'] > $this->_tabla->getColCount()) { $estilo['colspan'] = - $this->_tabla->getColCount() - $j - 1; + $this->_tabla->getColCount() - $j; } $ancho_columna = $attr2[$j+$estilo['colspan']] - $attr2[$j]; @@ -241,7 +250,6 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { else { $ancho_columna = $attr2[$j+1] - $attr2[$j]; } - $txt = $this->_marco->wordWrap( @$this->_tabla->getCellContents($i,$j), $ancho_columna, $estilo); @@ -256,7 +264,6 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { $repetir[$i]['max'] = $max; } } - if ($alto <= 0) { $this->_newPage(); @@ -269,9 +276,9 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { //Actuo por el colspan if (@$estilo['colspan']) { - if ($estilo['colspan'] >= $this->_tabla->getColCount()) { + if ($estilo['colspan'] > $this->_tabla->getColCount()) { $estilo['colspan'] = - $this->_tabla->getColCount() - $j - 1; + $this->_tabla->getColCount() - $jj; } $der = $attr2[$jj+$estilo['colspan']]; $izq = $attr2[$jj]; @@ -285,7 +292,6 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { $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']; @@ -299,7 +305,7 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { } if (@$estilo['colspan']) { - $jj++; + $jj += $estilo['colspan'] -1; } } @@ -311,11 +317,11 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { 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; + if ($estilo['colspan'] > $this->_tabla->getColCount()) { + $estilo['colspan'] = $this->_tabla->getColCount() - 1; } $der = $attr2[$j+$estilo['colspan']]; $izq = $attr2[$j]; @@ -343,7 +349,7 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido { } } if (@$estilo['colspan']) { - $j++; + $j += $estilo['colspan']-1; } }