位置: IT常识 - 正文

分享一个CSS的垂帘效果(css垂直导航栏)

编辑:rootadmin
分享一个CSS的垂帘效果

推荐整理分享分享一个CSS的垂帘效果(css垂直导航栏),希望有所帮助,仅作参考,欢迎阅读内容。

分享一个CSS的垂帘效果(css垂直导航栏)

文章相关热门搜索词:css实现垂直居中的方法,css垂直定位,css垂直导航栏,css div垂直居中的几种方法,css设置垂直位移一半,css垂直定位,css垂直对齐方式怎么设置,css 垂直,内容如对您有帮助,希望把文章链接给更多的朋友!

先上效果图: 再上代码:

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <style> html, body, canvas { -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } html, body { width: 100%; height: 100%; overflow: hidden; margin: 0; display: flex; align-items: center; justify-content: center; background: #191919; } .asset-img { display: none; } </style></head><body><canvas></canvas><img class="asset-img" id="light-img" src="" alt="base64"></body><script> class Mouse { constructor(canvas) { this.pos = new Vector(-1000, -1000) this.radius = 40 canvas.onmousemove = e => this.pos.setXY(e.clientX, e.clientY) canvas.ontouchmove = e => this.pos.setXY(e.touches[0].clientX, e.touches[0].clientY) canvas.ontouchcancel = () => this.pos.setXY(-1000, -1000) canvas.ontouchend = () => this.pos.setXY(-1000, -1000) } } class Dot { constructor(x, y) { this.pos = new Vector(x, y) this.oldPos = new Vector(x, y) this.friction = 0.97 this.gravity = new Vector(0, 0.6) this.mass = 1 this.pinned = false this.lightImg = document.querySelector('#light-img') this.lightSize = 15 } update(mouse) { if (this.pinned) return let vel = Vector.sub(this.pos, this.oldPos) this.oldPos.setXY(this.pos.x, this.pos.y) vel.mult(this.friction) vel.add(this.gravity) let { x: dx, y: dy } = Vector.sub(mouse.pos, this.pos) const dist = Math.sqrt(dx * dx + dy * dy) const direction = new Vector(dx / dist, dy / dist) const force = Math.max((mouse.radius - dist) / mouse.radius, 0) if (force > 0.6) this.pos.setXY(mouse.pos.x, mouse.pos.y) else { this.pos.add(vel) this.pos.add(direction.mult(force)) } } drawLight(ctx) { ctx.drawImage( this.lightImg, this.pos.x - this.lightSize / 2, this.pos.y - this.lightSize / 2, this.lightSize, this.lightSize ) } draw(ctx) { ctx.fillStyle = '#aaa' ctx.fillRect(this.pos.x - this.mass, this.pos.y - this.mass, this.mass * 2, this.mass * 2) } } class Stick { constructor(p1, p2) { this.startPoint = p1 this.endPoint = p2 this.length = this.startPoint.pos.dist(this.endPoint.pos) this.tension = 0.3 } update() { const dx = this.endPoint.pos.x - this.startPoint.pos.x const dy = this.endPoint.pos.y - this.startPoint.pos.y const dist = Math.sqrt(dx * dx + dy * dy) const diff = (dist - this.length) / dist const offsetX = diff * dx * this.tension const offsetY = diff * dy * this.tension const m = this.startPoint.mass + this.endPoint.mass const m1 = this.endPoint.mass / m const m2 = this.startPoint.mass / m if (!this.startPoint.pinned) { this.startPoint.pos.x += offsetX * m1 this.startPoint.pos.y += offsetY * m1 } if (!this.endPoint.pinned) { this.endPoint.pos.x -= offsetX * m2 this.endPoint.pos.y -= offsetY * m2 } } draw(ctx) { ctx.beginPath() ctx.strokeStyle = '#999' ctx.moveTo(this.startPoint.pos.x, this.startPoint.pos.y) ctx.lineTo(this.endPoint.pos.x, this.endPoint.pos.y) ctx.stroke() ctx.closePath() } } class Rope { constructor(config) { this.x = config.x this.y = config.y this.segments = config.segments || 10 this.gap = config.gap || 15 this.color = config.color || 'gray' this.dots = [] this.sticks = [] this.iterations = 10 this.create() } pin(index) { this.dots[index].pinned = true } create() { for (let i = 0; i < this.segments; i++) { this.dots.push(new Dot(this.x, this.y + i * this.gap)) } for (let i = 0; i < this.segments - 1; i++) { this.sticks.push(new Stick(this.dots[i], this.dots[i + 1])) } } update(mouse) { this.dots.forEach(dot => { dot.update(mouse) }) for (let i = 0; i < this.iterations; i++) { this.sticks.forEach(stick => { stick.update() }) } } draw(ctx) { this.dots.forEach(dot => { dot.draw(ctx) }) this.sticks.forEach(stick => { stick.draw(ctx) }) this.dots[this.dots.length - 1].drawLight(ctx) } } class App { static width = innerWidth static height = innerHeight static dpr = devicePixelRatio > 1 ? 2 : 1 static interval = 1000 / 60 constructor() { this.canvas = document.querySelector('canvas') this.ctx = this.canvas.getContext('2d') this.mouse = new Mouse(this.canvas) this.resize() window.addEventListener('resize', this.resize.bind(this)) this.createRopes() } createRopes() { this.ropes = [] const TOTAL = App.width * 0.06 for (let i = 0; i < TOTAL + 1; i++) { const x = randomNumBetween(App.width * 0.3, App.width * 0.7) const y = 0 const gap = randomNumBetween(App.height * 0.05, App.height * 0.08) const segments = 10 const rope = new Rope({ x, y, gap, segments }) rope.pin(0) this.ropes.push(rope) } } resize() { App.width = innerWidth App.height = innerHeight this.canvas.style.width = '100%' this.canvas.style.height = '100%' this.canvas.width = App.width * App.dpr this.canvas.height = App.height * App.dpr this.ctx.scale(App.dpr, App.dpr) this.createRopes() } render() { let now, delta let then = Date.now() const frame = () => { requestAnimationFrame(frame) now = Date.now() delta = now - then if (delta < App.interval) return then = now - (delta % App.interval) this.ctx.clearRect(0, 0, App.width, App.height) // draw here this.ropes.forEach(rope => { rope.update(this.mouse) rope.draw(this.ctx) }) } requestAnimationFrame(frame) } } function randomNumBetween(min, max) { return Math.random() * (max - min) + min } window.addEventListener('load', () => { const app = new App() app.render() }) class Vector { constructor(x, y) { this.x = x || 0 this.y = y || 0 } static add(v1, v2) { return new Vector(v1.x + v2.x, v1.y + v2.y) } static sub(v1, v2) { return new Vector(v1.x - v2.x, v1.y - v2.y) } add(x, y) { if (arguments.length === 1) { this.x += x.x this.y += x.y } else if (arguments.length === 2) { this.x += x this.y += y } return this } sub(x, y) { if (arguments.length === 1) { this.x -= x.x this.y -= x.y } else if (arguments.length === 2) { this.x -= x this.y -= y } return this } mult(v) { if (typeof v === 'number') { this.x *= v this.y *= v } else { this.x *= v.x this.y *= v.y } return this } setXY(x, y) { this.x = x this.y = y return this } dist(v) { const dx = this.x - v.x const dy = this.y - v.y return Math.sqrt(dx * dx + dy * dy) } }</script></html>

代码直接粘贴到html页面就能使用,顺滑的不可言说

本文链接地址:https://www.jiuchutong.com/zhishi/296029.html 转载请保留说明!

上一篇:情感计算——多模态情感识别(情感计算的应用)

下一篇:element - - - - - 你不知道的loading使用方式

  • 小爱音响怎么连接手机蓝牙放歌(小爱音响怎么连接电视)

    小爱音响怎么连接手机蓝牙放歌(小爱音响怎么连接电视)

  • 复制粘贴过来是空白的(为啥复制粘贴后还是原来的东西)

    复制粘贴过来是空白的(为啥复制粘贴后还是原来的东西)

  • 笔记本灰屏(笔记本灰屏但是还运作,电源键亮着)

    笔记本灰屏(笔记本灰屏但是还运作,电源键亮着)

  • 淘宝怎么查旺旺号(淘宝如何查看旺旺)

    淘宝怎么查旺旺号(淘宝如何查看旺旺)

  • 微信拉黑后查找对方位置(微信拉黑查找聊天记录)

    微信拉黑后查找对方位置(微信拉黑查找聊天记录)

  • tp-linkac1200是不是千兆(tp-linkac1200参数)

    tp-linkac1200是不是千兆(tp-linkac1200参数)

  • 微信运动怎么看到全部的人(微信运动怎么看好友步数)

    微信运动怎么看到全部的人(微信运动怎么看好友步数)

  • 蚂蚁森林的弹幕别人可以看见吗(蚂蚁森林的弹幕多久有效)

    蚂蚁森林的弹幕别人可以看见吗(蚂蚁森林的弹幕多久有效)

  • 荣耀9x像素多少万(荣耀magic5pro像素)

    荣耀9x像素多少万(荣耀magic5pro像素)

  • 抖音取消赞有什么影响吗(抖音取消赞会影响流量吗)

    抖音取消赞有什么影响吗(抖音取消赞会影响流量吗)

  • 对称三相电源是指什么(对称三相电源是星形还是三角形)

    对称三相电源是指什么(对称三相电源是星形还是三角形)

  • 华为智慧视觉什么东西(华为智慧视觉点了没反应)

    华为智慧视觉什么东西(华为智慧视觉点了没反应)

  • 怎么解除快手头像上限(怎么解除快手头像24小时上限怎么办)

    怎么解除快手头像上限(怎么解除快手头像24小时上限怎么办)

  • 如何查看华为手机网速(如何查看华为手机的手机号)

    如何查看华为手机网速(如何查看华为手机的手机号)

  • ie8以上版本浏览器有哪些(ie8.0以上浏览器是电脑浏览器吗)

    ie8以上版本浏览器有哪些(ie8.0以上浏览器是电脑浏览器吗)

  • 汇编语言的特点是什么(汇编语言的特点有哪些方面)

    汇编语言的特点是什么(汇编语言的特点有哪些方面)

  • 手机占用内存大怎么办(手机占用内存大的原因)

    手机占用内存大怎么办(手机占用内存大的原因)

  • 手机一直亮着不灭怎么办(手机一直亮着不动怎么办)

    手机一直亮着不灭怎么办(手机一直亮着不动怎么办)

  • 手机怎么查驾驶本分(手机怎么查驾驶证吊销时间)

    手机怎么查驾驶本分(手机怎么查驾驶证吊销时间)

  • qq音乐app收藏歌曲(qq音乐怎么收藏的歌单)

    qq音乐app收藏歌曲(qq音乐怎么收藏的歌单)

  • vue弄完视频怎么变黑了(vue 视频怎么无损导出)

    vue弄完视频怎么变黑了(vue 视频怎么无损导出)

  • 什么是远程登录(什么是远程登录的两个特征)

    什么是远程登录(什么是远程登录的两个特征)

  • 小米mix2s如何连接蓝牙耳机(小米mix2怎么连接无线耳机)

    小米mix2s如何连接蓝牙耳机(小米mix2怎么连接无线耳机)

  • ftm什么意思(ft=m)

    ftm什么意思(ft=m)

  • 新办营利性医疗机构是否免征土地使用税和房产税?
  • 哪些东西要征收消费税
  • 培训学校可以不可以用燃气取暖炉
  • 房租雇东不开发票只有收据怎么处理?
  • 债权人豁免债务的账务
  • 非限定性净资产借贷方向
  • 股东个人固定资产怎么查
  • 资金账号和交易账号一样吗
  • 暂估成本跨年后未收到票如何处理
  • 小规模购买金税盘可以全额抵扣吗
  • 现金日记账的登记依据有
  • 划拨土地能转为商业用地吗
  • 公司法人信息变更是先去税务局还是先去银行
  • 一个人有多份工作
  • 已经抵扣的发票可以取消抵扣吗
  • 工伤保险费发票
  • 公司在外地
  • 远程清卡显示清卡失败,证书已挂失怎么回事
  • 企业上市过程中遇到的困难
  • 新25项工资薪金是什么
  • 西部大开发政策2020到期
  • 资本公积盈余公积区别
  • 挂靠行为应当如何纳税?
  • 企业识别码怎么查询
  • mac版本系统
  • 印花税计税依据及计算方式
  • php数组函数大全
  • 两借三贷是复合分录吗
  • php中md5函数
  • 土地增值税案例题库
  • 鼓励证券投资基金的政策
  • 固定资产的减值准备,一经确认,不得转回
  • bug的5个级别
  • 建安企业开具增值税专用发票要求
  • 原生js获取document
  • 前端脚本开发
  • lvm命令详解
  • 现金流量表第四个期初现金余额怎么填
  • 发票清单用什么纸打印出来
  • 一次性伤残补助金怎么查询进度
  • 企业利润分配项目是什么
  • mysql数据表存储引擎
  • phpmyadmin密码修改
  • 发票税率开错了3%开成5%怎么办?
  • 成立业主委员会申请书
  • 房开企业预缴增值税附加税费
  • 会计销售返利处理流程
  • 商品互换概念
  • 收取物业费如何纳税
  • 分公司向总公司申请拨款的请示
  • 企业刚注册成功又要注销要什么手续
  • 社保滞纳金可以免除吗
  • 收到的专项资金怎么入账
  • 搜索功能使用方法
  • 微软一般什么时候活动
  • win7系统压缩包
  • Ubuntu远程桌面连接
  • win7与vista关系
  • linux安装.gz
  • win7网络正常网页打不开是什么原因
  • win8界面什么样
  • win7系统怎么关闭屏幕保护
  • win7系统怎么禁用开机启动项
  • linux查看系统配置内存大小
  • win7调整视觉效果
  • Win10 Mobile Build 14269版截图曝光:脱胎换骨 速度飙升
  • linuxweb服务器
  • node_
  • jquery 设置和返回元素属性
  • node 包管理
  • js的匿名函数
  • python3利用smtplib通过qq邮箱发送邮件方法示例
  • python实现识别相似图片小结
  • jquery做下拉
  • python设颜色代码
  • windows中的linux
  • 广西地方税务网站官网
  • 新疆伊犁水费怎么交
  • 重庆社保60%退休工资
  • 开原航天医院官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设