X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/bf5e13802a852ae3d121bb9a88237e9f1da2c33f..da6c25deda9c9c9e20124b90be71eb3dca42fa2e:/lib/MECON/Marco/ImagenAnimada.php
diff --git a/lib/MECON/Marco/ImagenAnimada.php b/lib/MECON/Marco/ImagenAnimada.php
index a845712..792167e 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 'MECON/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,10 +58,139 @@ 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 = '';
+
+ /**
+ * Nombre de la imagen
+ *
+ * @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
+ /**
+ * Texto alternativo.
+ */
+ var $_alt = '';
+
// +X2C Operation 70
/**
* Constructor. Recibe como parametro el nombre del archivo que contiene la imagen.
@@ -64,45 +199,33 @@ 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.
+ * @param string $alt Texto alternativo para la imagen.
*
* @return void
* @access public
*/
- function ImagenAnimada($imagenComun, $imagenMouseOn = null, $imagenSelect = null, $directorio = null) // ~X2C
+ function MECON_Marco_ImagenAnimada($imagenComun, $imagenMouseOn = '', $imagenSelect = '', $directorio = '', $nombre = '', $link = '', $alt = '') // ~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 = '/MECON/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 = '/MECON/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 = '/MECON/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 = '/MECON/images/'.$imagenComun.'_f3';
+ $this->_imgSelect = $this->_calcularImagen($imagenComun, $directorio, '_f3');
}
}
+ $this->_nombre = $nombre;
+ $this->_link = $link;
+ $this->_alt = $alt ? $alt : $nombre;
}
// -X2C
@@ -115,10 +238,51 @@ class ImagenAnimada extends Imagen {
*/
function toHtml() // ~X2C
{
- trigger_error('Not implemented!', E_USER_WARNING);
+ $src = $this->getSeleccionada() ? $this->_imgSelect : $this->_imgComun;
+ $img = new MECON_HTML_Image($src, $this->_alt, 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