鼠标移动时图像之间的平滑混合/过渡
最近,我已经找到了一个网站,在Mousemove上,背景变化很好,它与鼠标位置有某种联系。请看一下在这里。
实际上,只有两个图像显示,它们之间有平稳的过渡。这就是为什么我试图用自己的小提琴实现同样的事情的原因。
我的html在这里:
<section id="test">
<div class="container">
<div class="row">
<div class="col-lg-12 text-center link-danger">
testing background
</div>
</div>
</div>
<div class="masked" id="maskedImages">
<picture>
<img src="https://images4.alphacoders.com/108/thumb-1920-1082562.jpg" alt="test" />
</picture>
<picture>
<img src="https://images3.alphacoders.com/108/thumb-1920-1082567.jpg" alt="test" />
</picture>
</div>
</section>
CSS:
section#test {
background:url('https://images5.alphacoders.com/117/thumb-1920-1178361.jpg') center center/cover no-repeat;
}
section#test .masked {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 0
}
section#test .masked img {
width: 100%;
height: 100%;
object-fit: cover;
position: absolute;
left: 0;
top: 0
}
section#test .masked picture:nth-child(2) img {
-webkit-mask-image: linear-gradient(-90deg, rgba(0, 0, 0, 0) 0, #000 50%);
mask-image: linear-gradient(-90deg, rgba(0, 0, 0, 0) 0, #000 50%);
-webkit-mask-position: 0 0;
mask-position: 0 0;
-webkit-mask-repeat: no-repeat;
mask-repeat: no-repeat;
-webkit-mask-size: 200% auto;
mask-size: 200% auto
}
和JS(从该网站上取):
var n = $("maskedImages");
if (n) {
var o = n.getElement('div[data-vid="time2"] video');
o && n.addEvent("mousemove", function(e) {
var t = -2 * e.client.x;
o.setStyle(("chrome" == Browser.name ? "-webkit-" : "") + "mask-position", t + "px 0")
});
var s = n.getElements("img")[1];
s && n.getParent().addEvent("mousemove", function(e) {
var t = -2 * e.client.x;
s.setStyle(("chrome" == Browser.name ? "-webkit-" : "") + "mask-position", t + "px 0")
})
}
您可以想象,我的解决方案无效。目前,我遇到了一个错误: uck offerate typeError:n.getElement不是一个函数 ,
而IMHO与定义我的html中不存在的var o连接(但是,当我检查了该网站的来源时,无论如何,来自变量的元素与我要复制的元素都没有连接)。如何实现这种效果?
我目前的JSFIDDLE在这里:
Recently I've approached a website where on mousemove the background is changing nicely, it is somehow connected with the mouse position. Please take a look here.
In fact there are only two images showing and there is a smooth transition between them. That is why I was trying to achieve the same with my own fiddle.
My html is here:
<section id="test">
<div class="container">
<div class="row">
<div class="col-lg-12 text-center link-danger">
testing background
</div>
</div>
</div>
<div class="masked" id="maskedImages">
<picture>
<img src="https://images4.alphacoders.com/108/thumb-1920-1082562.jpg" alt="test" />
</picture>
<picture>
<img src="https://images3.alphacoders.com/108/thumb-1920-1082567.jpg" alt="test" />
</picture>
</div>
</section>
CSS:
section#test {
background:url('https://images5.alphacoders.com/117/thumb-1920-1178361.jpg') center center/cover no-repeat;
}
section#test .masked {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 0
}
section#test .masked img {
width: 100%;
height: 100%;
object-fit: cover;
position: absolute;
left: 0;
top: 0
}
section#test .masked picture:nth-child(2) img {
-webkit-mask-image: linear-gradient(-90deg, rgba(0, 0, 0, 0) 0, #000 50%);
mask-image: linear-gradient(-90deg, rgba(0, 0, 0, 0) 0, #000 50%);
-webkit-mask-position: 0 0;
mask-position: 0 0;
-webkit-mask-repeat: no-repeat;
mask-repeat: no-repeat;
-webkit-mask-size: 200% auto;
mask-size: 200% auto
}
and JS (taken from that website):
var n = $("maskedImages");
if (n) {
var o = n.getElement('div[data-vid="time2"] video');
o && n.addEvent("mousemove", function(e) {
var t = -2 * e.client.x;
o.setStyle(("chrome" == Browser.name ? "-webkit-" : "") + "mask-position", t + "px 0")
});
var s = n.getElements("img")[1];
s && n.getParent().addEvent("mousemove", function(e) {
var t = -2 * e.client.x;
s.setStyle(("chrome" == Browser.name ? "-webkit-" : "") + "mask-position", t + "px 0")
})
}
As you can imagine, my solution does not work. At the moment I'm getting an error: Uncaught TypeError: n.getElement is not a function
And IMHO it's connected with defining the var o which is not present in my html (but when I've checked source of that website, the element from variable is not anyhow connected to that I'm trying to reproduce). How to achieve this effect?
my current jsfiddle is here:
https://jsfiddle.net/kcpuz238/2/
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
函数
getElement
来自名为mootools
的类似 jquery 的库。老实说,我以前从未听说过。我将代码转换为纯 js 并附在下面。工作演示
The function
getElement
is from a jquery like library namedmootools
. Honestly, I have never heard of it before. I transpiled the code to plain js and attached below.Working demo