-
-
Notifications
You must be signed in to change notification settings - Fork 690
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Audio processing and silence skips #307
Comments
This has been on my radar, and there is a relatively simple way of implementing this on Android. What has delayed things is:
But, if there is enough demand for this feature, I could start thinking about point 2, then point 2, then later point 3. If anyone stumbles upon this feature request and would like to help, it would certainly be helpful to post links below to sample code and tutorials on the web that implement this on iOS/macOS, preferably AVPlayer/AVQueuePlayer-based implementations. To start things off, here is an article on skipping silence using AVAudioPlayer: https://blog.breaker.audio/how-we-skip-silences-in-podcasts-with-avaudioplayer-69232b57850a |
On the iOS side, some information on volume boost: https://stackoverflow.com/questions/30238287/core-audio-audio-unit-to-boost-signal-level This would depend on #334 . |
The Android side of "skip silence" is now implemented in The volume boost feature needs some further thought on the API design front. iOS can represent all sorts of audio effects via AVAudioUnit, while Android can represent these via AudioEffect. I would like to create some similar type of generalisation in the just_audio API after analysing the commonalities between these two underlying frameworks. |
The plan is now to implement volume boost as part of #398 . |
#398 is now complete, with two initial AudioEffect implementations on the Android side: |
The Android implementation is now published in release 0.8.0. |
How can we apply LoudnessEnhancer to an AudioPlayer? |
oh nevermind, I think I figured it out:
|
Will the iOS be supported soon too? |
Hi @mhassan772 Audio processing on the iOS side is more complex, but should be made easier on the AVAudioEngine-based implementation (see #784 ). Still, this project is only possible through collaborative effort, and the iOS side is waiting for a contributor. As such, you may like to consider becoming a contributor yourself, to help implement the features you need and contribute them back to the project. |
…yanheise#307) * removed redundant artBitmapCache code
|
Is your feature request related to a problem? Please describe.
I'm always frustrated when I can't hear some of the words because I'm in a noisy space.
Sometimes the podcasts I listen to have lots of spaces in them and I'd like to not waste that time please
Describe the solution you'd like
A 'skip silences' feature which would examine the audio that is about to play. If it is longer than (xx) miliseconds and is below (yy) audio level, then skip the silent bit.
A 'voice boost' feature which adds some form of dynamic processing to the audio, artificially compressing the dynamic range to make it easier to hear in loud environments, or to compensate for crappy audio production. Should compress audio's peaks over a certain audio level, then boost it back up again to hit a standard level. Ideally that standard level should be the same level as other notifications on the phone.
Describe alternatives you've considered
(n/a)
Additional context
A relatively poor example of 'skip silences' is implemented in Google Podcasts. A much better example (and I don't know what they do differently) is implemented in Pocket Casts, and they have a setting to control the fierceness of it. A cleverer version is in Overcast, which I believe also uses speed control.
Pocket Casts has a nice example of audio compression / "voice boost".
These features are particularly useful for podcast playback; though you could see some benefit for dynamic compression within music playback too. An enterprising app could use the microphone input to understand the noisiness of the environment and automatically add processing to make it easier to hear.
The text was updated successfully, but these errors were encountered: