-
-
Notifications
You must be signed in to change notification settings - Fork 484
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
Support for MediaButton long press / hold / custom click timings - click API is not enough #1068
Comments
On Android, you can't intercept a long press anyway since the os intercepts it to open Google assistant. |
Thank you for your quick response. Well, that may be true for modern stock android devices, but for older or more specialized models this is not always the case. I'm developing for a variety of older devices (Audio players, Phones, Tablets) using Android 7 to 11 as well as custom Android roms (Graphene OS, Lineage OS), where this behaviour is either not available or can be turned off. Even on modern devices this behaviour is not always the default - some of them support long press within Audiobookshelf. However, even if the long press is not supported, I still think that it would be great to have a more fine grained access to the MediaButton click events - e.g. to support triple or quad clicks or more accurate or customized click timings. My use case is to recreate the iPod click profile as accurate as possible (because I'm used to it), but I would also like to create custom click profiles in my App, where the user is able to add custom settings for click timings, number of repetitions and as long as it would be supported long press times. Probably all it would take is a small extension for the listener and one line for android: @Override
public boolean onMediaButtonEvent(Intent mediaButtonEvent) {
if (listener == null) return false;
// TODO: use typesafe version once SDK 33 is released.
@SuppressWarnings("deprecation")
final KeyEvent event = (KeyEvent)mediaButtonEvent.getExtras().getParcelable(Intent.EXTRA_KEY_EVENT);
// new code (maybe the platform would also be a nice hint to handle different platforms)
listener.onMediaButtonEvent(event.getKeyCode(), event.getAction(), "android");
// new code end
// ...
} See audio_service/audio_service/android/src/main/java/com/ryanheise/audioservice/AudioService.java Line 955 in fa845f7
Thank you for making |
If you can submit a working pull request that most importantly doesn't break the existing functionality, I'll consider it. While click profiles are exactly what I want the flexibility to do, I did look into the long press but ever since Android decided to reserve the long press for themselves, I no longer consider this a personal priority. I'm (personally) fine with following android's latest rules. |
Ok I'll try to submit one, but since I'm pretty new to dart / flutter, it may never happen :) |
@ryanheise I hope What I did:
There are some missing comment adjustments I'd like to care of, but first I would like to get it working. Here is the current state of the planned pull request: https://github.com/ryanheise/audio_service/compare/minor...sandreas:feature_1068_keyup_keydown?expand=1 Would you mind take a quick look and tell me, what I am missing or if I forgot something? |
It's not the best answer one might hope for, but I will consider it if/when you manage to get it working (since deprecated features are not something I would personally invest time into.) |
For everyone who is also doing research, here are my findings so far:
However I managed to write a kotlin handler and tweaked the timings as good as possible for audiobookshelf-app. The click detection works ok-ish (accoeding to my logs), but I'm currently still working on the thread communicating with exoplayer. As soon as I have something working, I'll try to port this to a PR |
My audiobookshelf PR is here - mainly kotlin. I'll wait for the merge and further test results. |
Feature proposal
I would like to suggest an extended API for the
click(MediaButton b)
method, where it would be possible to handle raw MediaButton events (KeyUp, KeyDown) to support MediaButton long press. It could be a method like this:Motivating use case(s)
I would like to implement high precision timer events and a MediaButton long press / hold to implement features that are very specific to audio books.
I use an Android Audio Player (HiBy M300 and similar) with dedicated MediaButtons on the device and headset button support.
Unfortunately the current implementation of play/pause, next, previous is not very reliable when using a headset click remote.
What I would like to implement that does not work (like it works in the iPod Nano 7g):
The following works (kind of, a bit unreliable):
To my understanding, the reason, why this does not work, is the handling code here:
audio_service/audio_service/android/src/main/java/com/ryanheise/audioservice/AudioService.java
Line 985 in fa845f7
Only the
KeyEvent.ACTION_DOWN
is regarded, but there is at least one other event (KeyEvent.ACTION_UP
, see https://github.com/advplyr/audiobookshelf-app/blob/fc954a968b47c5f89c171b6cdf22bf38dcc7379a/android/app/src/main/java/com/audiobookshelf/app/player/MediaSessionCallback.kt#L164) that should be regarded.I think it would be enough to just pass the (mapped) raw event to an
audio_service
API method to make it work on Android.What do you think?
The text was updated successfully, but these errors were encountered: