1 <?php /* vim: set binary expandtab tabstop=4 shiftwidth=4 textwidth=80:
2 -------------------------------------------------------------------------------
5 -------------------------------------------------------------------------------
6 This file is part of meconlib.
8 meconlib is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2 of the License, or (at your option)
13 meconlib is distributed in the hope that it will be useful, but WITHOUT
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License; if not,
18 write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
19 Boston, MA 02111-1307 USA
20 -------------------------------------------------------------------------------
21 Creado: Fri Oct 24 16:34:11 2003
22 Autor: Martin Marrese <mmarre@mecon.gov.ar>
23 -------------------------------------------------------------------------------
25 -----------------------------------------------------------------------------*/
27 require_once 'MECON/PDF/Contenido.php';
30 * Libreria que permite agregar una tabla a un pdf.
32 class MECON_PDF_Tabla extends MECON_PDF_Contenido {
42 * Objeto MECON_HTML_Tabla.
43 * @var &Object $tabla MECON_HTML_Tabla
49 * Objeto MECON_PDF_Marco
56 * Orientacion de las nuevas paginas
57 * @var string $orientacion
65 * @param &Object $TABLA MECON_HTML_Tabla
66 * @param string $orientacion Orientacion que deben tener las nuevas paginas
67 * que genere la tabla.
72 function MECON_PDF_Tabla($TABLA, $orientacion = null) {
73 $this->_tabla = $TABLA;
74 $this->_orientacion = $orientacion;
75 $this->_config = include 'MECON/PDF/Tabla/medidas.php';
79 * Funcion que agrega el contenido de la tabla que se este utilizando al
82 * @param &Object $MARCO MECON_PDF_Marco
87 function toPDF(&$MARCO) {
88 $this->_marco =& $MARCO;
89 $this->_agregarContenido();
93 * Funcion que devuelve la posicion X en donde se debe escribir un texto
94 * segun su ubicacion en la celda
96 * @param int $row Indicador de la fila
97 * @param int $col Indicador de la columna
98 * @param string $texto Texto a escribir
99 * @param array $attr Atributos internos de la celda
100 * @param array $estilo Estilo del texto
105 function _obtenerAlineacionTexto($row, $col, $texto, $attr, $estilo) {
107 $at = $this->_tabla->getCellAttributes($row, $col);
109 if (@$at['colspan']) {
110 $offset = $at['colspan'];
116 if (@$at['align'] == 'center') {
117 $tam = $this->_marco->strlen($texto, $estilo);
118 $init = $attr[$col] + ($attr[$col+$offset] - $attr[$col] - $tam) / 2;
120 elseif (@$at['align'] == 'right') {
121 $tam = $this->_marco->strlen($texto, $estilo);
122 $init = $attr[$col+$offset] - $tam + 1;
131 * Funcion que devuelve el estilo de la celda segun la configuracion.
133 * @param int $row Indicador de la fila
134 * @param int $col Indicador de la columna
139 function _obtenerEstiloCelda($row, $col) {
140 $clase = $this->_tabla->getCellAttributes($row, $col);
141 if (@$clase['cabecera']) {
142 $estilo = $this->_config['celda_cabecera'];
144 elseif (@$clase['titulo']) {
145 $estilo = $this->_config['celda_titulo'];
147 elseif (@$clase['oscura']) {
148 $tmp = $this->_config['celda_comun'];
149 $tmp['fillcolor'] = $this->_config['celda_cabecera']['fillcolor'];
150 $tmp['fill'] = $this->_config['celda_cabecera']['fill'];
153 elseif (@$clase['clara']) {
154 $tmp = $this->_config['celda_comun'];
155 $tmp['fillcolor'] = $this->_config['celda_titulo']['fillcolor'];
156 $tmp['fill'] = $this->_config['celda_titulo']['fill'];
160 $estilo = $this->_config['celda_comun'];
162 if (@$clase['colspan']) {
163 $estilo['colspan'] = $clase['colspan'];
169 * Funcion que calcula el ancho de las columnas de la tabla.
174 function _obtenerAnchoColumnas() {
175 $ancho_pagina = $this->_marco->getWidth($this->_marco->refPage(),
176 $this->_marco->getOrientation());
177 for ($row = 0; $row<$this->_tabla->getRowCount(); $row++) {
178 for ($i=0; $i<$this->_tabla->getColCount(); $i++ ) {
179 $tmp = $this->_tabla->getCellAttributes($row,$i);
180 if(@intval($tmp['width']) != 0)
181 $attr[$i] = intval($tmp['width']);
182 if(@count($attr) == $this->_tabla->getColCount())
188 die ('Todas las columnas tienen que tener un ancho asignado');
190 $tmp = array_sum($attr);
193 for ($i=1; $i<count($attr); $i++) {
194 $attr2[$i] = intval(($ancho_pagina * $attr[$i-1] / $tmp) +
197 $attr2[$i] = $ancho_pagina;
201 * Funcion que se encarga de crear las nuevas paginas.
206 function _newPage() {
207 $tmp = ($this->_orientacion) ? $this->_orientacion :
208 $this->_marco->getOrientation();
209 $this->_marco->newPage($this->_marco->tamanio, $tmp);
213 * Funcion que agrega las filas y columnas a la pagina.
218 function _agregarContenido() {
219 $alto = $this->_marco->espacioDisponible;
220 $orientacion = $this->_marco->getOrientation();
221 if ($alto <= 0 || ($this->_orientacion && $this->_orientacion !=
224 $orientacion = $this->_marco->getOrientation();
225 $alto = $this->_marco->espacioDisponible;
227 $attr2 = $this->_obtenerAnchoColumnas();
228 for ($i = 0; $i < $this->_tabla->getRowCount(); $i++) {
230 for ($j = 0; $j < $this->_tabla->getColCount(); $j++) {
231 $estilo = $this->_obtenerEstiloCelda($i, $j);
233 //Actuo por el colspan
234 if (@$estilo['colspan']) {
235 if ($estilo['colspan'] > $this->_tabla->getColCount()) {
237 $this->_tabla->getColCount() - $j;
239 $ancho_columna = $attr2[$j+$estilo['colspan']] -
243 $ancho_columna = $attr2[$j+1] - $attr2[$j];
245 $txt = $this->_marco->wordWrap(
246 @$this->_tabla->getCellContents($i,$j), $ancho_columna,
249 $txtt[$j] = $txt; //Esto es para no hacer el wordWrap siempre
250 $max = max($estilo['alto_linea'] * count($txt), $max);
253 $rep = $this->_tabla->getCellAttributes($i, $j);
254 if (@$rep['cabecera'] || @$rep['titulo']) {
255 $repetir[$i][$j] = $txt;
256 $repetir[$i]['max'] = $max;
262 $alto = $this->_marco->espacioDisponible;
264 foreach ($repetir as $ii => $value) {
265 $alto -= $repetir[$ii]['max'];
266 for ($jj = 0; $jj < $this->_tabla->getColCount(); $jj++) {
267 $estilo = $this->_obtenerEstiloCelda($ii, $jj);
269 //Actuo por el colspan
270 if (@$estilo['colspan']) {
271 if ($estilo['colspan'] > $this->_tabla->getColCount()) {
273 $this->_tabla->getColCount() - $jj;
275 $der = $attr2[$jj+$estilo['colspan']];
279 $der = $attr2[$jj+1];
284 $this->_marco->addRectangle($izq, $alto, $der,
285 $alto+$repetir[$ii]['max'], @$estilo['fill'],
287 $alto1 = $alto + $repetir[$ii]['max'];
288 foreach ($repetir[$ii][$jj] as $t) {
289 $alto1 -= $estilo['alto_linea'];
291 //Ubico el texto segun su alineacion
292 $init = $this->_obtenerAlineacionTexto($ii, $jj, $t, $attr2,
295 $this->_marco->addText($init, $alto1 + 2,
296 $t, $estilo, null, $orientacion);
299 if (@$estilo['colspan']) {
300 $jj += $estilo['colspan'] -1;
309 for ($j = 0; $j < $this->_tabla->getColCount(); $j++) {
311 $estilo = $this->_obtenerEstiloCelda($i, $j);
313 //Actuo por el colspan
314 if (@$estilo['colspan']) {
315 if ($estilo['colspan'] > $this->_tabla->getColCount()) {
316 $estilo['colspan'] = $this->_tabla->getColCount() - 1;
318 $der = $attr2[$j+$estilo['colspan']];
327 $this->_marco->addRectangle($izq, $alto, $der, $alto+$max,
328 @$estilo['fill'], null, $orientacion);
330 $alto1 = $alto + $max;
332 foreach ($txtt[$j] as $t) {
333 $alto1 -= $estilo['alto_linea'];
335 //Ubico el texto segun su alineacion
336 $init = $this->_obtenerAlineacionTexto($i, $j, $t, $attr2,
339 $this->_marco->addText($init, $alto1 + 2,
340 $t, $estilo, null, $orientacion);
343 if (@$estilo['colspan']) {
344 $j += $estilo['colspan']-1;
349 $this->_marco->espacioDisponible = $alto;