Ver Mensaje Individual
  #1 (permalink)  
Antiguo 29/10/2010, 04:29
EgEmKun
 
Fecha de Ingreso: mayo-2009
Mensajes: 37
Antigüedad: 15 años
Puntos: 0
Script para mover <div>'s por el sitio... funciona, pero ...

Hola!, bueno, debo admitir una cosa, que desafortunadamente apenas se de javascript ):...

Pero quisiera aprenderlo en pos de mis futuros sitios, el detalle es que ahorita estoy en un apuro jeje..

estoy manejando un sitio de fotografia donde quiero que la gente pueda "jugar" por asi decirlo con las fotografias, osea, que puedan mover las fotos de un lado a otro de la pagina libremente...

encontre un script que hace justamente lo mismo:

<script type="text/javascript">
//Si el navegador del cliente es Mozilla la variable siguiente valdrá true
var moz = document.getElementById && !document.all;
//Flag que indica si estamos o no en proceso de arrastrar el ratón
var estoyArrastrando = false;
//Variable para almacenar un puntero al objeto que estamos moviendo
var dobj;

function arrastrarRaton(e){
if (estoyArrastrando) {
newLeft = moz ? e.clientX : event.clientX;
newTop = moz ? e.clientY : event.clientY;

dobj.style.left = newLeft - parseInt(dobj.style.width)/2;
dobj.style.top = newTop - parseInt(dobj.style.height)/2;

return false;
}
}


function soltarBoton(e) {
estoyArrastrando = false;
}


function presionarBoton(e) {
//Obtenemos el elemento sobre el que se ha presionado el botón del ratón
var fobj = moz ? e.target : event.srcElement;

// Buscamos el primer elemento en la que esté contenido aquel sobre el que se ha pulsado
// que pertenezca a la clase objMovible.
while (fobj.tagName.toLowerCase() != "html" && fobj.className != "objMovible") {
fobj = moz ? fobj.parentNode : fobj.parentElement;
}

// Si hemos obtenido un objeto movible...
if (fobj.className == "objMovible") {
// Activamos el flag para indicar que se empieza a arrastrar
estoyArrastrando = true;
// Guardamos un puntero al objeto que se está moviendo en la variable global
dobj = fobj;

// Devolvemos false para no realizar ninguna acción posterior
return false;
}
}

document.onmousedown = presionarBoton;
document.onmouseup = soltarBoton;
document.onmousemove = arrastrarRaton;

document.oncontextmenu=new Function("return false");
</script>


entonces cuando alguien hace clic sobre un <div> que tenga dicha "class" como por ejemplo:

<div class="objMovible" style="width:411px; height:321px; background-image:url(fotos/imagen5.png); background-repeat:no-repeat;"></div>

Pues si, pueden mover la imagen por toda la pantalla libremente.... Cual es el problema ...?

El problema es que tambien, me gustaria que dichos "divs" fueran enlaces a secciones del sitio... El problema es que ya he intentado colocar un enlace en los <divs> de la clasica forma... osea:

<a href=""><div class="objMovible" style="width:411px; height:321px; background-image:url(fotos/imagen5.png); background-repeat:no-repeat;"></div> </a>

y funciona, pero digamos... hago clic en un <div>, pero mantengo presionado el mouse, al momento de soltarlo, me dirige a un sitio... y eso no es lo que necesito :(...

Lo que necesito es que por ejemplo, si comienzan a arrastrar el <div> por la pantalla, pues que solo arrastren dicho objeto, pero que si solamente dan un clic en el <div> este los lleve a dicha seccion...

Hay una forma sencilla de hacer esto :S?

Espero puedan ayudarme... Muchas gracias de antemano