Cambiar el puntero del ratón (Web)

Email this to someoneShare on FacebookShare on Google+Share on LinkedInTweet about this on Twitter

Modificar el puntero del ratón en una web, blog o perfil de una red social como hi5 o MySpace es una práctica aún habitual en muchos webmasters que buscan personalizar su espacio en la red ofreciendo a sus visitantes unas palabras, el nombre de la web o algún tipo de imagen curiosa o graciosa.

Este es un sencillo código Javascript llamado Image Trail Script con el que podremos personalizar nuestro puntero del ratón con hasta seis pequeñas imagenes de modo que una detrás de otra sigan el rastro del puntero cada vez que el visitante se desplace por la web. (ver imágen del lateral)

Su funcionamiento es tan sencillo como alojar las imagenes en tu hosting, cambiar los nombres en negrita (trail1.gif) y pegar el siguiente código completo después de la eqtiqueta <body> en tu web.

<script>

A=document.getElementById
B=document.all;
C=document.layers;
T1=new Array(“trail1.gif“,38,35,”trail2.gif“,30,31,”trail3.gif“,28,26,”trail4.gif“,22,21,”trail5.gif“,16,16,”trail6.gif“,10,10)

var offsetx=15 //x offset of trail from mouse pointer
var offsety=10 //y offset of trail from mouse pointer

nos=parseInt(T1.length/3)
rate=50
ie5fix1=0;
ie5fix2=0;
rightedge=B? document.body.clientWidth-T1[1] : window.innerWidth-T1[1]-20
bottomedge=B? document.body.scrollTop+document.body.clientHeight-T1[2] : window.pageYOffset+window.innerHeight-T1[2]

for (i=0;i<nos;i++){
createContainer(“CUR”+i,i*10,i*10,i*3+1,i*3+2,””,”<img src='”+T1[i*3]+”‘ width=”+T1[(i*3+1)]+” height=”+T1[(i*3+2)]+” border=0>”)
}

function createContainer(N,Xp,Yp,W,H,At,HT,Op,St){
with (document){
write((!A && !B) ? “<layer id='”+N+”‘ left=”+Xp+” top=”+Yp+” width=”+W+” height=”+H : “<div id='”+N+”‘”+” style=’position:absolute;left:”+Xp+”; top:”+Yp+”; width:”+W+”; height:”+H+”; “);
if(St){
if (C)
write(” style='”);
write(St+”;’ “)
}
else write((A || B)?”‘”:””);
write((At)? At+”>” : “>”);
write((HT) ? HT : “”);
if (!Op)
closeContainer(N)
}
}

function closeContainer(){
document.write((A || B)?”</div>”:”</layer>”)
}

function getXpos(N){
if (A)
return parseInt(document.getElementById(N).style.left)
else if (B)
return parseInt(B[N].style.left)
else
return C[N].left
}

function getYpos(N){
if (A)
return parseInt(document.getElementById(N).style.top)
else if (B)
return parseInt(B[N].style.top)
else
return C[N].top
}

function moveContainer(N,DX,DY){
c=(A)? document.getElementById(N).style : (B)? B[N].style : (C)? C[N] : “”;
if (!B){
rightedge=window.innerWidth-T1[1]-20
bottomedge=window.pageYOffset+window.innerHeight-T1[2]
}
c.left=Math.min(rightedge, DX+offsetx);
c.top=Math.min(bottomedge, DY+offsety);
}
function cycle(){
//if (IE5)
if (document.all&&window.print){
ie5fix1=document.body.scrollLeft;
ie5fix2=document.body.scrollTop;
}
for (i=0;i<(nos-1);i++){
moveContainer(“CUR”+i,getXpos(“CUR”+(i+1)),getYpos(“CUR”+(i+1)))
}
}

function newPos(e){
moveContainer(“CUR”+(nos-1),(B)?event.clientX+ie5fix1:e.pageX+2,(B)?event.clientY+ie5fix2:e.pageY+2)
}

function getedgesIE(){
rightedge=document.body.clientWidth-T1[1]
bottomedge=document.body.scrollHeight-T1[2]
}

if (B){
window.onload=getedgesIE
window.onresize=getedgesIE
}

if(document.layers)
document.captureEvents(Event.MOUSEMOVE)
document.onmousemove=newPos
setInterval(“cycle()”,rate)
</script>

Nota: el código javascript para modificar el puntero del ratón es soportado por la mayoría de navegadores (FF1+ IE5+ Opr7+)

Un comentario

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

De conformidad con lo establecido en la LOPD, Adpv Advertising Provider S.L. garantiza la adopción de las medidas necesarias para asegurar el tratamiento confidencial de los datos de carácter personal. Así mismo le informamos de la inclusión de sus datos en un fichero con la finalidad de mantener su relación negocial o contractual con Adpv Advertising Provider S.L. y de la posibilidad de ejercer los derechos de acceso, rectificación, cancelación y oposición en la siguiente dirección: Ercilla, 26, 1Dcha., 48011, Bilbao, Bizkaia. Privacidad.