]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Marco/ImagenAnimada.php
Se corrige un bugcito.
[mecon/meconlib.git] / lib / MECON / Marco / ImagenAnimada.php
index 4c78a040996aaaebd09fb77659c2d85b8ec86720..86369c6d666921e90deac19209ef112eff66a1aa 100644 (file)
@@ -24,6 +24,8 @@
 // $Rev$
 //
 
+require_once 'HTML/Image.php';
+
 define('MECON_MARCO_IMAGENANIMADA_DIR_GENERAL', '/MECON/images');
 
 // +X2C Class 17 :ImagenAnimada
@@ -57,6 +59,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 +191,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);
@@ -79,15 +205,17 @@ class ImagenAnimada {
                 $this->_imgMouseOn = $this->_calcularImagen($imagenMouseOn, $directorio);
             }
             else {
-                $this->_imgMouseOn = $this->_calcularImagen($imagenMouseOn, $directorio, '_f2');
+                $this->_imgMouseOn = $this->_calcularImagen($imagenComun, $directorio, '_f2');
             }
             if ($imagenSelect !== '') {
                 $this->_imgSelect = $this->_calcularImagen($imagenSelect, $directorio);
             }
             else {
-                $this->_imgSelect = $this->_calcularImagen($imagenSelect, $directorio, '_f3');
+                $this->_imgSelect = $this->_calcularImagen($imagenComun, $directorio, '_f3');
             }
         }
+        $this->_nombre = $nombre;
+        $this->_link   = $link;
     }
     // -X2C
 
@@ -100,7 +228,22 @@ class ImagenAnimada {
      */
     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