-
-
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
Pitch adjustment #329
Comments
i think you should add it to android and then some time later implement it on iOS |
True. I should probably mention that all new features from this point will only be developed on the null-safe branch (i.e. the 0.7.* releases). For now, this will require the beta channel of the Flutter SDK, although stable is coming soon. |
Note to self. This API might integrate well with AVQueuePlayer: (Though I'm not particularly happy with the quality of iOS's pitch/time stretching algorithms, if the above works, I may as well use it.) |
This would be another massive winner for me. Any eta? As with the equalizer functionality, happy to offer a bounty to bump the priority. |
Hi @leidig54 Thanks again for offering to support the project! I will ordinarily prioritise features based on the number of thumbs up and their difficulty, although I also tend to prioritise requests from GitHub sponsors too (otherwise, you're welcome to discuss by email - the address can be found in the git log). The next two big features I plan to work on are the visualizer and equalizer, but I may throw the pitch shifting feature into that group, too, since there may be some overlap in the section of code involved on the iOS side. |
It definitely has overlap with what's happening on the |
As I originally suspected, this feature would best be handled by a move to AVAudioEngine on iOS. Although there might be ways to get this to work with AVQueuePlayer, maybe it is finally time to make the switch to AVAudioEngine, given that a lot of the popular feature requests at the moment involve audio processing. This would also allow complete control over audio interruptions since AVQueuePlayer is hardcoded to take over this responsibility. There are some existing libraries built over the top of AVAudioEngine that could make things easier, which I will have a look at first. For example, AudioKit seems to provide everything we need in terms of audio processing, and there are others (and there's the option of just using the AVAudioEngine API directly), but I will just need to evaluate these options based on how well they support the complete just_audio feature set. I'd estimate the rewrite of existing features at maybe 1-to-2 months at a minimum, if worked on full time, after which I would expect pitch shifting to be an extra couple of days on top of that. Given that, I think I may go ahead and release the feature for Android first. |
i really love the direction you are taking in working on your audio plugins, and how you implement features. these are by far the most mature and will-maintained flutter plugins |
The Android implementation is now available for testing on the |
For the first time with this project I'm starting to feel the need for a |
@ryanheise completely agreed with you here, just a suggestion we can also update the readme for the new features in branch. Also eady to support the project, for the good work you are doing. |
|
(Copying this comment from another issue to get broader interest)
The waveform visualizer is implemented on iOS but not pitch. You can track the pitch feature here: #329 There is a big question at this point whether to continue with the current AVQueuePlayer-based implementation or switch to an AVAudioEngine-based implementation. For pitch scaling, I really want to take advantage of AVAudioEngine's built-in features, but that requires a rewrite of the iOS side - see #334 and this is a MUCH bigger project. I would really like to see an AVAudioEngine-based solution see the light of day, but it will probably not happen if I work on it alone. If anyone would like to help, maybe we can pull it off with some solid open source teamwork. One of the attractive solutions is to use AudioKit which is a library built on top of AVAudioEngine which also provides access to pitch adjustment AND provides a ready-made API for a visualizer and equalizer. That is, it provides us with everything we need - BUT it is written in Swift and so that involves a language change and it means we may need to deal with complaints that old projects don't compile (we'd need to provide extra instructions on how to update their projects to be Swift-compatible). Would anyone like to help me with this? (Please reply on #334) |
Does it possible to use BASS or Superpowered(best for pitch shifting) or you would like to implement this by yourself? |
@smakarov this should be relatively straightforward to do once the AVAudioEngine / AudioKit implementation is done. See: https://audiokit.io/playgrounds/Playback/Time%20Stretching%20and%20Pitch%20Shifting/ So the main effort will go into #334 itself. |
Is it also possible to get the pitch of recorded audio? BTW, this plugin very helpful, thanks for developing it :) |
Hi, |
@gkmuhannad this is already implemented on Android (on the |
Great😍.. Thank you so much
Get Outlook for iOS<https://aka.ms/o0ukef>
…________________________________
From: ryanheise ***@***.***>
Sent: Sunday, June 20, 2021 5:18:01 PM
To: ryanheise/just_audio ***@***.***>
Cc: Almuhannad Ghaleb ***@***.***>; Mention ***@***.***>
Subject: Re: [ryanheise/just_audio] Pitch adjustment (#329)
@gkmuhannad<https://github.com/gkmuhannad> this is already implemented on Android (on the dev branch), iOS will take quite a while longer. I will publish a release including the Android implementation as soon as I update the unit tests.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub<#329 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/ATI3EV23IRT7QN47EVWTCTLTTX2BTANCNFSM4YQ52OGQ>.
|
The Android implementation is now published in release 0.8.0. |
@ryanheise |
Always happy to help |
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
Any update on this topic? I need a package to manage pitch and tune, any suggestion? |
There is some progress being made in #334 on an AVAudioEngine-based implementation. This should make it much easier to implement this functionality on iOS. Some notes for implementation, these are the classes to look at to adjust the speed and pitch of audio:
|
@ryanheise I'm having trouble trying to use it in the version 0.9.20. Is there a way to raise a song pitch just one half step? I mean, a song in C goes to C#? Thank you the amazing work you have been doing to the community. We very much appreaciate it. |
I guess you want to know the formula to map a semitone into a pitch adjustment scale. I don't actually know, because the underlying native API just says this scale is "the factor by which pitch will be shifted". An answer to this question will depend on the answer to the same question for native app developers, so I would suggest Googling for that. And if you don't find anything, I would suggest doing a little bit of experimentation and mathematics. E.g. what does a factor of 2x give you? Is it just doubling the frequency? If so, that's a starting point for your calculation. |
@ryanheise the pitch adjustment doesn't work on android when using just_audio_background? It shows UnimplementedError, but it worked for me before using background plugin. |
Thanks for reporting, @akshdeep-singh . Actually there are several methods not implemented by just_audio_background:
I'll implement these at my next opportunity. |
any update for web platform? |
It's one of the next items on my list, although my main computer has been down so not yet. |
Sorry I meant to say that fixing @akshdeep-singh I have fixed the unimplemented methods in just_audio_background now. Can you try out the fix in the |
Regarding |
@ryanheise I have verified pitch change, it's working for me. Thanks for your support. |
Thank you very much for creating such a great library. I would like to know the current status of this issue. Could anyone please update? Thanks again. |
I promise that my comments above truthfully reflect the status, as does the README page. |
I can see I'm running an app on an iOS simulator and I'm encountering this issue
It seems the issue occurs due to the Is there a way to avoid the |
Since the platform support is not equal, you can write code like this: if (Platform.isAndroid) {
await _player.setPitch(pitch);
} If you're also cross compiling to web, then you can do this: if (!kIsWeb && Platform.isAndroid) {
await _player.setPitch(pitch);
} |
I'm not calling |
There is the following code in try {
await platform.setPitch(SetPitchRequest(pitch: pitch));
} catch (e) {
// setPitch not supported on this platform.
} So here the exception is handled. Are you sure that this is the call site that is causing the issue? Maybe you're actually using a different plugin such as just_audio_background? Can you reproduce this with one of the official example project, and if so, can you tell me which one and how to reproduce it? |
I'm using I tried the official example and I modified the line where the audio source is set to
and I'm encountering the same error
There might be an issue on my side because the actual URL doesn't contain the file extension and I added the extension to the URL (I mean in the Flutter app) Is there a way to specify the file extension? LE: I added |
@alexgrusu Would you mind opening a new bug report? I don't think this issue is specifically related to the |
Sounds good, I will open a different bug. Might be my approach wrong? I mean, setting the |
any update of pitch change on iOS? |
This is something that would require an AVAudioEngine-based implementation. You could take a look at #784 as a starting point, and consider contributing to it to add pitch adjustment. |
@ryanheise Hello. I could not find any documentation on setPitch(). What do i have to pass as argument to setPitch() ? What would be the factor, in order to shift pitch by one semitone. In android flutter app, just |
It should be there on https://pub.dev/packages/just_audio under the link "API Documentation". Find the class (i.e. AudioPlayer), then find the thing inside the class (i.e. setPitch). The README page gives the supported platforms (as mentioned above, only Android).
That same comment above confirms this is correct. |
Thank you for such a prompt reply. You have done great service to flutter community. |
@ryanheise any update on |
The iOS side depends on rewriting using AVAudioEngine (see #334 for further details) |
Is your feature request related to a problem? Please describe.
Pitch adjustment would be useful in some apps (e.g. changing pitch of voice or music).
Describe the solution you'd like
Describe alternatives you've considered
There is no other way to achieve this other than plugin support.
Additional context
This is easily implemented on Android, iOS might be more problematic (post below if you are able to share useful resources/documentation)
The text was updated successfully, but these errors were encountered: