位置: 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使用方式

  • 优酷怎么分享影视作品给好友(优酷怎么分享影片)

    优酷怎么分享影视作品给好友(优酷怎么分享影片)

  • 微信开启悬浮窗的方法是什么(微信开启悬浮窗口)

    微信开启悬浮窗的方法是什么(微信开启悬浮窗口)

  • 为什么手机密码正确还是解不开(为什么手机密码别人能轻易解开)

    为什么手机密码正确还是解不开(为什么手机密码别人能轻易解开)

  • surface充电白灯不亮(surface充电白灯闪烁后不亮)

    surface充电白灯不亮(surface充电白灯闪烁后不亮)

  • 抖音消息界面怎么变了(抖音消息界面怎么换主题颜色)

    抖音消息界面怎么变了(抖音消息界面怎么换主题颜色)

  •   淘宝如何刷单(淘宝如何刷人气)

      淘宝如何刷单(淘宝如何刷人气)

  • 电脑上的句号是哪个键(电脑上面句号)

    电脑上的句号是哪个键(电脑上面句号)

  • 滴滴注册城市很重要吗(滴滴司机注册城市)

    滴滴注册城市很重要吗(滴滴司机注册城市)

  • 12123星期六日不能登录吗(12123星期天)

    12123星期六日不能登录吗(12123星期天)

  • apple京东自营店是真的吗(apple京东自营店和苹果官网有区别吗)

    apple京东自营店是真的吗(apple京东自营店和苹果官网有区别吗)

  • 红米note5是lcd还是oled(红米note5 lcd)

    红米note5是lcd还是oled(红米note5 lcd)

  • 抖音可以知道被谁举报(抖音可以知道被谁拉黑)

    抖音可以知道被谁举报(抖音可以知道被谁拉黑)

  • 微控制器由哪三部分组成(微控制器的主要性能包括哪几个方面)

    微控制器由哪三部分组成(微控制器的主要性能包括哪几个方面)

  • 苹果id无法下载app(apple id 无法下载)

    苹果id无法下载app(apple id 无法下载)

  • 爱奇艺会员到期了下载的还能看吗(爱奇艺会员到期是24点吗)

    爱奇艺会员到期了下载的还能看吗(爱奇艺会员到期是24点吗)

  • lndal40是什么型号(lndtl40)

    lndal40是什么型号(lndtl40)

  • word怎么安装新字体(word安装教程)

    word怎么安装新字体(word安装教程)

  • 手机怎么收听电台(手机如何收听)

    手机怎么收听电台(手机如何收听)

  • iphonex如何投屏到电视(苹果x怎样手机投屏)

    iphonex如何投屏到电视(苹果x怎样手机投屏)

  • 电脑没声音了怎么办(电脑没声音了怎么办恢复正常win11)

    电脑没声音了怎么办(电脑没声音了怎么办恢复正常win11)

  • 苹果手机怎么量身高(苹果手机怎么量尺寸长度)

    苹果手机怎么量身高(苹果手机怎么量尺寸长度)

  • 苹果屏幕使用时间怎么关闭(苹果屏幕使用时间怎么清除)

    苹果屏幕使用时间怎么关闭(苹果屏幕使用时间怎么清除)

  • ipad分屏大小怎么调整(ipad分屏大小怎么调整不了)

    ipad分屏大小怎么调整(ipad分屏大小怎么调整不了)

  • 一加手机代言人是谁(一加手机代言人胡歌)

    一加手机代言人是谁(一加手机代言人胡歌)

  • 曲面手机屏容易破碎吗(曲面屏手机屏幕容易碎)

    曲面手机屏容易破碎吗(曲面屏手机屏幕容易碎)

  • 苹果6sp摄像头抖动(苹果6sp摄像头抖动修复多少钱)

    苹果6sp摄像头抖动(苹果6sp摄像头抖动修复多少钱)

  • 华为p30如何截图(华为p30如何截图截屏)

    华为p30如何截图(华为p30如何截图截屏)

  • 极易一键重装系统怎么用?极易一键重装系统详细步骤图解(极易一键重装系统怎么用)

    极易一键重装系统怎么用?极易一键重装系统详细步骤图解(极易一键重装系统怎么用)

  • 可以抵扣进项税额的增值税普通发票
  • 一般纳税人出租不动产增值税税率
  • 完税证明是可以抵扣吗
  • 企业购进固定资产时增值税如何处理
  • 个税新规定2021
  • 成本核算需要哪些基础工作
  • 活动经费属于什么费用
  • 现金流量科目怎么选择
  • 写字楼租金税率
  • 居民企业应纳税所得额税率
  • 个体工商户装修经营范围
  • 外购原材料自用要进项转出吗
  • 装修预付款怎么做分录
  • 应收代位追偿款是什么意思
  • 递延所得税如何申报
  • 进口小汽车消费税组成计税价格
  • 补计提去年的折旧该怎么做账
  • 小规模餐饮业会计核算
  • 经纪人佣金计入什么科目
  • 企业接收政府划入资产的税务处理办法
  • 一般纳税人注销公司麻烦吗
  • 小规模纳税人印花税怎样计算
  • 增资印花税如何申报缴纳
  • 地税三方协议是什么意思
  • 跨行转账16万手续费多少
  • 进项明细和开票明细不一致怎么办
  • 收据做账税局认嘛
  • 应交税费借方余额怎么处理
  • 发放股票股利后的未分配利润怎么算
  • 汽车发票金额怎么算
  • 投资性房地产转为自用的会计处理
  • 华为鸿蒙双击背面打开健康码
  • 股东分红个税怎么做账
  • Win10 Build 19044.1319(21H1)预览版发布:修复 Bug提高安全性
  • 年底会计结账
  • window10怎么取消快捷方式
  • 减免税款怎么做账务处理
  • 应发工资扣税
  • 项目的分包行为是否合理
  • php判断数组是否为空的函数
  • thinkphp项目怎么部署
  • php 后期静态绑定
  • topas命令详解
  • 织梦数据库连接失败的原因
  • 所得税的应税所得额
  • 运输行业油费怎么入账
  • 现流表与资产负债表的关系
  • 小规模纳税人缴纳增值税的会计科目
  • 含税销售收入会计分录
  • 安防工程注意事项有哪些
  • 付承包费计入什么科目
  • 股权转让账务咋处理
  • 印花税的减免
  • 退货开负数发票的情况该如何做会计处理?
  • 银行公司账户限额
  • 企业支付宝提现到对公账户要交税吗
  • 开销项负数的流程
  • 长期应付款涉及哪些业务,应如何进行核算
  • mysql字符集的作用
  • windows key查询
  • win2008 无线网卡
  • 电脑程序在运行桌面不显示的解决方法
  • linux中的ssh命令
  • macos10.8下载
  • win10回收站文件在哪里
  • windows7播放器在哪找
  • linux扩大文件系统
  • 微软商店更新错误
  • 下列关于android的说法中,错误的是
  • 利用的近义词
  • android面试题及答案2021
  • linux无法使用yum命令
  • javascript高级程序设计电子书
  • Zero Clipboard js+swf实现的复制功能使用方法
  • js的scrolltop
  • flexable.js
  • 国家税务局内蒙古税务
  • 销售不动产增值税税率
  • 淄博新农合怎么网上缴费
  • 税务主管机关有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设