繁体   English   中英

过渡背景图片

[英]Transition Background-Image

我是Web编程领域的新手,但是我正在尝试开发一个网页,该网页在页面加载时将从黑白版本的照片过渡到普通彩色版本的照片。

在尝试了许多不同的方法之后,我能做的最好的就是使彩色版本立即出现。 我也尝试使用JQuery,但是由于某种原因,我无法正确加载页面。 它停留在黑白版本上,而不是过渡到普通版本。

HTML如下:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<link rel="stylesheet" type="text/css" href="index.css">
<link href='http://fonts.googleapis.com/css?family=Bad+Script' rel='stylesheet' type='text/css'>
<title>UCLA Wushu - Home</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
        $("html").animate({'background' : 'url(images/home_background.jpg) no-repeat center center fixed'}, 'slow');
});
</script>

</head>
<body>
<div id="container">
<div id="middleBar">
<strong>
<a href="index.html">My Portal</a>
</strong>
<div id="enter"><a href="announcements.html">Enter</a></div>
</div>
</div>
</body>
</html>

相关的CSS如下(我复制并粘贴以将背景图像有效地拉伸到浏览器中):

@charset "UTF-8";
/* CSS Document */
html { 
  background: url(images/home_background_bw.jpg) no-repeat center center fixed; 
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

请让我知道是否有一种方法可以使用这种格式从黑白平滑过渡到彩色。 谢谢 :)

我认为最简单的解决方案,不使用任何饱和度插件等,是在body标签之后放置带有彩色图像和零不透明度的div,然后将该div的不透明度动画化为100%。

HTML的一部分:

...
<title>UCLA Wushu - Home</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
        $("#colored-bg").animate({
           opacity: 100
        }, 'slow');
});
</script>

</head>
<body>
<div id="colored-bg"></div>
<div id="container">
<div id="middleBar">
...

CSS:

#colored-bg { 
  background: url(images/home_background.jpg) no-repeat center center fixed; 
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  opacity: 0;
  filter: ~"alpha(opacity=@{0})"; // IE
  // following will strecth the element from corner to corner
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

如果我了解您的需求,可以尝试使用

-webkit-transition: background-color 2s linear;
-moz-transition: background-color 2s linear;
-ms-transition: background-color 2s linear;
-o-transition: background-color 2s linear;
transition: background-color 2s linear;

像这样: http : //jsfiddle.net/guillaumek/CcNHv/

看一下这个。 JSFIDDLE

它使用两个图像,一个是黑色,而另一个是彩色。 彩色图像隐藏在黑白图像的后面。

然后单击,淡出黑白图像以显示彩色图像。

看看这个。

HTML:

<div id="color">
    <div id="blackAndWhite"></div>
</div>

jQuery的:

$("#blackAndWhite").click(function(){
$(this).fadeOut(5000);
});

希望能帮助到你!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM