X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/f1e8dd28b05b78b0992493d8508bddaab2bd13d6..03be513c148fa5a12a313476ca407e8a5265e2e8:/lib/MECON/Marco/ImagenAnimada.php diff --git a/lib/MECON/Marco/ImagenAnimada.php b/lib/MECON/Marco/ImagenAnimada.php index fbdd28c..a2b01c9 100644 --- a/lib/MECON/Marco/ImagenAnimada.php +++ b/lib/MECON/Marco/ImagenAnimada.php @@ -24,12 +24,7 @@ // $Rev$ // -#require_once 'PEAR.php'; - - -// +X2C includes -require_once 'MECON/Marco/Imagen.php'; -// ~X2C +define('MECON_MARCO_IMAGENANIMADA_DIR_GENERAL', '/MECON/images'); // +X2C Class 17 :ImagenAnimada /** @@ -37,7 +32,15 @@ require_once 'MECON/Marco/Imagen.php'; * * @access public */ -class ImagenAnimada extends Imagen { +class ImagenAnimada { + /** + * Nombre del archivo imagen. + * + * @var string $imgComun + * @access private + */ + var $_imgComun; + /** * Nombre del archivo imagen. * @@ -54,6 +57,99 @@ class ImagenAnimada extends Imagen { */ 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 = ''; + + /** + * 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; + } + // ~X2C // +X2C Operation 70 @@ -68,39 +164,21 @@ class ImagenAnimada extends Imagen { * @return void * @access public */ - function ImagenAnimada($imagenComun, $imagenMouseOn = null, $imagenSelect = null, $directorio = null) // ~X2C + function ImagenAnimada($imagenComun, $imagenMouseOn = '', $imagenSelect = '', $directorio = '')// ~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'); } } } @@ -113,9 +191,51 @@ class ImagenAnimada extends Imagen { * @return string * @access public */ - function toHtml() // ~X2C + function toHtml()// ~X2C { - trigger_error('Not implemented!', E_USER_WARNING); + $img = new HTML_Image(array('name' => $this->getName(), 'border' => 0)); + $src = $this->getSeleccionada() ? $this->_imgSelect : $this->_imgComun; + $img->updateAttributes('src' => $src); + $html = $img->toHtml(); + if ($this->getHabilitada()) { + if ($this->getSeleccionada()) { + $prepend = ''; + } else { + $prepend = 'getName().'\',\'\',\''.$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