X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/bf5e13802a852ae3d121bb9a88237e9f1da2c33f..03be513c148fa5a12a313476ca407e8a5265e2e8:/lib/MECON/Marco/ImagenAnimada.php
diff --git a/lib/MECON/Marco/ImagenAnimada.php b/lib/MECON/Marco/ImagenAnimada.php
index a845712..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 = '/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');
}
}
}
@@ -113,12 +191,54 @@ 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
} // -X2C Class :ImagenAnimada
-?>
\ No newline at end of file
+?>