Javascript - Water Ripple Effect
I need the script on JS, which will change images/html in this 'water ripple' style (sorry, 6MB GIF file!): http://fcunited.ru/_temp/listening2.gif Any lib? I only found this: http
Solution 1:
If HTML5 is an option (replace the image with a canvas loading the image), you may be able to extract this effect from the demo and adjust the effect in size and position (source code included):
Solution 2:
This is a water ripple effect originally created by Jonas Wagner.
var floor = Math.floor;
functionloadImage(callback) {
var img = document.getElementById('bg');
callback(img);
}
functiongetDataFromImage(img) {
canvas.width = img.width;
canvas.height = img.height;
ctx.clearRect(0, 0, img.width, img.height);
ctx.drawImage(img, 0 ,0);
return ctx.getImageData(0, 0, img.width, img.height);
}
functiondisturb(x, y, z){
if(x < 2 || x > width-2 || y < 1 || y > height-2)
return;
var i = x+y*width;
buffer0[i] += z;
buffer0[i-1] -= z;
}
functionprocess(){
var img = ctx.getImageData(0, 0, width, height),
data = img.data,
i, x;
// average cells to make the surface more evenfor(i=width+1;i<size-width-1;i+=2){
for(x=1;x<width-1;x++,i++){
buffer0[i] = (buffer0[i]+buffer0[i+1]+buffer0[i-1]+buffer0[i-width]+buffer0[i+width])/5;
}
}
for(i=width+1;i<size-width-1;i+=2){
for(x=1;x<width-1;x++,i++){
// wave propagationvar waveHeight = (buffer0[i-1] + buffer0[i+1] + buffer0[i+width] + buffer0[i-width])/2-buffer1[i];
buffer1[i] = waveHeight;
// calculate index in the texture with some fake referactionvar ti = i+floor((buffer1[i-2]-waveHeight)*0.08)+floor((buffer1[i-width]-waveHeight)*0.08)*width;
// clamping
ti = ti < 0 ? 0 : ti > size ? size : ti;
// some very fake lighting and caustics based on the wave height// and anglevar light = waveHeight*2.0-buffer1[i-2]*0.6,
i4 = i*4,
ti4 = ti*4;
// clamping
light = light < -10 ? -10 : light > 100 ? 100 : light;
data[i4] = texture.data[ti4]+light;
data[i4+1] = texture.data[ti4+1]+light;
data[i4+2] = texture.data[ti4+2]+light;
}
}
aux = buffer0;
buffer0 = buffer1;
buffer1 = aux;
ctx.putImageData(img, 0, 0);
}
var canvas = document.getElementById('c'),
ctx = canvas.getContext('2d'),
width = 320,
height = 240,
size = width*height,
buffer0 = [],
buffer1 = [],
aux, i, texture;
for(i=0;i<size;i++){
buffer0.push(0);
buffer1.push(0);
}
loadImage(function(img){
texture = getDataFromImage(img);
canvas.width = width;
canvas.height = height;
ctx.fillRect(0, 0, width, height);
setInterval(process, 1000/60);
resizeBy(width-innerWidth, height-innerHeight);
});
canvas.onmousemove = function(e){
disturb(
floor(e.clientX/innerWidth*width),
floor(e.clientY/innerHeight*height),
15000);
}
<imgid="bg"src=""style="display:none;"><canvasid="c"style="position: absolute; top:0; left:0; width:100%;height:100%; "></canvas>
Solution 3:
.paperButton {
display: block;
text-align: center;
text-decoration: none;
position: relative;
overflow: hidden;
-webkit-transition: all 0.2s ease;
-moz-transition: all 0.2s ease;
-o-transition: all 0.2s ease;
transition: all 0.2s ease;
z-index: 0;
cursor:pointer;
}
.animate {
-webkit-animation: ripple 0.65s linear;
-moz-animation: ripple 0.65s linear;
-ms-animation: ripple 0.65s linear;
-o-animation: ripple 0.65s linear;
animation: ripple 0.65s linear;
}
@-webkit-keyframes
ripple { 100% {
opacity: 0;
-webkit-transform: scale(2.5);
}
}
@-moz-keyframes
ripple { 100% {
opacity: 0;
-moz-transform: scale(2.5);
}
}
@-o-keyframes
ripple { 100% {
opacity: 0;
-o-transform: scale(2.5);
}
}
@keyframes
ripple { 100% {
opacity: 0;
transform: scale(2.5);
}
}
$(function(){
var ink, i, j, k;
$(".paperButton").mousedown(function(e){
if($(this).find(".ink").length === 0){
$(this).prepend("<span class='ink'></span>");
}
ink = $(this).find(".ink");
ink.removeClass("animate");
if(!ink.height() && !ink.width()){
i = Math.max($(this).outerWidth(), $(this).outerHeight());
ink.css({height: i, width: i});
}
j = e.pageX - $(this).offset().left - ink.width()/2;
k = e.pageY - $(this).offset().top - ink.height()/2;
ink.css({top: k+'px', left: j+'px'}).addClass("animate");
});
});
Post a Comment for "Javascript - Water Ripple Effect"