iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >基于JavaScript实现年份数字拼图效果
  • 753
分享到

基于JavaScript实现年份数字拼图效果

JavaScript年份数字拼图效果JavaScript数字拼图JavaScript拼图 2022-12-30 12:12:08 753人浏览 八月长安
摘要

目录背景实现原理具体实现延伸总结背景 时光荏苒,2022年又要收尾了,公司的年会是不是都安排上了?(顺便问一嘴,您阳了吗?) 前几天看到一个年会抽奖系统,功能十分的强大,其中有一个年

背景

时光荏苒,2022年又要收尾了,公司的年会是不是都安排上了?(顺便问一嘴,您阳了吗?)

前几天看到一个年会抽奖系统,功能十分的强大,其中有一个年份数字的拼图效果深深的吸引了哥,决定深入探索一番。先看下具体的效果,图中有个2022的年份数字。

实现原理

从效果能看出,实际就是将相应卡片设置为高亮颜色拼成数字,实现原理大致是:

  • 设计好数字(0-9)在横向和纵向占据的卡片列数和行数,比如上图中的横向为3列,纵向为5行;
  • 针对每个数字(0-9)的形状,获取亮色卡片位置的坐标,从而得到每个数字的形状坐标数组
  • 根据每个数字的形状坐标、要展示数字的顺序计算出具体的位置,将对应坐标卡片设置为亮色就可以了;

具体实现

1. 创建背景卡片

拼图展示的数字是当前的年份(2022),也就是4位数字。根据数字在横行占3列,纵向占5行,数字前后间隔1列,为了美观数字区域上下左右边界要空出一行或者一列。所以整个背景卡片的列数和行数就有了:

行数 = 5 + 1 + 1 = 7;

列数 = 3 * 4 + 3(间隔) + 1 + 1 = 17;

const rowCount = 7;
const colCount = 17;
// 创建卡片
const createCard = () => {
  const frag = document.createDocumentFragment();
  for (let i = 0; i < rowCount; i++) {
    for (let j = 0; j < colCount; j++) {
      const item = document.createElement('div');
      item.className = "item";
      frag.appendChild(item);
    }

  }
  document.querySelector('.container').appendChild(frag);
}

2. 设置数字形状坐标

这个其实就是根据每个数字的形状,记录下形状路径上的每个点的坐标。规则是从上到下,从左到右,找到所有路径上的点。0-9的形状坐标数组如代码所示,可以比照着上文中的图片,确认下数字的形状坐标。

注意:如果想设计其他的数字字体展示形式,可以根据具体形状收集路径点坐标。

// 0-9数字的坐标形状
const NUMBER_MATRIX = [
  [
    // 0
    [0, 0],
    [1, 0],
    [2, 0],
    [0, 1],
    [2, 1],
    [0, 2],
    [2, 2],
    [0, 3],
    [2, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ],
  [
    // 1
    [1, 0],
    [0, 1],
    [1, 1],
    [1, 2],
    [1, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ],
  [
    // 2
    [0, 0],
    [1, 0],
    [2, 0],
    [2, 1],
    [0, 2],
    [1, 2],
    [2, 2],
    [0, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ],
  [
    // 3
    [0, 0],
    [1, 0],
    [2, 0],
    [2, 1],
    [0, 2],
    [1, 2],
    [2, 2],
    [2, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ],
  [
    // 4
    [0, 0],
    [2, 0],
    [0, 1],
    [2, 1],
    [0, 2],
    [1, 2],
    [2, 2],
    [2, 3],
    [2, 4]
  ],
  [
    // 5
    [0, 0],
    [1, 0],
    [2, 0],
    [0, 1],
    [0, 2],
    [1, 2],
    [2, 2],
    [2, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ],
  [
    // 6
    [0, 0],
    [1, 0],
    [2, 0],
    [0, 1],
    [0, 2],
    [1, 2],
    [2, 2],
    [0, 3],
    [2, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ],
  [
    // 7
    [0, 0],
    [1, 0],
    [2, 0],
    [2, 1],
    [2, 2],
    [2, 3],
    [2, 4]
  ],
  [
    // 8
    [0, 0],
    [1, 0],
    [2, 0],
    [0, 1],
    [2, 1],
    [0, 2],
    [1, 2],
    [2, 2],
    [0, 3],
    [2, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ],
  [
    // 9
    [0, 0],
    [1, 0],
    [2, 0],
    [0, 1],
    [2, 1],
    [0, 2],
    [1, 2],
    [2, 2],
    [2, 3],
    [0, 4],
    [1, 4],
    [2, 4]
  ]
];

3. 数字拼图

第二步中,给出的数字形状坐标实际是单个数字展示时的坐标,如果多个数字并排展示,需要对每个数字的坐标进行换算,换算规则主要有2条

  • 因为数字是横向排列的,所以每增加一个数字,x坐标都要增加4列(包含一列数字间隔)
  • 由于数字展示区域周边上下左右都空了一行或者一列,所以x坐标和y坐标的开始位置,都是从(1,1)开始的。
// 根据数字形状、当前年份等信息,筛选出需要设置为亮色的卡片位置
const getHighlight = () => {
  // 获取当前年份
  let year = new Date().getFullYear() + "";
  let step = 4,
    xoffset = 1,
    yoffset = 1,
    highlight = [];

  year.split('').forEach(n => {
    highlight = highlight.concat(
      NUMBER_MATRIX[n].map(item => {
        return `${item[0] + xoffset}-${item[1] + yoffset}`;
      })
    );
    xoffset += step;
  });

  return highlight;
}

最后highlight返回的其实就是点坐标字符串的数组,类似['1-1', '2-1']这种。

然后就可以根据返回的点坐标数组进行绘制拼图,其实就是将对应坐标的卡片添加高亮的样式类名

const createHighLight = async (cards, hightLight) => {
  for (let i = 0; i < hightLight.length; i++) {
    const [col, row] = hightLight[i].split('-');
    const index = Math.floor(row) * colCount + Math.floor(col);
    cards[index].className = 'item highlight'
  }
}

最终实现效果如下图所示:

延伸

上文中只是实现了静态数字的拼图展示效果,如果能够让数字动起来呢?比如实现一个写字效果、或者倒计时变动数字效果,这些会让拼图更加的酷炫。我们下面实现一个写字效果

其实,原理很简单,只需要在绘制数字拼图卡片时,将每个坐标点的绘制,改成异步串行绘制就行了

const createHighLight = async (cards, hightLight) => {
  for (let i = 0; i < hightLight.length; i++) {
    await new Promise((resolve, reject) => setTimeout(resolve, 100));
    const [col, row] = hightLight[i].split('-');
    const index = Math.floor(row) * colCount + Math.floor(col);
    cards[index].className = 'item highlight'
  }
  // 绘制结束后,循环绘制
  await new Promise((resolve, reject) => setTimeout(resolve, 100));
  drawData(); 
}

具体实现效果如下所示:

注意:数字的绘制效果可能和我们正常的书写笔画顺序不一致,这是因为坐标点是按照从上到下,从左到右的顺序收集的,其实可以调整坐标点顺序,让它符合书写笔画的顺序,就可以看到正常的书写效果了,自己尝试吧哈

总结

本文主要分析了数字拼图效果的实现原理,实现核心就是要先确定每个数字的形状坐标,然后根据形状坐标去绘制高亮卡片。最后在静态数字拼图效果的基础之上,借助异步串行,实现了手写字的效果,其他效果可以自己在此基础上自己尝试。

以上就是基于javascript实现年份数字拼图效果的详细内容,更多关于JavaScript年份数字拼图的资料请关注编程网其它相关文章!

--结束END--

本文标题: 基于JavaScript实现年份数字拼图效果

本文链接: https://www.lsjlt.com/news/176296.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 基于JavaScript实现年份数字拼图效果
    目录背景实现原理具体实现延伸总结背景 时光荏苒,2022年又要收尾了,公司的年会是不是都安排上了?(顺便问一嘴,您阳了吗?) 前几天看到一个年会抽奖系统,功能十分的强大,其中有一个年...
    99+
    2022-12-30
    JavaScript年份数字拼图效果 JavaScript数字拼图 JavaScript拼图
  • Java二维数组实现数字拼图效果
    二维数组实现数字拼图,供大家参考,具体内容如下 二维数组可以自己随意定义大小,通过方法判断来实现对所有的数字进行随机打乱,并可以通过移动来正确还原,并可以判断0(表示空格)是否可以移...
    99+
    2024-04-02
  • 基于JavaScript实现新年贺卡特效
    目录动图演示主要代码css样式Javascirpt动图演示 一款超级炫酷的2022新年快乐html网页特效,霓虹的城市夜景和绚烂的烟花很是特别,该html页面还有交互效果,点击鼠标就...
    99+
    2024-04-02
  • Java二维数组怎么实现数字拼图效果
    本篇内容主要讲解“Java二维数组怎么实现数字拼图效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java二维数组怎么实现数字拼图效果”吧!二维数组实现数字拼图,供大家参考,具体内容如下二维数...
    99+
    2023-06-20
  • 基于Echarts实现饼图效果
    本文实例为大家分享了Echarts实现饼图效果的具体代码,供大家参考,具体内容如下 1 显示数值效果 series 下的label 饼图的文字显示2 半径 圆环 radius3 南丁...
    99+
    2024-04-02
  • JavaScript如何实现年份轮播选择效果
    这篇文章主要讲解了“JavaScript如何实现年份轮播选择效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript如何实现年份轮播选择效果”吧!前言用 js 实现一个年份轮换...
    99+
    2023-06-27
  • JavaScript实现年历效果
    本文实例为大家分享了JavaScript实现年历效果的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html> <head...
    99+
    2024-04-02
  • 基于jquery实现轮播图效果
    本文实例为大家分享了jquery实现轮播图效果的具体代码,供大家参考,具体内容如下 轮播图左切换原理图 黄色的方框表示的是  slides ,而  slide ...
    99+
    2024-04-02
  • 基于JavaScript实现省市联动效果
    本文实例为大家分享了JavaScript实现省市联动效果的具体代码,供大家参考,具体内容如下 代码: <!DOCTYPE html> <html lang="...
    99+
    2024-04-02
  • 原生js实现拼图效果
    本文实例为大家分享了原生js实现拼图效果的具体代码,供大家参考,具体内容如下 需求:每次刷新页面后,右侧容器内会随机排列碎片图片,鼠标按下拖动到左侧,在正确坐标一定范围内,图片会自动...
    99+
    2024-04-02
  • 基于Echarts如何实现饼图效果
    这篇文章主要讲解了“基于Echarts如何实现饼图效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于Echarts如何实现饼图效果”吧!1 显示数值效果 series 下的label 饼...
    99+
    2023-06-30
  • js实现数字拼图
    本文实例为大家分享了js实现数字拼图的具体代码,供大家参考,具体内容如下 重点: 游戏区分为8个div,进行游戏时需要判断点击的div是否可移动,移动后判断游戏是否结束。 解决思路:...
    99+
    2024-04-02
  • 基于jquery实现简单轮播图效果
    本文使用jquery实现轮播图效果,供大家参考,具体内容如下 首先上效果 上代码 html <div id="main">     <div class="pic...
    99+
    2024-04-02
  • 基于Three.js实现酷炫3D地图效果
    目录实现效果前言使用1.修改整体的背景图可以使用颜色或用贴图改材质2. 取消地图上柱状图显示3.更换地图、更换省份、市 4.修改相机的视角,页面展示的远近角度5....
    99+
    2022-11-13
    Three.js 3D地图 Three.js 地图
  • 基于jquery如何实现轮播图效果
    这篇文章主要讲解了“基于jquery如何实现轮播图效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于jquery如何实现轮播图效果”吧!轮播图左切换原理图黄色的方框表示的是  ...
    99+
    2023-06-14
  • 怎么用js实现拼图效果
    这篇文章主要讲解了“怎么用js实现拼图效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用js实现拼图效果”吧!需求:每次刷新页面后,右侧容器内会随机排列碎片图片,鼠标按下拖动到左侧,在...
    99+
    2023-06-20
  • 基于JavaScript如何实现新手引导效果
    这篇文章主要介绍了基于JavaScript如何实现新手引导效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇基于JavaScript如何实现新手引导效果文章都会有所收获,下面我们一起来看看吧。一、实现效果二、实...
    99+
    2023-07-05
  • 基于JavaScript实现在线网页烟花效果
    目录实现效果关键步骤源码实现效果 关键步骤 随机颜色 var hue = Math.random() * 360;var hueVariance = 30; functio...
    99+
    2023-02-03
    JavaScript在线网页烟花效果 JavaScript 烟花效果 JavaScript烟花
  • 基于Vue3怎么实现图片散落效果
    这篇文章主要介绍“基于Vue3怎么实现图片散落效果”,在日常操作中,相信很多人在基于Vue3怎么实现图片散落效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”基于Vue3怎么实现图片散落效果”的疑惑有所帮助!...
    99+
    2023-06-30
  • react基于react-slick实现多图轮播效果
    目录写在前面:一、进入官网查看文档(Docs)二、安装插件(Quick Start)三、范例使用(Examples)1、直接copy代码:2、实现结果:3、引入样式:4、还是报错?5...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作