The original address: www.joshwcomeau.com/react/annou…
By Josh Comeau
Reprint is prohibited without authorization.
Read the instructions before
Some of the audio demos involved in this translation need to be tried out in the original.
Highly recommended to try oh ~ (need to climb the wall)
introduce
Probably because I’m an audio engineer, I’m looking forward to hearing more sound in the browser.
I know a lot of people are going to argue with me at this point, in large part because audio has been used so badly in browsers that some people find it annoying to hear sound in the browser.
Early encounters with audio tend to be in the following situations:
- Older browsers used MIDI files as background music ðº
- Audio has been used for nefarious purposes to grab users’ attention and make scams more believable ð
- There are also autoplay videos and so on ð¬
But I think the idea can be saved. I believe sound can accentuate user behavior, enhance feedback, and add some joy to boring user behavior. When the sound is used elegantly, the product will be more real, more lifelike.
Adding sound to projects is not a new idea: web games, for example, or mobile apps have long used sound to enhance user interaction. In fact, the Web is weird, and every digital medium I can think of uses sound, right? Do you think so?
When I set up this blog, I wanted to start this experiment. In my blog, there are many UI components that make sounds when you interact with them
Go for it!
You can try clicking on the top right corner of the blog.
Or try the original online code editing area, which is really fun!
Because sound effects are so few and far between on the browser, playing them feels like a particularly appealing “ear ball.” So as long as the sound is used in the right project, it can be an absolute secret weapon to everybody’s surprise!
To make it easy for you to get started, I have posted the hook, use-sound, of this blog to NPM. This blog will let you know what it can do as soon as possible, and I’ll share some tips on how to use sound properly on the Web.
Go straight to the document?
If you want to use this hook directly, you can jump directly to the GITHUB link
An overview of the
Use-sound is a React Hook that allows you to play sound effects. Here’s a simple example:
import useSound from 'use-sound';
import boopSfx from '.. /.. /sounds/boop.mp3'; // Import your own audio
const BoopButton = () = > {
const [play] = useSound(boopSfx);
return <button onClick={play}>Boop!</button>;
};
Copy the code
UseSound asynchronously loads a 10KB third-party dependency package Howler, but only enlarges your package by about 1KB.
It offers a bunch of cool stuff, including:
- Stop the sound early or pause/replay the sound.
- Load up one Sprite audio and split it into many individual sounds.
- Speed up or slow down the sound.
- Have a lot of events!
- There are many, many more advanced things Howler implements.
If you want to see more sophisticated usage or API details, you can check out the documentation here.
Let’s get started!
The installation
The first step is to install the package via NPM or Yarn:
# to use YARN
yarn add use-sound
# or, use NPM
npm install use-sound
Copy the code
The import
This package exports only one default hook, useSound:
import useSound from 'use-sound';
Copy the code
Before using this hook, you also need to import your audio files.
If you’re using scaffolding like create-react-app/Gatsby, you should be able to import MP3 files in the same way you import images or other media:
import boopSfx from '.. /.. /sounds/boop.mp3';
Copy the code
If you are tinkering with your own Webpack configuration, you can use file-loader to make.mp3 files arbitrary.
Good front end sound!
Knowing how to install dependencies and write code is only half the battle; We also need to prepare some beautiful music!
My favorite resource is freesound.org. Almost all of the blog’s audio comes from this site. You need to register an account first to download their resources, everything is free.
Be prepared to find music. A lot of the audio on the site isn’t very clear,
Maybe it’s like looking for a needle in a haystack
To prepare the audio
There’s a lot of audio from Freesound.org that we need to deal with first:
- Some chords, for example, are broken when the audio plays. You need to crop them so that they can be heard immediately after the sound is triggered.
- If the volume of some audio goes up and down, you’ll have to adjust the volume of the audio to be consistent.
- Download the audio format may be different, you also need to convert to MP3 format ~
Do all of the above and your audio will be perfect
You can use a free, open source, cross-platform audio editor to edit your downloaded audio
I recommend Audacity.
The translator found this download address on Baidu: audacity.onl/
Of course, learning how to use Audacity isn’t the focus of this blog, but there are plenty of free resources out there to learn how to use it.
Why do you have to use MP3?
Long ago, there wasn’t an audio format that was supported everywhere; People often use MP3, AIFF, or WAV to load different files in different environments.
Happily, MP3 is now supported by all major browsers, including Internet Explorer 9. Compared to other formats, MP3 can be compressed to a much smaller file size.
So I push MP3!
Audio ð & Accessibility â¿ïž & usability
Even if audio is supported on the web, I’ve noticed that there’s a subset of users who don’t care about it, who probably prefer to stay quiet.
For those with impaired vision, screen reading software is commonly used to access the web. If we put too many sound effects on the page, we may cause this user to be distracted while listening to what is being read.
For these reasons, it is important to have a mute button ð on your page. It’s also important to keep the mute “on” so that users don’t have to repeatedly set whether or not to mute it.
In contrast, for hearing-impaired users, they can’t detect whether the sound is being triggered. Therefore, we should never use audio alone to convey important information. If you are using sound effects as a way to give feedback to your users, make sure you have visual feedback as well. This way, the page can be 100% usable without sound.
Sticky is another article by the author,
If you are interested, you can like it in the comments section
A profound
Please visit the author’s blog to try out different online demos
Don’t forget to turn on the sound of your local device
1. Checkbox
When I click on this checkbox, I have been top goippy-ã feeling!! If you have a mouse or touch pad, try one quick click, then one slow click, and listen to their sound effects.
Code:
function Demo() {
const [isChecked, setIsChecked] = React.useState(
false
);
const [playActive] = useSound(
'/sounds/pop-down.mp3',
{ volume: 0.25});const [playOn] = useSound(
'/sounds/pop-up-on.mp3',
{ volume: 0.25});const [playOff] = useSound(
'/sounds/pop-up-off.mp3',
{ volume: 0.25});return (
<Checkbox
name="demo-checkbox"
checked={isChecked}
size={24}
label="I agree to self-isolate"
onChange={()= >setIsChecked(! isChecked)} onMouseDown={playActive} onMouseUp={() => { isChecked ? playOff() : playOn(); }} / >
);
}
Copy the code
2. Interactive audio
Sometimes you just want the sound to be played during the interaction. Note that the following demo sound is played only when hover:
Code:
function Demo() {
const soundUrl = '/sounds/rising-pops.mp3';
// You can change the resource 'rising-pops' into the following audio resource to listen to it
// - fanfare
// - dun-dun-dun
// - guitar-loop
const [play, { stop }] = useSound(
soundUrl,
{ volume: 0.5});const [isHovering, setIsHovering] = React.useState(
false
);
return (
<Button
onMouseEnter={()= > {
setIsHovering(true);
play();
}}
onMouseLeave={() => {
setIsHovering(false);
stop();
}}
>
<ButtonContents isHovering={isHovering}>
Hover over me!
</ButtonContents>
</Button>
);
}
Copy the code
3. Progressively rising scales
I added an interesting trick to the “like” button: Each click would have a higher audio scale than the previous click. Here’s how I did it:
Code:
function Demo() {
const soundUrl = '/sounds/glug-a.mp3';
const [playbackRate, setPlaybackRate] = React.useState(0.75);
const [play] = useSound(soundUrl, {
playbackRate,
volume: 0.5});const handleClick = () = > {
setPlaybackRate(playbackRate + 0.1);
play();
};
return (
<Button onClick={handleClick}>
<span role="img" aria-label="Heart">
ð
</span>
</Button>
);
}
Copy the code
4. Play/pause button
You can use this play button to create a new netease music hahaha.
Code:
function Demo() {
const soundUrl = '/sounds/guitar-loop.mp3';
const [play, { stop, isPlaying }] = useSound(soundUrl);
return (
<PlayButton
active={isPlaying}
size={60}
iconColor="var(--color-background)"
idleBackgroundColor="var(--color-text)"
activeBackgroundColor="var(--color-primary)"
play={play}
stop={stop}
/>
);
}
Copy the code
Sprite audio
If your component is going to use a lot of sound effects, I suggest you use Sprite audio oh ~ Sprite audio is an audio file that contains a lot of different sound effects. By combining the audio into a single file, we can write more elegant code and prevent many parallel HTTP requests.
Here we use a Sprite audio to build a disc player! Try clicking one of these buttons, or click 1234 on your keyboard and have a listen!
Code:
function Demo() {
const soundUrl = '/sounds/909-drums.mp3';
const [play] = useSound(soundUrl, {
sprite: {
kick: [0.350].hihat: [374.160].snare: [Awesome!.290].cowbell: [968.200]}});// Custom hook that listens for 'keydown',
// and calls the appropriate handler function.
useKeyboardBindings({
1: () = > play({ id: 'kick' }),
2: () = > play({ id: 'hihat' }),
3: () = > play({ id: 'snare' }),
4: () = > play({ id: 'cowbell'})})return (
<>
<Button
aria-label="kick"
onMouseDown={()= > play({ id: 'kick' })}
>
1
</Button>
<Button
aria-label="hihat"
onMouseDown={()= > play({ id: 'hihat' })}
>
2
</Button>
<Button
aria-label="snare"
onMouseDown={()= > play({ id: 'snare' })}
>
3
</Button>
<Button
aria-label="cowbell"
onMouseDown={()= > play({ id: 'cowbell' })}
>
4
</Button>
</>
);
}
Copy the code
See the API documentation for more details on Sprite Audio
Million possibilities
Exploring sound on the web really struck me because there was so much unexplored territory!! I’ve been experimenting with audio on the web for a while now, but I feel like I’ve barely scratched the surface.
Now that you have the tools to start experimenting, I hope to encourage you to give it a try and see how far you can go ð
You can learn more about use-Sound hook on GitHub