复刻画龙产品vue实现新春气泡兔

 更新时间:2023年01月16日 08:34:40   作者:小鑫同学  
这篇文章主要为大家介绍了复刻画龙产品之使用vue实现新春气泡兔示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

😇推荐几个好用的工具

进入正题

复刻掘金一篇画龙的文章,在兔年春节来临之际献上一幅新春气泡兔,创意虽旧但技术永存,在线协作编写代码更轻松。

剪影图:

1. 初始化容器

通过 PIXI 中的 Application 对象初始化一个宽600、高1000、白色背景的容器,并通过appendChild添加到当前组件的模板中:

const initContainer = () => {
  const app = new PIXI.Application({ 
    width: 600, 
    height: 1000, 
    background: 'fff' 
  });
  container.value.appendChild(app.view);
  return app;
} 

2. 实现添加Sprite函数:

SpritePIXI中一个重要的概念,最后的气泡兔就是由一个个的Sprite拼出来的,最后再把每一个Sprite添加到stage中:

const setSprite = (app: any, x: any, y: any, size: any, scale: any) => {
  let sprite = PIXI.Sprite.from('circle.png');
  sprite.width = size;
  sprite.height = size;
  sprite.x = x * scale - size;
  sprite.y = y * scale - size;
  app.stage.addChild(sprite);
}

3. 核心三步绘制气泡兔

3.1 加载剪影图片,获取像素数据

剪影图片是一张由黑色主体和透明背景或纯色背景构成的一张图片,我们要加载这张剪影图片并获取到每个像素的数据。

下面是通过canvas来加载图片的过程,并通过getImageData()函数获取到了一个包含以 RGBA 为顺序的一维数组数据:

const transform = (app: any) => {
  const canvas = document.createElement("canvas") as HTMLCanvasElement;
  const ctx = canvas.getContext("2d") as CanvasRenderingContext2D;
  const image = new Image();
  image.src = "rabbit.jpeg";
  image.onload = () => {
    canvas.width = image.width;
    canvas.height = image.height;
    ctx.drawImage(image, 0, 0);
    // Uint8ClampedArray 类型
    const imageData = ctx.getImageData(0, 0, image.width, image.height).data;
    consoel.log(imageData) // 长度 = 高度 × 宽度 × 4 bytes
  }
}

3.2 搞清楚每个像素的颜色

需要通过双层循环来逐行对剪影图片中的每一个像素进行检查,在遍历时可以指定一个固定的step来控制遍历点的密度,在获取每一个position的时候要保持是一组RGBA4位的长度的倍数,这样在拿到每个点以后,通过下标来分别获取到R\G\B\A四个值:

const imageData = ctx.getImageData(0, 0, image.width, image.height).data;
const step = 20; // 控制每个点的密度
for (let y = 0; y < image.height; y += step) {
  for (let x = 0; x < image.width; x += step) {
    const position = (image.width * y + x) * 4;
    // 4个字节表示一组RGBA数据
    const r = imageData[position];
    const g = imageData[position + 1];
    const b = imageData[position + 2];
    const a = imageData[position + 3];
    if (r + g + b === 0 && a !== 0) { // 纯黑
      // TODO 绘制气泡
    }
  }
}

3.3 着手绘制气泡兔

在获取到每一组的RGBA数据后,如果R、G、B均为 0 且透明度非 0,那么代表这个位置需要绘制气泡了,绘制的气泡大小随机产生:

const scale = 0.8; // 控制绘制的整体缩放比
if (r + g + b === 0 && a !== 0) { // 纯黑
  const size = (Math.random() * 10 + 20) / 3;
  let sx = x * scale - size;
  let sy = y * scale - size;
  setSprite(app, sx, sy, size, scale);
}

气泡兔:

总结

本小节就到此结束了,文中提到的加载图片、获取像素点、遍历每个像素获取RGBA数据都搞清楚了吗?破解登录时遇到的滑动验证码是不是也可以用到这里面的知识点呢?大家可以发散一下思维。再次祝各位同学,兔年大吉、新春快乐~

以上就是复刻画龙产品vue实现新春气泡兔的详细内容,更多关于vue新春气泡兔的资料请关注脚本之家其它相关文章!

相关文章

  • vue+element UI实现树形表格

    vue+element UI实现树形表格

    这篇文章主要为大家详细介绍了vue+element UI实现树形表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • ElementUI修改实现更好用图片上传预览组件

    ElementUI修改实现更好用图片上传预览组件

    这篇文章主要为大家介绍了ElementUI修改实现更好用图片上传预览组件示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Uniapp设置页面的背景图片方法代码

    Uniapp设置页面的背景图片方法代码

    这篇文章主要给大家介绍了关于Uniapp设置页面的背景图片,uni-app中设置背景图有两种方式,分别是全局设置和在相应的view内设置背景,文中给出了代码示例,需要的朋友可以参考下
    2024-03-03
  • Vue 和 Django 实现 Token 身份验证的流程

    Vue 和 Django 实现 Token 身份验证的流程

    这篇文章主要介绍了Vue 和 Django 实现 Token 身份验证 ,Vue.js 和 Django 编写的前后端项目中,实现了基于 Token 的身份验证机制,其他前后端框架的 Token 实现原理与本文一致,需要的朋友可以参考下
    2022-08-08
  • elementUI使用el-upload上传文件写法及避坑总结(上传图片/视频到本地/服务器及回显+删除)

    elementUI使用el-upload上传文件写法及避坑总结(上传图片/视频到本地/服务器及回显+删除)

    upload上传是前端开发很常用的一个功能,下面这篇文章主要给大家介绍了关于elementUI使用el-upload上传文件写法及避坑的相关资料,包括上传图片/视频到本地/服务器及回显+删除,需要的朋友可以参考下
    2023-03-03
  • vue3实现v-model原理详解

    vue3实现v-model原理详解

    这篇文章主要介绍了vue3实现v-model原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • vue.js 初体验之Chrome 插件开发实录

    vue.js 初体验之Chrome 插件开发实录

    这篇文章主要介绍了vue.js 初体验之Chrome 插件开发实录 ,需要的朋友可以参考下
    2017-05-05
  • vue踩坑记录:属性报undefined错误问题

    vue踩坑记录:属性报undefined错误问题

    这篇文章主要介绍了vue踩坑记录:属性报undefined错误问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • vue-cli配置flexible过程详解

    vue-cli配置flexible过程详解

    这篇文章主要介绍了vue-cli配置flexible过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • Vue看了就会的8个小技巧

    Vue看了就会的8个小技巧

    这篇文章主要介绍了玩转Vue的8个小技巧,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
    2021-01-01

最新评论