当前位置:首页 > 技术博客 > JavaScript > Bilibili头部景深对焦效果

Bilibili头部景深对焦效果

4年前 (2021-07-20)JavaScript934

交互式鼠标悬停头图景深对焦效果

60f6949b0001dcde19150287.png


<head>      
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">    
		<title>B站头图景深对焦效果</title>    
<style>    
    body {    
    margin: 0;    
    }    
    header {    
    height: 160px;    
    position: relative;    
    overflow: hidden;    
    }    
    header > div {    
    position: absolute;    
    top: 0;    
    left: 0;    
    width: 100%;    
    height: 100%;    
    display: flex;    
    justify-content: center;    
    align-items: center;    
    --offset: 0px;    
    --blur: 2px;    
    }    
    header > div > img {    
    display: block;    
    width: 110%;    
    height: 100%;    
    object-fit: cover;    
    transform: translatex(var(--offset));    
    filter: blur(var(--blur));    
    }    
</style>    
</head>    
<body>    
<header>    
    <div><img src="https://pic3.58cdn.com.cn/nowater/webim/big/n_v2aa4e07773e834330a4879a85aaf52d20.png"></div>    
    <div><img src="https://pic1.58cdn.com.cn/nowater/webim/big/n_v21e2504548c9d46ad86eb8e1fb1343184.png"></div>    
    <div><img src="https://pic1.58cdn.com.cn/nowater/webim/big/n_v292447ee06af84d38a004ffcc74a26218.png"></div>    
    <div><img src="https://pic8.58cdn.com.cn/nowater/webim/big/n_v2c6b65cf6c5a54a8ca776a34045e2b349.png"></div>    
    <div><img src="https://pic2.58cdn.com.cn/nowater/webim/big/n_v2ea1dda358ed543df8628fcbf686f5230.png"></div>    
    <div><img src="https://pic1.58cdn.com.cn/nowater/webim/big/n_v23b40c7a5df42486084baa03b53e366be.png"></div>    
</header>        
	<h3 style="text-align: center">请在图片上左右移动鼠标查看效果</h3>    
<script>    
    const images = document.querySelectorAll('header > div > img')    
    document.querySelector('header').addEventListener('mousemove', (e) => {    
    let percentage = e.clientX / window.outerWidth    
    let offset = 10 * percentage    
    let blur = 20    
    for (let [index, image] of images.entries()) {    
    offset *= 1.3    
    let blurValue = (Math.pow((index / images.length - percentage), 2) * blur)    
    image.style.setProperty('--offset', `${offset}px`)    
    image.style.setProperty('--blur', `${blurValue}px`)    
    }    
    })    
</script>    
</body>


电脑端的朋友可以直接点击上面的【运行代码】按钮查看效果

版权声明:本文由 LzxBlog 发布,如需转载请注明出处。

本文链接:https://www.liuzhixi.cn/html/131.html

标签: JavaScriptHTML

相关文章

通俗的理解js中的&&和||

通俗的理解js中的&&和||

js中的&&和||本质是什么呢?进行布尔值的且和或的运算。当运算到某一个变量就得出最终结果之后,就返回哪个变量。在javascript中:以下内...

JavaScript 中定义数组和操作数组

JavaScript 中定义数组和操作数组

一.认识数组数组就是某类数据的集合,数据类型可以是整型、字符串、甚至是对象Javascript不支持多维数组,但是因为数组里面可以包含对象(数组也是一个对象),...

百度地图JavaScript简单标点连线

百度地图JavaScript简单标点连线

背景最近在研究轨迹数据的挖掘,第一步就是把轨迹数据在地图上可视化出来,然后再进行后续的算法研究。从一开始懵懂知道百度地图有免费的 API 可以调用,到后面知道还...

原生js自定义雷达图

原生js自定义雷达图

完整代码:<head>     <style> body{   &nb...

整理:JavaScript字符串的截取以及数组的截取

整理:JavaScript字符串的截取以及数组的截取

在编写前端时,截取字符串或者是截取数组的部分元素都是频繁出现的场景,所以在这整理一下:一、截取字符串JS提供三个截取字符串的方法,分别是:slice(),sub...

关于bootstrap.min.js.map报错404的问题

关于bootstrap.min.js.map报错404的问题

相信很多用过BootStrap框架的伙伴都遇到过bootstrap.min.js.map 404的错误,明明自己并没有去调用这个文件为什么会报这个错误呢?小沫就...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。