亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > canvas版人體時鐘的實現示例

canvas版人體時鐘的實現示例

熱門標簽:通遼地圖標注app 江西ai電銷機器人如何 地圖標注員工作內容 中國地圖標注城市的 高德地圖標注廁所 威海語音外呼系統平臺 智能語音電銷機器人客戶端 地圖標注沿海城市房價 西安金倫外呼系統

不知道老網民們還記不記得這個魔性的時鐘插件:

作為網上沖浪十數載的網蟲,不久前看到這個圖瞬間破防,直接夢回10年前的QQ空間,感嘆一下歲月蹉跎、時光荏苒、青春不在、不勝唏噓。

十年后的今天,flash在各個瀏覽器都已經不再支持,已經是個不再那個只會用腳本打扮QQ空間的我,自然得用青春換來得技術還原一下自己的青春記憶。

首先感謝原作者提供的如此優秀好玩的插件: http://chabudai.org/blog/?p=59

這次為了圖方便,就直接那pixi.js來上手做動畫了,動畫素材來源于油管視頻,拿到PS逐幀摳圖并導出,這個過程就不再詳細介紹了。合成后的精靈圖以及對應的json文件我會放在文章末尾。

核心的API是PIXI.AnimatedSprite。

代碼也是很短,就直接放到下面了

<!doctype html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>HoneHoneClock</title>
  <style>
    * {
      padding: 0;
      margin: 0;
    }
    html, body {
      width: 100%;
      height: 100%;
    }
    body {
      background-color: lightcyan;
    }
    canvas {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      z-index: 1;
    }
  </style>
</head>
<body>
<canvas class="canvas"></canvas>
<script src="pixi_5.3.4.min.js"></script>
<script src="Stats.min.js"></script>
<script>

  (async function () {
    const stats = new Stats()
    document.body.appendChild(stats.domElement)

    let pageWidth = 0
    let pageHeight = 0

    let clockHour1, clockHour2
    let clockMin1, clockMin2
    let clockSec1, clockSec2
    const $canvas = document.querySelector('canvas')
    const renderer = new PIXI.Renderer({
      view: $canvas,
      width: pageWidth,
      height: pageHeight,
      transparent: true,
      autoDensity: true,
      antialias: true
    })

    // 人體時鐘
    class Clock extends PIXI.Container {
      constructor (name) {
        super()
        const textures = loader.resources[honeHoneClockJson].textures
        let frames = []
        let aniData = []
        if (this.frames) {
          frames = this.frames
          aniData = this.aniData
        }
        else {
          aniData = [
            {
              prefix: '0',
              count: 6,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '1',
              count: 9,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '2',
              count: 7,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '3',
              count: 6,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '4',
              count: 9,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '5',
              count: 14,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '6',
              count: 7,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '7',
              count: 10,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '8',
              count: 7,
              frameFrom: -1,
              frameTo: -1,
            },
            {
              prefix: '9',
              count: 9,
              frameFrom: -1,
              frameTo: -1,
            },
          ]
          let k = 0
          for (let i = 0; i < aniData.length; i++) {
            const data = aniData[i]
            data.frameFrom = k
            for (let j = 1; j <= data.count; j++) {
              k++
              frames.push(textures[`${data.prefix}(${j}).png`])
            }
            data.frameTo = k - 1
          }
          this.frames = frames
          this.aniData = aniData
        }
        const ani = new PIXI.AnimatedSprite(frames)
        ani.anchor.set(0.5, 1)
        ani.animationSpeed = 0.4

        this.stopAt = -1
        ani.onFrameChange = () => {
          if (ani.currentFrame === this.stopAt) {
            ani.stop()
          }
        }
        this.addChild(ani)
        this.name = name
        this.ani = ani
        this.num = -1
      }

      set number (number) {
        if (this.num !== number) {
          this.num = number
          this.stopAt = this.aniData[number].frameTo
          this.ani.gotoAndPlay(this.aniData[number].frameFrom)
        }
      }
    }

    const stage = new PIXI.Container()
    stage.name = 'stage'
    let clockWrap

    const ticker = new PIXI.Ticker()
    let now = new Date()
    let lastTime = now.getTime()
    const loop = function () {
      stats.begin()
      now = new Date()
      if (now.getTime() - lastTime >= 1000) {
        let hours = now.getHours()
        if (hours > 9) {
          clockHour1.number = Math.floor(hours / 10)
          clockHour2.number = hours % 10
        }
        else {
          clockHour1.number = 0
          clockHour2.number = hours
        }

        let minutes = now.getMinutes()
        if (minutes > 9) {
          clockMin1.number = Math.floor(minutes / 10)
          clockMin2.number = minutes % 10
        }
        else {
          clockMin1.number = 0
          clockMin2.number = minutes
        }

        let seconds = now.getSeconds()
        if (seconds > 9) {
          clockSec1.number = Math.floor(seconds / 10)
          clockSec2.number = seconds % 10
        }
        else {
          clockSec1.number = 0
          clockSec2.number = seconds
        }
        lastTime = now.getTime()
      }
      renderer.render(stage)
      stats.end()
    }

    ticker.add(loop)

    const honeHoneClockJson = 'HoneHoneClock.json'
    const loader = new PIXI.Loader()
    loader.add([honeHoneClockJson])
    loader.onComplete.add(async (res) => {
      clockWrap = new PIXI.Container()
      clockWrap.position.set((pageWidth - 630) * 0.5, (pageHeight + 150) * 0.5)

      clockHour1 = new Clock('hour')
      clockHour2 = new Clock('hour')
      clockMin1 = new Clock('min')
      clockMin2 = new Clock('min')
      clockSec1 = new Clock('sec')
      clockSec2 = new Clock('sec')
      clockHour1.position.set(0, 0)
      clockHour2.position.set(100, 0)
      clockMin1.position.set(250, 0)
      clockMin2.position.set(350, 0)
      clockSec1.position.set(500, 0)
      clockSec2.position.set(600, 0)
      clockWrap.addChild(clockHour1)
      clockWrap.addChild(clockHour2)
      clockWrap.addChild(clockMin1)
      clockWrap.addChild(clockMin2)
      clockWrap.addChild(clockSec1)
      clockWrap.addChild(clockSec2)
      stage.addChild(clockWrap)

      // 開始動畫循環
      ticker.start()
    })
    loader.load()

    const onResize = (e) => {
      pageWidth = document.body.clientWidth
      pageHeight = document.body.clientHeight
      if (clockWrap) {
        clockWrap.position.set((pageWidth - 630) * 0.5, (pageHeight + 150) * 0.5)
      }
      renderer.resize(pageWidth, pageHeight)
    }

    onResize()

    window.onresize = onResize
  })()
</script>
</body>
</html>

完整代碼戳這里

在線演示1 、 在線演示2

到此這篇關于canvas版人體時鐘的實現示例的文章就介紹到這了,更多相關canvas人體時鐘內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持腳本之家!

標簽:眉山 崇左 青海 北海 晉中 阜陽 營口 河池

巨人網絡通訊聲明:本文標題《canvas版人體時鐘的實現示例》,本文關鍵詞  canvas,版,人體,時鐘,的,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas版人體時鐘的實現示例》相關的同類信息!
  • 本頁收集關于canvas版人體時鐘的實現示例的相關信息資訊供網民參考!
  • 推薦文章
    国产成+人+综合+亚洲不卡| 99久久网站| 欧美a免费| 精品国产一区二区三区国产馆| 国产91精品一区二区| 91麻豆高清国产在线播放| 天堂网中文在线| 日本伦理片网站| 999精品在线| 国产成人精品综合| 欧美激情影院| 久久99中文字幕| 91麻豆精品国产自产在线观看一区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 久久99中文字幕久久| 久久国产精品自由自在| 成人免费网站久久久| 精品视频在线观看一区二区三区| 欧美激情影院| 日韩在线观看视频黄| 日韩免费在线视频| 精品毛片视频| 免费毛片播放| 国产一区二区精品久久91| 日韩专区一区| 欧美激情一区二区三区视频| 国产精品自拍一区| 国产不卡高清| 亚洲精品永久一区| 亚洲女人国产香蕉久久精品| 欧美国产日韩精品| 欧美国产日韩精品| 一级毛片视频播放| 欧美国产日韩久久久| 一级片片| 精品视频在线观看一区二区| 国产不卡精品一区二区三区| 精品视频在线观看视频免费视频| 国产激情一区二区三区| 精品视频在线观看一区二区三区| 欧美一级视频免费| 日韩欧美一及在线播放| 香蕉视频久久| 91麻豆高清国产在线播放| 青草国产在线| 国产伦久视频免费观看视频| 国产一区二区精品尤物| 国产伦久视频免费观看 视频| 国产一区精品| 99热精品一区| 黄视频网站免费看| 国产不卡在线看| 亚洲天堂免费| 国产成人啪精品| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 久久国产精品自由自在| 日韩专区在线播放| 精品久久久久久免费影院| 国产成人精品综合久久久| 国产a视频| 欧美激情一区二区三区视频 | 亚欧乱色一区二区三区| 日韩专区一区| 99色播| 精品久久久久久影院免费| 美女被草网站| 青草国产在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产a视频精品免费观看| 国产精品免费久久| 精品久久久久久综合网| 精品国产一级毛片| 韩国妈妈的朋友在线播放| 成人高清视频在线观看| 国产麻豆精品免费视频| a级毛片免费全部播放| 九九热国产视频| 国产精品自拍在线观看| 国产伦精品一区三区视频| 日韩专区亚洲综合久久| 日本免费乱人伦在线观看| 国产精品1024在线永久免费| 精品久久久久久综合网| 久久成人综合网| 超级乱淫伦动漫| 91麻豆国产| 免费毛片播放| 亚洲爆爽| 久久国产精品永久免费网站| a级黄色毛片免费播放视频| 国产伦久视频免费观看视频| 可以在线看黄的网站| 成人a大片在线观看| 日韩一级黄色片| 精品国产香蕉伊思人在线又爽又黄| 91麻豆精品国产自产在线| 你懂的国产精品| 成人影视在线观看| 国产综合成人观看在线| 午夜激情视频在线观看 | 亚洲女人国产香蕉久久精品| 日韩免费在线观看视频| 精品在线视频播放| 欧美一区二区三区在线观看| 久久99中文字幕| 亚洲精品久久久中文字| 黄色免费网站在线| 国产不卡在线看| 天天做日日爱| 色综合久久天天综线观看| 欧美国产日韩一区二区三区| 欧美日本韩国| 免费的黄视频| 精品国产一级毛片| 高清一级毛片一本到免费观看| 日韩中文字幕在线播放| 天天色成人| 日韩在线观看免费| 韩国毛片免费| 成人免费网站久久久| 日韩免费在线观看视频| 成人高清视频在线观看| 久久精品欧美一区二区| 欧美日本免费| 99久久精品国产高清一区二区| 精品久久久久久中文| 中文字幕一区二区三区 精品 | 一级女性全黄久久生活片| 韩国三级一区| 欧美电影免费| 精品国产一区二区三区精东影业 | 欧美激情伊人| 99久久网站| 一级女人毛片人一女人| 91麻豆tv| 中文字幕97| 久久精品免视看国产明星| 欧美激情一区二区三区在线 | 精品视频一区二区三区| 国产成人啪精品| 可以免费看污视频的网站| 99热精品在线| 国产视频一区二区三区四区 | 91麻豆国产| 成人免费一级纶理片| 天天做人人爱夜夜爽2020 | 国产原创中文字幕| 国产91精品露脸国语对白| 亚洲 男人 天堂| 999精品视频在线| 久久精品免视看国产明星| 久久精品道一区二区三区| 韩国毛片基地| 久久成人综合网| 国产麻豆精品| 国产视频一区二区三区四区 | 免费一级片在线| 成人a大片高清在线观看| 精品国产香蕉在线播出| 欧美a级片免费看| 二级特黄绝大片免费视频大片| 欧美大片一区| 亚洲天堂免费| 欧美爱色| 99久久精品国产麻豆| 99久久精品国产国产毛片| 日韩在线观看免费完整版视频| 青青青草视频在线观看| 午夜激情视频在线播放| 91麻豆国产| 青青青草视频在线观看| 一级女人毛片人一女人| 中文字幕一区二区三区 精品| 天堂网中文在线| 黄色短视频网站| 国产福利免费视频| 尤物视频网站在线观看| 日韩在线观看视频网站| 久久99欧美| 国产成人精品综合在线| 黄色短视频网站| 欧美激情一区二区三区视频高清| 国产伦理精品| 天堂网中文在线| 日本在线不卡免费视频一区| 四虎论坛| 可以免费看污视频的网站| 九九精品久久| 你懂的国产精品| 日本特黄特色aaa大片免费| 欧美一级视频高清片| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 美女被草网站| 日本伦理片网站| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产精品免费精品自在线观看| 欧美a级片免费看| 二级特黄绝大片免费视频大片| 国产福利免费观看| 欧美18性精品|