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

离线一分钟小游戏《挖宝石》

公司内网无外网的情况下,就玩这个…
把上面代码全选→复制→记事本→另存为“miner.html”。
双击打开,方向键或WASD移动。
挖土找绿宝石(+10分),躲开灰色落石。
60秒倒计时结束或被砸中即游戏结束,刷新可重开。

<!DOCTYPEhtml><htmllang="zh-CN"><head><metacharset="utf-8"><title>像素矿工</title><style>body{margin:0;background:#111;display:flex;justify-content:center;align-items:center;height:100vh;font-family:monospace;color:#fff}canvas{border:2px solid #444;background:#000}#hud{position:absolute;top:10px;left:50%;transform:translateX(-50%);font-size:18px}</style></head><body><divid="hud">时间<spanid="t">60</span>分数<spanid="s">0</span></div><canvasid="c"></canvas><script>constC=document.getElementById('c'),X=C.getContext('2d');C.width=400;C.height=400;constS=20,G=20;// 格子大小 & 行列数constmap=Array.from({length:G},()=>Array(G).fill(1));// 1=土 0=空constgems=[],rocks=[];// 宝石与落石letpx=0,py=0,score=0,timeLeft=60,gameOver=false;// 随机挖个初始空洞for(leti=0;i<60;i++){letrx=Math.floor(Math.random()*G),ry=Math.floor(Math.random()*G);map[ry][rx]=0;}// 初始玩家位置px=Math.floor(Math.random()*G)*S;py=Math.floor(Math.random()*G)*S;// 键盘constkeys={};onkeydown=e=>keys[e.key.toLowerCase()]=1;onkeyup=e=>keys[e.key.toLowerCase()]=0;// 生成宝石functionspawnGem(){letx=Math.floor(Math.random()*G)*S;lety=Math.floor(Math.random()*G)*S;gems.push({x,y});}for(leti=0;i<10;i++)spawnGem();// 生成落石functionspawnRock(){letx=Math.floor(Math.random()*G)*S;rocks.push({x,y:0});}// 主循环setInterval(()=>{if(gameOver)return;// 倒计时timeLeft-=0.05;if(timeLeft<=0){gameOver=true;alert('时间到!得分:'+score);}document.getElementById('t').textContent=Math.ceil(timeLeft);// 移动letnx=px,ny=py;if(keys['a']||keys['arrowleft'])nx-=S;if(keys['d']||keys['arrowright'])nx+=S;if(keys['w']||keys['arrowup'])ny-=S;if(keys['s']||keys['arrowdown'])ny+=S;nx=Math.max(0,Math.min(C.width-S,nx));ny=Math.max(0,Math.min(C.height-S,ny));// 挖土letgx=nx/S|0,gy=ny/S|0;if(map[gy][gx]===1)map[gy][gx]=0;px=nx;py=ny;// 捡宝石gems.forEach((g,i)=>{if(Math.abs(g.x-px)<S&&Math.abs(g.y-py)<S){gems.splice(i,1);score+=10;spawnGem();}});// 落石if(Math.random()<0.02)spawnRock();rocks.forEach((r,i)=>{r.y+=3;if(r.y>C.height)rocks.splice(i,1);if(Math.abs(r.x-px)<S&&Math.abs(r.y-py)<S){gameOver=true;alert('你被落石砸中!得分:'+score);}});// 绘制X.fillStyle='#000';X.fillRect(0,0,C.width,C.height);// 画地图for(lety=0;y<G;y++){for(letx=0;x<G;x++){if(map[y][x]===1){X.fillStyle='#654';X.fillRect(x*S,y*S,S,S);}}}// 画宝石gems.forEach(g=>{X.fillStyle='#3f3';X.fillRect(g.x+6,g.y+6,8,8)});// 画落石rocks.forEach(r=>{X.fillStyle='#aaa';X.fillRect(r.x+4,r.y+4,12,12)});// 画玩家X.fillStyle='#f63';X.fillRect(px+2,py+2,S-4,S-4);document.getElementById('s').textContent=score;},50);</script></body></html>

最近业务不忙,所以丧心病狂的资本家开始作妖了!收手机,关外网…能玩的就一个能通电的铁疙瘩…所以你看到了上边的html~你知道我有多无聊么…

http://www.cnnetsun.cn/news/60561.html

相关文章:

  • leetcode 2110. 股票平滑下跌阶段的数目 中等
  • 15、智能平台管理接口驱动与直接内存访问技术解析
  • Ability Kit(程序框架服务)Stage模型
  • JVM内存结构与Java内存模型的区别
  • 认证加密算法选择困境:AES-GCM与ChaCha20-Poly1305的深度决策指南
  • 5分钟搞定NAS媒体库!nas-tools终极使用指南让你效率翻倍
  • GLM-4.5:重新定义智能体时代的成本效益比与工程化实践
  • yarn的容量调度器多队列
  • Spark的容错机制
  • M3u8下载终极指南:5分钟快速上手完整教程
  • Slint UI开发终极指南:2025从入门到精通的完整路径
  • 字节跳动UI-TARS重构GUI自动化:单模型架构超越GPT-4o,企业级应用提速300%
  • Qwen3-235B-A22B:双模式推理重塑2025企业AI效率标准
  • 万亿级MoE架构技术突破:Kimi-K2-Base如何重塑AI产业价值链
  • 30亿参数挑战720亿:CapRL-3B如何改写多模态模型游戏规则
  • Android开发终极指南:cw-omnibus项目完全解析
  • AutoGPT镜像一键部署方案发布,3分钟启动智能代理
  • 高级语言的分类和区别
  • AI绘图采样器选择指南:如何通过Stable Diffusion优化实现快速生成与质量平衡
  • 9、CentOS系统管理:Rsync文件同步备份与Mutt邮件报告使用指南
  • Kubernetes数据保护终极指南:Velero CSI快照实战全解析
  • Element-UI-X Typewriter组件终极指南:如何打造沉浸式打字体验?
  • 10、云计算应用实施与发展及容量管理解析
  • 2003-2023年各省高标准农田面板数据
  • 音频特征提取实战指南:从入门到精通的5大关键步骤
  • 终极指南:如何使用开源Wan 2.2轻松制作高清视频
  • PyTorch大模型高效部署指南:torchtune与ONNX深度整合实践
  • 32B大模型落地新范式:IBM Granite-4.0-H-Small如何重塑企业AI应用
  • 字节跳动Seed-OSS-36B:动态推理革命与企业级AI效率新标准
  • 6个实战技巧:彻底掌握Avalonia跨平台UI开发