亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

復(fù)刻畫龍產(chǎn)品vue實現(xiàn)新春氣泡兔

 更新時間:2023年01月16日 08:34:40   作者:小鑫同學(xué)  
這篇文章主要為大家介紹了復(fù)刻畫龍產(chǎn)品之使用vue實現(xiàn)新春氣泡兔示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

??推薦幾個好用的工具

進(jìn)入正題

復(fù)刻掘金一篇畫龍的文章,在兔年春節(jié)來臨之際獻(xiàn)上一幅新春氣泡兔,創(chuàng)意雖舊但技術(shù)永存,在線協(xié)作編寫代碼更輕松。

剪影圖:

1. 初始化容器

通過 PIXI 中的 Application 對象初始化一個寬600、高1000、白色背景的容器,并通過appendChild添加到當(dāng)前組件的模板中:

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

2. 實現(xiàn)添加Sprite函數(shù):

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 加載剪影圖片,獲取像素數(shù)據(jù)

剪影圖片是一張由黑色主體和透明背景或純色背景構(gòu)成的一張圖片,我們要加載這張剪影圖片并獲取到每個像素的數(shù)據(jù)。

下面是通過canvas來加載圖片的過程,并通過getImageData()函數(shù)獲取到了一個包含以 RGBA 為順序的一維數(shù)組數(shù)據(jù):

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 搞清楚每個像素的顏色

需要通過雙層循環(huán)來逐行對剪影圖片中的每一個像素進(jìn)行檢查,在遍歷時可以指定一個固定的step來控制遍歷點的密度,在獲取每一個position的時候要保持是一組RGBA4位的長度的倍數(shù),這樣在拿到每個點以后,通過下標(biāo)來分別獲取到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個字節(jié)表示一組RGBA數(shù)據(jù)
    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數(shù)據(jù)后,如果R、G、B均為 0 且透明度非 0,那么代表這個位置需要繪制氣泡了,繪制的氣泡大小隨機產(chǎn)生:

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);
}

氣泡兔:

總結(jié)

本小節(jié)就到此結(jié)束了,文中提到的加載圖片、獲取像素點、遍歷每個像素獲取RGBA數(shù)據(jù)都搞清楚了嗎?破解登錄時遇到的滑動驗證碼是不是也可以用到這里面的知識點呢?大家可以發(fā)散一下思維。再次祝各位同學(xué),兔年大吉、新春快樂~

以上就是復(fù)刻畫龍產(chǎn)品vue實現(xiàn)新春氣泡兔的詳細(xì)內(nèi)容,更多關(guān)于vue新春氣泡兔的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue+element UI實現(xiàn)樹形表格

    vue+element UI實現(xiàn)樹形表格

    這篇文章主要為大家詳細(xì)介紹了vue+element UI實現(xiàn)樹形表格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • ElementUI修改實現(xiàn)更好用圖片上傳預(yù)覽組件

    ElementUI修改實現(xiàn)更好用圖片上傳預(yù)覽組件

    這篇文章主要為大家介紹了ElementUI修改實現(xiàn)更好用圖片上傳預(yù)覽組件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Uniapp設(shè)置頁面的背景圖片方法代碼

    Uniapp設(shè)置頁面的背景圖片方法代碼

    這篇文章主要給大家介紹了關(guān)于Uniapp設(shè)置頁面的背景圖片,uni-app中設(shè)置背景圖有兩種方式,分別是全局設(shè)置和在相應(yīng)的view內(nèi)設(shè)置背景,文中給出了代碼示例,需要的朋友可以參考下
    2024-03-03
  • Vue?和?Django?實現(xiàn)?Token?身份驗證的流程

    Vue?和?Django?實現(xiàn)?Token?身份驗證的流程

    這篇文章主要介紹了Vue?和?Django?實現(xiàn)?Token?身份驗證?,Vue.js?和?Django?編寫的前后端項目中,實現(xiàn)了基于?Token?的身份驗證機制,其他前后端框架的?Token?實現(xiàn)原理與本文一致,需要的朋友可以參考下
    2022-08-08
  • elementUI使用el-upload上傳文件寫法及避坑總結(jié)(上傳圖片/視頻到本地/服務(wù)器及回顯+刪除)

    elementUI使用el-upload上傳文件寫法及避坑總結(jié)(上傳圖片/視頻到本地/服務(wù)器及回顯+刪除)

    upload上傳是前端開發(fā)很常用的一個功能,下面這篇文章主要給大家介紹了關(guān)于elementUI使用el-upload上傳文件寫法及避坑的相關(guān)資料,包括上傳圖片/視頻到本地/服務(wù)器及回顯+刪除,需要的朋友可以參考下
    2023-03-03
  • vue3實現(xiàn)v-model原理詳解

    vue3實現(xiàn)v-model原理詳解

    這篇文章主要介紹了vue3實現(xiàn)v-model原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue.js 初體驗之Chrome 插件開發(fā)實錄

    vue.js 初體驗之Chrome 插件開發(fā)實錄

    這篇文章主要介紹了vue.js 初體驗之Chrome 插件開發(fā)實錄 ,需要的朋友可以參考下
    2017-05-05
  • vue踩坑記錄:屬性報undefined錯誤問題

    vue踩坑記錄:屬性報undefined錯誤問題

    這篇文章主要介紹了vue踩坑記錄:屬性報undefined錯誤問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue-cli配置flexible過程詳解

    vue-cli配置flexible過程詳解

    這篇文章主要介紹了vue-cli配置flexible過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • Vue看了就會的8個小技巧

    Vue看了就會的8個小技巧

    這篇文章主要介紹了玩轉(zhuǎn)Vue的8個小技巧,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2021-01-01

最新評論