]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Marco/ImagenAnimada.php
Todavia a medio arreglar, sorry
[mecon/meconlib.git] / lib / MECON / Marco / ImagenAnimada.php
index 79e056cc4a86922bf42e56a9b3c913653fc4a023..bb3f3bbb97878a8992415fe00812f458ffadce48 100644 (file)
 // $Rev$
 //
 
+require_once 'HTML/Image.php';
+
 define('MECON_MARCO_IMAGENANIMADA_DIR_GENERAL', '/MECON/images');
 
 // +X2C Class 17 :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 {
@@ -57,6 +60,128 @@ class ImagenAnimada {
      */
     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
 
     // +X2C Operation 70
@@ -67,11 +192,13 @@ class ImagenAnimada {
      * @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 = '', $imagenSelect = '', $directorio = '')// ~X2C
+    function ImagenAnimada($imagenComun, $imagenMouseOn = '', $imagenSelect = '', $directorio = '', $nombre = '', $link = '') // ~X2C
     {
         if ($imagenComun !== '') {
             $this->_imgComun = $this->_calcularImagen($imagenComun, $directorio);
@@ -88,6 +215,8 @@ class ImagenAnimada {
                 $this->_imgSelect = $this->_calcularImagen($imagenComun, $directorio, '_f3');
             }
         }
+        $this->_nombre = $nombre;
+        $this->_link   = $link;
     }
     // -X2C
 
@@ -98,9 +227,24 @@ class ImagenAnimada {
      * @return string
      * @access public
      */
-    function toHtml()// ~X2C
+    function toHtml() // ~X2C
     {
-        trigger_error('Poner javascript, crear imagen y detectar si esta seleccionada o no (o pasarlo por el constructor)', 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 = '<a href="'.$this->getLink().'">';
+            } else {
+                $prepend = '<a href="'.$this->getLink().'" onMouseOut="MM_swapImgRestore()"
+                    onMouseOver="MM_displayStatusMsg(\''.$this->_nombre.'\');
+                    MM_swapImage(\''.$this->_nombre.'\',\'\',\''.$this->_imgMouseOn.'\',1);
+                    return document.MM_returnValue"
+                    MM_swapImage(\''.$this->_nombre.'\',\'\',\''.$this->_imgMouseOn.'\',1)>';
+            }
+            $html = $prepend . $html . '</a>';
+        }
+        return $html;
     }
     // -X2C
 
@@ -113,7 +257,7 @@ class ImagenAnimada {
      * @return string
      * @access protected
      */
-    function _calcularImagen($imagen, $directorio, $modificador = '')// ~X2C
+    function _calcularImagen($imagen, $directorio, $modificador = '') // ~X2C
     {
         if ($modificador !== '') {
             $pos = strrpos($imagen, '.');
@@ -132,4 +276,4 @@ class ImagenAnimada {
 
 } // -X2C Class :ImagenAnimada
 
-?>
+?>
\ No newline at end of file