Generate waveform images from audio files within Carrierwave
Add this line to your application's Gemfile:
gem 'carrierwave-audio-waveform'
And then execute:
$ bundle
Or install it yourself as:
$ gem install carrierwave-audio-waveform
First, install SoX on your local environment and production servers.
Second, install Audio Waveform on your local environment and production servers if you plan to generate waveform data rather than an image.
Lastly, include CarrierWave::AudioWaveform in your CarrierWave uploader class:
class AudioUploader < CarrierWave::Uploader::Base
include CarrierWave::AudioWaveform
end
See the sections below for specific implementations.
To generate a PNG image:
class AudioUploader < CarrierWave::Uploader::Base
include CarrierWave::AudioWaveform
version :waveform_image do
process :waveform => [{
background_color: :transparent,
color: "#666",
sample_width: 2,
gap_width: 2,
height: 75,
width: 1500
}]
def full_filename(for_file)
"#{super.chomp(File.extname(super))}.png"
end
end
end
Note: Make sure to install Audio Waveform on your local environment and production servers if you plan to generate waveform data.
To generate an array of waveform data:
class AudioUploader < CarrierWave::Uploader::Base
include CarrierWave::AudioWaveform
version :waveform_peak_data do
process :waveform_data => [{
convert_to_extension_before_processing: :wav,
pixels_per_second: 10
}]
def full_filename(for_file)
"#{super.chomp(File.extname(super))}.json"
end
end
end
Parameter | Description | Permitted Values | Default |
---|---|---|---|
convert_to_extension_before_processing |
Useful if .wav or .mp3 isn't being passed in as the source file--you can convert to the specified format first before reading the peaks. |
Symbol (:wav or :mp3 ) |
nil |
set_extension_before_processing |
This is useful because CarrierWave will send files in with the wrong extension sometimes. For instance, if this is nested under a version, that version may be an .mp3 , but its parent might be .wav , so even though the version is a different extension, the file type will be read from the original file's extension (not the version file) if you don't set this parameter. |
Symbol (:wav or :mp3 ) |
nil |
pixels_per_second |
The number of pixels per second to evaluate. | Integer | 10 |
bits |
8- or 16-bit precision | Integer (8 or 16 ) |
16 |
logger |
IOStream to log progress | IOStream | nil |
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request