Platform
Resources
Pricing
Sign in
Get started
Tom Sugden
Workspace
Fork
Public
By
Tom Sugden
Edited
Dec 25, 2022
1 fork
3 stars
1
Insert cell
Insert cell
viewof
playButton
=
Inputs
.
button
(
"Play"
)
Insert cell
Insert cell
song
=
FileAttachment
(
"SoundHelix-Song-1.mp3"
)
Insert cell
Insert cell
audioElement
=
{
const
url
=
await
song
.
url
(
)
;
return
html
`<audio src="${
url
}" crossorigin="anonymous"></audio>`
}
Insert cell
Insert cell
audioContext
=
{
const
context
=
new
AudioContext
(
)
;
const
track
=
context
.
createMediaElementSource
(
audioElement
)
;
track
.
connect
(
context
.
destination
)
;
return
context
;
}
Insert cell
Insert cell
{
if
(
playButton
>
0
)
{
if
(
audioContext
.
state
===
"suspended"
)
audioContext
.
resume
(
)
;
if
(
audioElement
.
paused
)
audioElement
.
play
(
)
else
audioElement
.
pause
(
)
;
}
}
Insert cell
Purpose-built for displays of data
Observable is your go-to platform for exploring data and creating expressive data visualizations. Use reactive JavaScript notebooks for prototyping and a collaborative canvas for visual data exploration and dashboard creation.
Try it for free
Learn more
Fork
View
Export
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
playButton
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
song
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
audioElement
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
audioContext
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML