]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/PDF/Tabla.php
MECON_PDF_Imagen finalizado. Falta probarlo y hacer un codigo mas leible.
[mecon/meconlib.git] / lib / MECON / PDF / Tabla.php
index 3530180dd9eee214e276f0e29eb4142348e1948c..499c406bc3e0f8af596248045ca31889a83d124c 100644 (file)
@@ -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,14 +185,16 @@ 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(intval($tmp['width']) != 0)
+                if(@intval($tmp['width']) != 0)
                     $attr[$i] = intval($tmp['width']);
-                if(count($attr) == $this->_tabla->getColCount())
-                  break;
+                if(@count($attr) == $this->_tabla->getColCount())
+                  break 2;
             }
-            if(count($attr) == $this->_tabla->getColCount())
-               break;
         }
+        
+        if (!isset($attr))
+            trigger_error ('Todas las columnas tienen que tener un ancho asignado', E_USER_ERROR);
+        
         $tmp = array_sum($attr);
         
         $attr2[0] = 0;
@@ -204,7 +214,7 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido {
     function _newPage() {
         $tmp = ($this->_orientacion) ? $this->_orientacion :
             $this->_marco->getOrientation();
-        $this->_marco->newPage($this->_marco->tamanio, $tmp);               
+        $this->_marco->newPage($this->_marco->tamanio, $tmp, $this->_encabezado);               
     }
 
     /**
@@ -230,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];
@@ -240,9 +250,15 @@ 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);
+                if (@$this->_tabla->getCellContents($i,$j)) {
+                    $txt = $this->_marco->wordWrap(
+                            @$this->_tabla->getCellContents($i,$j), $ancho_columna, 
+                            $estilo
+                            );
+                }
+                else {
+                    $txt = array (' ');
+                }
                 
                 $txtt[$j] = $txt; //Esto es para no hacer el wordWrap siempre
                 $max = max($estilo['alto_linea'] * count($txt), $max);
@@ -266,9 +282,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];
@@ -282,7 +298,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'];
@@ -296,7 +311,7 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido {
                         }
 
                         if (@$estilo['colspan']) {
-                            $jj++;
+                            $jj += $estilo['colspan'] -1;
                         }
                         
                     }
@@ -308,11 +323,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];
@@ -340,7 +355,7 @@ class MECON_PDF_Tabla extends MECON_PDF_Contenido {
                     }
                 }
                 if (@$estilo['colspan']) {
-                    $j++;
+                    $j += $estilo['colspan']-1;
                 }
 
             }