前端页面效果收集
文章目录
- 数字雨
- 元素融化动画
- 电子签名
- 共享屏幕
数字雨
<canvas id="matrix"></canvas>
<script>const canvas = document.getElementById('matrix');const ctx = canvas.getContext('2d');canvas.width = window.innerWidth;canvas.height = window.innerHeight;const chars = '01';const drops = Array(Math.floor(canvas.width / 20)).fill(0);function draw() {ctx.fillStyle = 'rgba(0,0,0,0.05)';ctx.fillRect(0, 0, canvas.width, canvas.height);ctx.fillStyle = '#0F0';drops.forEach((drop, i) => {ctx.fillText(chars[Math.random() > 0.5 ? 0 : 1], i * 20, drop);drops[i] = drop > canvas.height ? 0 : drop + 20;});}setInterval(draw, 100);
</script>
元素融化动画
<div onclick="melt(this)" style="cursor:pointer; padding:20px; background:#ff6666;"> 点击融化!</div>
<script>function melt(element) {let pos = 0;const meltInterval = setInterval(() => {element.style.borderRadius = `${pos}px`;element.style.transform = `skew(${pos}deg) scale(${1 - pos/100})`;element.style.opacity = 1 - pos / 100;pos += 2;if (pos > 100) clearInterval(meltInterval);}, 50);}
</script>
电子签名
<style>* {margin: 0;padding: 0;}body {display: flex;justify-content: center;align-items: center;flex-direction: column;height: 100vh;width: 100vw;background-color: #f0f0f0;overflow: hidden;}canvas {border: 1px solid #000;background-color: #fff;}.controls {margin-top: 10px;display: flex;gap: 10px;}button,select {padding: 5px 10px;cursor: pointer;}
</style><!-- 画板 --><canvas id="signature-pad" width="400" height="200"></canvas><!-- 控制器 --><div ><select id="stroke-style" ><option value="pen">钢笔</option><option value="brush">毛笔</option></select><button id="clear" >清空</button><button id="export">导出图片</button></div><script>document.addEventListener('DOMContentLoaded', () => {// 获取 canvas 元素和其 2D 上下文const canvas = document.getElementById('signature-pad');const ctx = canvas.getContext('2d');let drawing = false; // 标志是否正在绘制let lastX = 0, lastY = 0; // 保存上一个点的坐标let strokeStyle = 'pen'; // 初始笔画样式// 开始绘制的函数const startDrawing = (e) => {e.preventDefault(); // 阻止默认行为,避免页面滚动drawing = true; // 设置为正在绘制ctx.beginPath(); // 开始新路径// 记录初始点的位置const { offsetX, offsetY } = getEventPosition(e);lastX = offsetX;lastY = offsetY;ctx.moveTo(offsetX, offsetY); // 移动画笔到初始位置};// 绘制过程中的函数const draw = (e) => {e.preventDefault(); // 阻止默认行为,避免页面滚动if (!drawing) return; // 如果不是在绘制,直接返回// 获取当前触点位置const { offsetX, offsetY } = getEventPosition(e);// 使用贝塞尔曲线进行平滑过渡绘制ctx.quadraticCurveTo(lastX,lastY,(lastX + offsetX) / 2,(lastY + offsetY) / 2);ctx.stroke(); // 实际绘制路径// 更新上一个点的位置lastX = offsetX;lastY = offsetY;};// 停止绘制的函数const stopDrawing = (e) => {e.preventDefault(); // 阻止默认行为drawing = false; // 结束绘制状态};// 获取事件中触点的相对位置const getEventPosition = (e) => {// 鼠标事件或者触摸事件中的坐标const offsetX = e.offsetX || e.touches[0].clientX - canvas.offsetLeft;const offsetY = e.offsetY || e.touches[0].clientY - canvas.offsetTop;return { offsetX, offsetY };};// 绑定鼠标事件const bindMouseEvents = () => {canvas.addEventListener('mousedown', startDrawing);canvas.addEventListener('mousemove', draw);canvas.addEventListener('mouseup', stopDrawing);canvas.addEventListener('mouseout', stopDrawing);};// 绑定触摸事件const bindTouchEvents = () => {canvas.addEventListener('touchstart', startDrawing);canvas.addEventListener('touchmove', draw);canvas.addEventListener('touchend', stopDrawing);canvas.addEventListener('touchcancel', stopDrawing);};// 清除画布的功能const clearCanvas = () => {document.getElementById('clear').addEventListener('click', () => {ctx.clearRect(0, 0, canvas.width, canvas.height); // 清空整个画布});};// 修改笔画样式的功能const changeStrokeStyle = () => {document.getElementById('stroke-style').addEventListener('change', (e) => {strokeStyle = e.target.value; // 获取选中的笔画样式updateStrokeStyle(); // 更新样式});};// 根据 strokeStyle 更新笔画样式const updateStrokeStyle = () => {if (strokeStyle === 'pen') {ctx.lineWidth = 2; // 细线条ctx.lineCap = 'round'; // 线条末端圆角} else if (strokeStyle === 'brush') {ctx.lineWidth = 5; // 粗线条ctx.lineCap = 'round'; // 线条末端圆角}};// 导出图片的功能const exportImage = () => {document.getElementById('export').addEventListener('click', () => {// 创建临时 canvasconst tempCanvas = document.createElement('canvas');tempCanvas.width = canvas.width;tempCanvas.height = canvas.height;const tempCtx = tempCanvas.getContext('2d');// 绘制白色背景tempCtx.fillStyle = 'white';tempCtx.fillRect(0, 0, tempCanvas.width, tempCanvas.height);// 将原画布内容绘制到临时画布上tempCtx.drawImage(canvas, 0, 0);const dataURL = tempCanvas.toDataURL('image/png');const link = document.createElement('a');link.href = dataURL;link.download = 'signature.png';link.click();});};// 初始化const init = () => {bindMouseEvents();bindTouchEvents();clearCanvas();changeStrokeStyle();updateStrokeStyle();exportImage();};init();});
</script>
共享屏幕
<button>共享屏幕</button>
<script>const button = document.querySelector("button");button.addEventListener("click", async () => {const stream = await navigator.mediaDevices.getDisplayMedia({video: true,});const mime = MediaRecorder.isTypeSupported("video/webm;codecs=h264")? "video/webm;codecs=h264": "video/webm";const mediaRecorder = new MediaRecorder(stream, { mimeType: mime });const chunks = [];mediaRecorder.addEventListener("dataavailable", function (e) {chunks.push(e.data);});mediaRecorder.addEventListener("stop", () => {const blob = new Blob(chunks, { type: chunks[0].type });const url = URL.createObjectURL(blob);const a = document.createElement("a");a.href = url;a.download = "video.webm";a.click();});mediaRecorder.start();});
</script>
相关文章:
前端页面效果收集
文章目录 数字雨元素融化动画电子签名共享屏幕 数字雨 <canvas id"matrix"></canvas> <script>const canvas document.getElementById(matrix);const ctx canvas.getContext(2d);canvas.width window.innerWidth;canvas.height window.innerH…...
(leetcode算法题)309. 买卖股票的最佳时机含冷冻期
按照题目要求,研究对象是最后一天结束后获得的最大利润 那么就可以把问题拆分成 第 1 天结束后获得的最大利润, 第 2 天结束后获得的最大利润, 第 i 天结束后获得的最大利润, 由于规则中强调不能同时参与多笔交易,…...
Chrome漏洞可窃取数据并获得未经授权的访问权限
在发现两个关键漏洞后,谷歌发布了Chrome浏览器的紧急安全更新。这些漏洞可能允许攻击者窃取敏感数据并未经授权访问用户系统。 这些缺陷被识别为CVE-2025-3619和CVE-2025-3620,在Windows和Mac的135.0.7049.95/.96之前影响Chrome版本,影响Linux的135.0.7049.95/.96。该更新将在…...
.net core 项目快速接入Coze智能体-开箱即用-全局说明
目录 一、Coze智能体的核心价值 二、开箱即用-效果如下 三 流程与交互设计 为什么要分析意图,而不是全部交由AI处理。 四 接入前的准备工作 五:代码实现----字节Coze 签署 JWT和获取Token .net core 项目快速接入Coze智能体-开箱即用 .net core快…...
风丘年度活动:2025年横滨汽车工程展览会
| 展会简介: 2025年横滨汽车工程展览会,是由日本汽车工程师学会(JSAE)精心主办的一场行业盛会。预计届时将汇聚超550家参展商,设置1300个展位,展览面积超过20000平方米。展会受众广泛,面向汽车…...
Redis线上操作最佳实践有哪些?
大家好,我是锋哥。今天分享关于【Redis线上操作最佳实践有哪些?】面试题。希望对大家有帮助; Redis线上操作最佳实践有哪些? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在使用 Redis 时,尤其是在生产环境中,合理…...
Gin趣讲
故事背景:Gin快递公司 假设你开了一家名叫“Gin快递”的公司,专门帮客户寄包裹。客户会通过电话(也就是HTTP请求)告诉你他们要寄什么东西,你的公司得快速接单、分任务、处理包裹,最后把结果送回去。Gin框架…...
Redis——五种数据类型
目录 前言 1.String 1.1RAW编码 1.2EMBSTR编码 1.3 INT编码 2.List 3.Set 3.1 InSet编码转化成Dict编码 4.ZSet 4.1结合SkipList和HT实现 4.2使用ZipList实现 4.3编码转换 4.4 ZipList排序功能 5.Hash 5.1Hash底层存储结构 6.Redis数据结构和数据类型关系图 前言…...
Godot学习-创建简单动画
文章目录 1、准备工作Godot资源 2、创建项目3、创建结点4、创建动画1、创建动画2、添加轨道3、创建关键帧3.1 第一个关键帧3.2 第二个关键帧 5、加载后自动播放6、动画循环7、轨道设置1、轨道更新模式2、轨迹插值3、其他属性的关键帧4、编辑关键帧5、使用 RESET 轨道6、洋葱皮 …...
论文阅读VACE: All-in-One Video Creation and Editing
code:https://github.com/ali-vilab/VACE 核心 单个模型同时处理多种视频生成和视频编辑任务通过VCU(视频条件单元)进行实现 方法 视频任务 所有的视频相关任务可以分为4类 文本生视频 参考图片生视频 视频生视频 视频mask生视频 VCU …...
JavaSE学习(前端初体验)
文章目录 前言一、准备环境二、创建站点(创建一个文件夹)三、将站点部署到编写器中四、VScode实用小设置五、案例展示 前言 首先了解前端三件套:HTML、CSS、JS HTML:超文本标记语言、框架层、描述数据的; CSS…...
AlmaLinux 9.2 安装 snmp 后 sshd 服务无法启动
问题 AlmaLinux 9.2 安装 net-snmp 后导致 sshd 无法启动,SSH 无法正常连接。并且在日志中发现OpenSSL version mismatch. Built against 30000010, you have 30200020错误。 问题排查 AlmaLinux 9.2 初始安装 openssl 的版本为 3.0.7。软件包为openssl-3.0.7-6。…...
前端渲染pdf文件解决方案
一、前言 在当今数字化信息传播的时代,PDF文档作为一种常见的文件格式扮演着重要的角色。对于前端开发者而言,实现在网页上渲染和展示PDF文件是一项常见但也具有挑战性的任务。幸运的是,现在有一个强大的工具——react-pdf-viewer,…...
Kubernetes(K8S)内部功能总结
Kubernetes(K8S)是云技术的最核心的部分,也是构建是云原生的基石 K8S K8S,是Kubernetes的缩写,是Google开发的容器编排平台,现在由云原生计算基金会(CNCF)进行维护。 K8Sÿ…...
蓝桥杯日期的题型
做题思路 一般分为3个步骤,首先要定义一个结构体来存储月份的天数,第一循环日期,第二判断日期是否为闰年,第三就是题目求什么 结构体 static int[] ds{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; 判断是否闰年的函数 public static void f(int m,int d){//被4整…...
【计算机网络】3数据链路层①
这篇笔记专门讲数据链路层的功能。 2.功能 数据链路层的主要任务是让帧在一段链路上或一个网络中传输。 2.1.封装成帧(组帧) 解决的问题:①帧定界②帧同步③透明传输 实现组帧的方法通常有以下种。 2.1.1.字符计数法 原理:在每个帧开头,用一个定长计数字段来记录该…...
Mysql--基础知识点--93--两阶段提交
1 两阶段提交 以update语句的具体执行过程为例: 具体更新一条记录 UPDATE t_user SET name ‘xiaolin’ WHERE id 1;的流程如下: 1.执行器负责具体执行,会调用存储引擎的接口,通过主键索引树搜索获取 id 1 这一行记录&#…...
Nginx底层架构(非常清晰)
目录 前言: 场景带入: HTTP服务器是什么? 反向代理是什么? 模块化网关能力: 1.配置能力: 2.单线程: 3.多worker进程 4.共享内存: 5.proxy cache 6.master进程 最后&…...
期货数据API对接实战指南
一、期货数据接口概述 StockTV提供全球主要期货市场的实时行情与历史数据接口,覆盖以下品种: 商品期货:原油、黄金、白银、铜、天然气、农产品等金融期货:股指期货、国债期货特色品种:马棕油、铁矿石等区域特色期货 …...
网页图像优化:现代格式与响应式技巧
网页图像优化:现代格式与响应式技巧 网页图像如果处理不好,很容易拖慢加载速度,影响用户体验。这篇文章聊聊怎么用现代图像格式和响应式技巧,让你的网站图片加载更快、效果更好。 推荐的图像格式 选对图像格式,能在保…...
Docker 设置镜像源后仍无法拉取镜像问题排查
#记录工作 Windows系统 在使用 Docker 的过程中,许多用户会碰到设置了国内镜像源后,依旧无法拉取镜像的情况。接下来,记录了操作要点以及问题排查方法,帮助我们顺利解决这类问题。 Microsoft Windows [Version 10.0.27823.1000…...
设计模式实践:模板方法、观察者与策略模式详解
目录 1 模板方法1.1 模板方法基本概念1.2 实验1.2.1 未使用模板方法实现代码1.2.2 使用模板方法的代码 2 观察者模式2.1 观察者模式基本概念2.2 实验 3 策略模式3.1 策略模式基本概念3.2 实验 1 模板方法 1.1 模板方法基本概念 定义:一个操作中的算法的骨架 &…...
Rockchip 显示架构
对于 Rockchip 平台,主要有以下几种显示架构可供选择: Qt + WaylandQt + EGLFSEGL program + X11WaylandNone多窗口的功能需求,选择: X11Wayland桌面的功能需求,选择: X114K 视频播放 + 全屏:Qt + WaylandQt + EGLFSX11Wayland4K 视频播放 + 多窗口: X11Qt + WaylandWa…...
Edge 浏览器推出 Copilot Vision:免费实时解析屏幕内容;Aqua Voice:极速 AI 语音输入工具丨日报
开发者朋友们大家好 这里是 「RTE 开发者日报」 ,每天和大家一起看新闻、聊八卦。我们的社区编辑团队会整理分享 RTE(Real-Time Engagement) 领域内「有话题的 技术 」、「有亮点的 产品 」、「有思考的 文章 」、「有态度的 观点 」、「有看…...
async-profiler火焰图找出耗CPU方法
事情起于开发应用对依赖的三方包(apache等等)进行了升级后(主要是升级spring),CPU的使用率较原来大幅提升,几个应用提升50%-100%。 查找半天,对比每次版本的cpu火焰图,看不出有什么…...
@Autowird 注解与存在多个相同类型对象的解方案
现有一个 Student 类,里面有两个属性,分别为 name 和 id;有一个 StuService 类,里面有两个方法,返回值均为类型为 Student 的对象;还有一个 StuController 类,里面有一个 Student 类型的属性&am…...
WordPiece 详解与示例
WordPiece详解 1. 定义与背景 WordPiece 是一种子词分词算法,由谷歌于2012年提出,最初用于语音搜索系统,后广泛应用于机器翻译和BERT等预训练模型。其核心思想是将单词拆分为更小的子词单元(如词根、前缀/后缀),从而解决传统分词方法面临的词汇表过大和未知词(OOV)处…...
PVE+CEPH+HA部署搭建测试
一、基本概念介绍 Proxmox VE Proxmox Virtual Environment (Proxmox VE) 是一款开源的虚拟化管理平台,基于 Debian Linux 开发,支持虚拟机和容器的混合部署。它提供基于 Web 的集中管理界面,简化了计算、存储和网络资源的配置与监控。P…...
【Leetcode 每日一题 - 补卡】1534. 统计好三元组
问题背景 给你一个整数数组 a r r arr arr,以及 a 、 b 、 c a、b 、c a、b、c 三个整数。请你统计其中好三元组的数量。 如果三元组 ( a r r [ i ] , a r r [ j ] , a r r [ k ] ) (arr[i], arr[j], arr[k]) (arr[i],arr[j],arr[k]) 满足下列全部条件ÿ…...
ROS ROS2 机器人深度相机激光雷达多传感器标定工具箱
系列文章目录 目录 系列文章目录 前言 三、标定目标 3.1 使用自定义标定目标 四、数据处理 4.1 相机数据中的标定目标检测 4.2 激光雷达数据中的标定目标检测 输入过滤器: 正常估算: 区域增长: 尺寸过滤器: RANSAC&a…...
