X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/f1e8dd28b05b78b0992493d8508bddaab2bd13d6..8a7c41689e3915b23a5e0a59a4e849289a287438:/lib/MECON/Marco/ImagenAnimada.php diff --git a/lib/MECON/Marco/ImagenAnimada.php b/lib/MECON/Marco/ImagenAnimada.php index fbdd28c..65aba3c 100644 --- a/lib/MECON/Marco/ImagenAnimada.php +++ b/lib/MECON/Marco/ImagenAnimada.php @@ -1,50 +1,56 @@ - -// +----------------------------------------------------------------------+ -// -// $Id$ -// $Author$ -// $URL$ -// $Date$ -// $Rev$ -// - -#require_once 'PEAR.php'; - - -// +X2C includes -require_once 'MECON/Marco/Imagen.php'; -// ~X2C - -// +X2C Class 17 :ImagenAnimada + +------------------------------------------------------------------------------- +$Id$ +-----------------------------------------------------------------------------*/ + +require_once 'HTML/Image.php'; + +define('MECON_MARCO_IMAGENANIMADA_DIR_GENERAL', '/MECON/images'); + +// +X2C Class 17 :MECON_Marco_ImagenAnimada /** * Clase para el manejo de la animacion de las imagenes. Utilizada principalmente en la barra de secciones * + * @package MECON_Marco * @access public */ -class ImagenAnimada extends Imagen { +class MECON_Marco_ImagenAnimada { + /** + * Nombre del archivo imagen. + * + * @var string $imgComun + * @access private + */ + var $_imgComun = ''; + /** * Nombre del archivo imagen. * * @var string $imgMouseOn * @access private */ - var $_imgMouseOn; + var $_imgMouseOn = ''; /** * Nombre del archivo imagen. @@ -52,7 +58,129 @@ class ImagenAnimada extends Imagen { * @var string $imgSelect * @access private */ - var $_imgSelect; + var $_imgSelect = ''; + + /** + * Indica si la imagen esta seleccionada. + * + * @var bool $seleccionada + * @access protected + */ + var $_seleccionada = false; + + /** + * Indica si est?habilitado el link. + * + * @var bool $habilitada + * @access protected + */ + var $_habilitada = true; + + /** + * Link a donde apunta la imagen. + * + * @var string $link + * @access protected + */ + var $_link = ''; + + /** + * @var string $nombre + * @access protected + */ + var $_nombre = ''; + + /** + * Gets Seleccionada. + * + * @return bool + * @access public + */ + function getSeleccionada() + { + return $this->_seleccionada; + } + /** + * Sets Seleccionada. + * + * @param bool $seleccionada Seleccionada. + * + * @return void + * @access public + */ + function setSeleccionada($seleccionada) + { + $this->_seleccionada = $seleccionada; + } + + /** + * Gets Habilitada. + * + * @return bool + * @access public + */ + function getHabilitada() + { + return $this->_habilitada; + } + /** + * Sets Habilitada. + * + * @param bool $habilitada Habilitada. + * + * @return void + * @access public + */ + function setHabilitada($habilitada) + { + $this->_habilitada = $habilitada; + } + + /** + * Gets Link. + * + * @return string + * @access public + */ + function getLink() + { + return $this->_link; + } + /** + * Sets Link. + * + * @param string $link Link. + * + * @return void + * @access public + */ + function setLink($link) + { + $this->_link = $link; + } + + /** + * Gets Nombre. + * + * @return string + * @access public + */ + function getNombre() + { + return $this->_nombre; + } + /** + * Sets Nombre. + * + * @param string $nombre Nombre. + * + * @return void + * @access public + */ + function setNombre($nombre) + { + $this->_nombre = $nombre; + } // ~X2C @@ -64,45 +192,31 @@ class ImagenAnimada extends Imagen { * @param string $imagenMouseOn Imagen alterna con el mouse por arriba * @param string $imagenSelect Imagen alterna cuando esta seleccionada la seccion * @param string $directorio Directorio en donde se encuentran las imagenes + * @param string $nombre Nombre de la imagen animada. + * @param string $link Link. * * @return void * @access public */ - function ImagenAnimada($imagenComun, $imagenMouseOn = null, $imagenSelect = null, $directorio = null) // ~X2C + function MECON_Marco_ImagenAnimada($imagenComun, $imagenMouseOn = '', $imagenSelect = '', $directorio = '', $nombre = '', $link = '') // ~X2C { - if (!is_null($imagenComun) && $imagenComun != '') { - parent::Imagen($imagenComun, $directorio); - - if (!is_null($imagenMouseOn) && $imagenMouseOn != ''){ - if (is_readable($_SERVER['DOCUMENT_ROOT'].$directorio.'/'.$imagenMouseOn.'.gif')) { - $this->_imgMouseOn = $directorio.'/'.$imagenMouseOn; - } - else { - $this->_imgMouseOn = '/www/images/'.$imagenMouseOn; - } - } - elseif (is_readable($_SERVER['DOCUMENT_ROOT'].$directorio.'/'.$imagenComun.'_f2.gif')) { - $this->_imgMouseOn = $directorio.'/'.$imagenComun.'_f2'; + if ($imagenComun !== '') { + $this->_imgComun = $this->_calcularImagen($imagenComun, $directorio); + if ($imagenMouseOn !== '') { + $this->_imgMouseOn = $this->_calcularImagen($imagenMouseOn, $directorio); } else { - $this->_imgMouseOn = '/www/images/'.$imagenComun.'_f2'; + $this->_imgMouseOn = $this->_calcularImagen($imagenComun, $directorio, '_f2'); } - - if (!is_null($imagenSelect) && $imagenSelect != ''){ - if (is_readable($_SERVER['DOCUMENT_ROOT'].$directorio.'/'.$imagenSelect.'.gif')) { - $this->_imgSelect = $directorio.'/'.$imagenSelect; - } - else { - $this->_imgSelect = '/www/images/'.$imagenSelect; - } - } - elseif (is_readable($_SERVER['DOCUMENT_ROOT'].$directorio.'/'.$imagenComun.'_f3.gif')) { - $this->_imgSelect = $directorio.'/'.$imagenComun.'_f3'; + if ($imagenSelect !== '') { + $this->_imgSelect = $this->_calcularImagen($imagenSelect, $directorio); } else { - $this->_imgSelect = '/www/images/'.$imagenComun.'_f3'; + $this->_imgSelect = $this->_calcularImagen($imagenComun, $directorio, '_f3'); } } + $this->_nombre = $nombre; + $this->_link = $link; } // -X2C @@ -115,10 +229,51 @@ class ImagenAnimada extends Imagen { */ function toHtml() // ~X2C { - trigger_error('Not implemented!', E_USER_WARNING); + $src = $this->getSeleccionada() ? $this->_imgSelect : $this->_imgComun; + $img = new HTML_Image($src, $this->_nombre, array('name' => $this->_nombre, 'border' => 0)); + $html = $img->toHtml(); + if ($this->getHabilitada()) { + if ($this->getSeleccionada()) { + $prepend = ''; + } else { + $prepend = '_nombre.'\',\'\',\''.$this->_imgMouseOn.'\',1)>'; + } + $html = $prepend . $html . ''; + } + return $html; + } + // -X2C + + // +X2C Operation 209 + /** + * @param string $imagen Nombre de la imagen. + * @param string $directorio Directorio. + * @param string $modificador Modificador que indica una variante de la imagen. + * + * @return string + * @access protected + */ + function _calcularImagen($imagen, $directorio, $modificador = '') // ~X2C + { + if ($modificador !== '') { + $pos = strrpos($imagen, '.'); + $ext = substr($imagen, $pos); + $nom = substr($imagen, 0, $pos); + $imagen = "$nom$modificador$ext"; + } + if (is_readable("{$_SERVER['DOCUMENT_ROOT']}$directorio/$imagen")) { + return "$directorio/$imagen"; + } + else { + return MECON_MARCO_IMAGENANIMADA_DIR_GENERAL . "/$imagen"; + } } // -X2C -} // -X2C Class :ImagenAnimada +} // -X2C Class :MECON_Marco_ImagenAnimada -?> +?> \ No newline at end of file