Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
15
Help us understand the problem. What is going on with this article?
@tbaba

JavaScriptでAudioを操作する

More than 5 years have passed since last update.

自分のバンド用に音楽共有サービスを作ってるんだけど、やっぱりwebだけで視聴とかもしたいわけで。
HTML5のaudioタグを使うのも手なんだけど、やっぱりちょっとケータイからは使いづらい。

そこで、Audioクラスを使ってJavaScriptで操作する、みたいなことをやってみることにしたので、その備忘録的なアレ。

とりあえずコーヒー置いときますね

コードに粗があったり汚かったり使い方間違ってたりしたら指摘していただきたく。

class AudioPlayer
  constructor: (el) ->
    @el = $(el)
    @src = @el.find('audio')
    @playButton = @el.find('.play')
    @pauseButton = @el.find('.pause')
    @volumeBar = @el.find('.volume')
    @seekBar = @el.find('.duration')

    @pauseButton.hide()

    @audio = new Audio
    @audio.src = @src.attr('src')
    @audio.volume = 1.0

    @handleAudio()

    @audio.load()

  play: (ev) =>
    ev.preventDefault()
    @audio.play()
    @playButton.hide()
    @pauseButton.show()

  pause: (ev) =>
    ev.preventDefault()
    @audio.pause()
    @playButton.show()
    @pauseButton.hide()

  updateCurrentTime: =>
    current = @audio.currentTime
    @seekBar.val Math.ceil(current)

  updateTimeWithEnd: =>
    @seekBar.val(0)
    @audio.currentTime = 0
    @playButton.show()
    @pauseButton.hide()

  changeVolume: =>
    @audio.volume = @volumeBar.val() / 100

  handleAudio: =>
    @playButton.on 'click', @play
    @pauseButton.on 'click', @pause
    @volumeBar.on 'change', @changeVolume
    a = $(@audio)

    a
      .on 'loadeddata', =>
        @seekBar.attr('max', Math.ceil(@audio.duration))
      .on 'timeupdate', =>
        @updateCurrentTime()
      .on 'ended', =>
        @updateTimeWithEnd()

    @seekBar.on 'change', =>
      time = @seekBar.val()
      console.log time
      @audio.currentTime = time

こんな感じで、ちょっとデザインとか整えたりすると、こうなる。
uploada_tracks_show.png

Audioについて説明

Audioクラスは、JavaScriptから音楽ファイルを上手いこと扱うためのもので、例えばplay()とかpause()とかっていうファンクションがある。

audio = new Audio

みたいな感じで使って、

audio.src = "音楽ソースのパス"

で音楽ファイルを指定する。そんで、

audio.play()

とかやってやればなんとなくファイルが再生される、という仕組み。

書き途中だけど眠くなってきたので風呂入って寝る。(でも公開はする

15
Help us understand the problem. What is going on with this article?
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
tbaba
プログラマー。ウェブアプリケーションとか。 https://forkwell.com の中の人。仕事道具は VSCode と Git。Git は綺麗な歴史を作る派。
grooves
エンジニア向けサービス「Forkwell」などを開発・運営しています。

Comments

No comments
Sign up for free and join this conversation.
Sign Up
If you already have a Qiita account Login
15
Help us understand the problem. What is going on with this article?