当前位置: 首页 > news >正文

HTML5+JavaScript绘制闪烁的网格错觉

HTML5+JavaScript绘制闪烁的网格错觉

闪烁的网格错觉(scintillating grid illusion)是一种视觉错觉,通过简单的黑白方格网格和少量的精心设计,能够使人眼前出现动态变化的效果。

闪烁的栅格错觉,是一种经典的视觉错觉现象。网格错觉是指在由黑白相间的格子组成的图案中,观看者会在网格的交叉点处看到并不实际存在的灰色斑点或黑色圆点的现象。最早由德国心理学家卢迪马尔·赫尔曼(Ludimar Hermann)在1870年发现并报告。

如图所示:

HTML5+JavaScript绘制闪烁的网格错觉,源码如下:

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>闪烁网格错觉</title><style>body {display: flex;justify-content: center;align-items: center;height: 100vh;margin: 0;background-color: #F0FFFF;}canvas {border: 2px solid #333;}</style>
</head>
<body><canvas id="illusion" width="400" height="400"></canvas><script>const canvas = document.getElementById('illusion');const ctx = canvas.getContext('2d');const gridSize = 10;const cellSize = canvas.width / gridSize;function drawGrid() {// 设置黑色背景ctx.fillStyle = 'black';ctx.fillRect(0, 0, canvas.width, canvas.height);// 绘制灰色网格线#888ctx.strokeStyle = '#696969';ctx.lineWidth = 10;// 绘制竖线和横线for (let i = 1; i < gridSize; i++) {const pos = i * cellSize;// 竖线ctx.beginPath();ctx.moveTo(pos, 0);ctx.lineTo(pos, canvas.height);ctx.stroke();// 横线ctx.beginPath();ctx.moveTo(0, pos);ctx.lineTo(canvas.width, pos);ctx.stroke();}// 在交叉点绘制白色圆点ctx.fillStyle = 'white';for (let x = cellSize; x < canvas.width; x += cellSize) {for (let y = cellSize; y < canvas.height; y += cellSize) {ctx.beginPath();ctx.arc(x, y, 5, 0, Math.PI * 2);ctx.fill();}}}drawGrid();</script>
</body>
</html>

相关文章:

  • 基于php的酒店管理系
  • 【Python】数据可视化之点线图
  • 后端人需知
  • Spring Boot 进阶- Spring Boot 自定义拦截器详解
  • Go版数据结构 -【4.2 二叉搜索树】
  • 从零开始Ubuntu24.04上Docker构建自动化部署(五)Docker安装jenkins
  • Linux系统性能调优技巧:提升效率与响应速度的秘诀
  • uni-app在线预览pdf
  • LeetCode 704. 二分查找
  • attrs:Python的类装饰器(简化类定义)
  • 华为-单臂路由
  • 怎样将多个视频合并成一个?7种无损视频合并技巧,1分钟剪辑出大片!
  • 腾讯邮箱上传附件卡、慢、无法上传,下载慢问题处理
  • Unity图形用户界面!*★,°*:.☆( ̄▽ ̄)/$:*.°★* 。(万字解析)
  • Tableau数据可视化入门
  • 《网管员必读——网络组建》(第2版)电子课件下载
  • 2017-08-04 前端日报
  • Angular 4.x 动态创建组件
  • JavaScript实现分页效果
  • laravel 用artisan创建自己的模板
  • Map集合、散列表、红黑树介绍
  • Object.assign方法不能实现深复制
  • oldjun 检测网站的经验
  • Unix命令
  • use Google search engine
  • ViewService——一种保证客户端与服务端同步的方法
  • vue:响应原理
  • 程序员该如何有效的找工作?
  • 基于 Ueditor 的现代化编辑器 Neditor 1.5.4 发布
  • 面试总结JavaScript篇
  • 如何利用MongoDB打造TOP榜小程序
  • 使用Maven插件构建SpringBoot项目,生成Docker镜像push到DockerHub上
  • 数据仓库的几种建模方法
  • 微服务核心架构梳理
  • 微信小程序:实现悬浮返回和分享按钮
  • 小李飞刀:SQL题目刷起来!
  • 自动记录MySQL慢查询快照脚本
  • 阿里云ACE认证学习知识点梳理
  • 带你开发类似Pokemon Go的AR游戏
  • 积累各种好的链接
  • 继 XDL 之后,阿里妈妈开源大规模分布式图表征学习框架 Euler ...
  • ​Java基础复习笔记 第16章:网络编程
  • ​ssh-keyscan命令--Linux命令应用大词典729个命令解读
  • ​草莓熊python turtle绘图代码(玫瑰花版)附源代码
  • #Linux(Source Insight安装及工程建立)
  • #控制台大学课堂点名问题_课堂随机点名
  • (152)时序收敛--->(02)时序收敛二
  • (JS基础)String 类型
  • (NO.00004)iOS实现打砖块游戏(九):游戏中小球与反弹棒的碰撞
  • (pojstep1.1.2)2654(直叙式模拟)
  • (Redis使用系列) Springboot 整合Redisson 实现分布式锁 七
  • (ZT) 理解系统底层的概念是多么重要(by趋势科技邹飞)
  • (安全基本功)磁盘MBR,分区表,活动分区,引导扇区。。。详解与区别
  • (附源码)springboot太原学院贫困生申请管理系统 毕业设计 101517
  • (回溯) LeetCode 40. 组合总和II