Día 3: Efecto espejo con CSS3 y JS

Este efecto está hecho utilizando la librería jQuery para ahorrarme un par de minutos. El efecto que trato de recrear es el de un espejo, puedes probarlo haciendo clic en el siguiente botón.

El "mouse invertido" está realizado con un mouse falso agregado después de .everything, que es el contenedor que voltearemos. Esto para evitar que ese elemento también sea invertido en algún sentido y pueda ser libre en todo el canvas.

#mouse {
  position: absolute;
  width: 10px;
  height: 10px;
  width: 12px;
  height: 20px;
  background-repeat: no-repeat;
  background-image: url();
  display: none;
}

El data en background-image utilizado devuelve la siguiente imagen: .

El siguienté bloque de código se encarga de realizar el efecto de mouse en espejo.

$(document).mousemove(function (e) {
  $("#mouse").css({
    'top': e.pageY,
    'right': e.pageX
  })
});

Y por último, el siguiente bloque de código se encarga de darle la vuelta en el eje Y a .everything.

var elem = $(".everything");
$({deg: 0}).animate({deg: 180}, // Animará de 0 a 180 grados en 500 milisegundos a .everything
  {
    duration: 500,
    step: function (now) {
      elem.css({
        transform: "rotateY(" + now + "deg)"
      });
  }
});

Parece raro pero parece ser que a los elementos con position: fixed; no les gusta ser transformados porque pierden la propiedad de alguna manera.

Y listo, un efecto bastante inútil pero si le encuentras un uso deja un comentario. Y si no, también deja un comentario.


palabras / Compartir en: Facebook , Twitter o copiar enlace