Skip to content
ts
import { Assets, Sprite } from 'pixi.js'
import type { Application } from 'pixi.js'
import { type Fish, addFishes, animateFishes } from './addFishes'

// Store an array of fish sprites for animation.
export const fishes: Fish[] = []

async function preload() {
  const assets = [
    { alias: 'background', src: 'https://pixijs.com/assets/tutorials/fish-pond/pond_background.jpg' },
    { alias: 'fish1', src: 'https://pixijs.com/assets/tutorials/fish-pond/fish1.png' },
    { alias: 'fish2', src: 'https://pixijs.com/assets/tutorials/fish-pond/fish2.png' },
    { alias: 'fish3', src: 'https://pixijs.com/assets/tutorials/fish-pond/fish3.png' },
    { alias: 'fish4', src: 'https://pixijs.com/assets/tutorials/fish-pond/fish4.png' },
    { alias: 'fish5', src: 'https://pixijs.com/assets/tutorials/fish-pond/fish5.png' },
    { alias: 'overlay', src: 'https://pixijs.com/assets/tutorials/fish-pond/wave_overlay.png' },
    { alias: 'displacement', src: 'https://pixijs.com/assets/tutorials/fish-pond/displacement_map.png' },
  ]
  await Assets.load(assets)
}

function addBackground(app: Application) {
  const background = Sprite.from('background')
  background.anchor.set(0.5)

  if (app.screen.width > app.screen.height) {
    background.width = app.screen.width * 1.2
    background.scale.y = background.scale.x
  }
  else {
    background.height = app.screen.height * 1.2
    background.scale.x = background.scale.y
  }

  background.x = app.screen.width / 2
  background.y = app.screen.height / 2

  app.stage.addChild(background)
}

export async function createFishPond(app: Application) {
  await preload()

  // add background
  addBackground(app)
  addFishes(app, fishes)

  app.ticker.add(time => animateFishes(app, fishes, time))
}

export default createFishPond