Si todavía te interesa una solución javascript con una única imagen, quizá te sirva esto (está al revés, primero en color y luego en escala de grises, pero es fácilmente adaptable):
Código PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Documento sin título</title>
<script>
function toGrayScale(im){
im.style.cursor='pointer';
if(document.createElement("canvas").getContext){
if(im.gs){
im.src=im.gs;
return;
}
var ref = document.createElement("canvas");
ref.width = im.width || im.offsetWidth;
ref.height =im.height || im.offsetHeight;
var context = ref.getContext("2d");
context.drawImage(im,0,0);
var iData=context.getImageData(0,0, ref.width, ref.height);
var data = iData.data;
var length = data.length;
for (var i = 0;i<length;i+=4) {
var average = (data[i]+data[i+1]+data[i+2])/3;
data[i] = average;
data[i+1] = average;
data[i+2] = average;
}
context.putImageData(iData, 0, 0);
im.src=im.gs=ref.toDataURL();
}else{
im.style.filter = 'progid:DXImageTransform.Microsoft.BasicImage(grayscale=1)';
}
}
</script>
</head>
<body>
<img onmouseout="this.src='tigre2.jpg';this.style.filter=''" onmouseover="toGrayScale(this)" src="tigre2.jpg" width="550" height="413" />
</body>
</html>
Aquí un ejemplo:
http://www.disegnocentell.com.ar/eje...S/rollgray.php