-
Notifications
You must be signed in to change notification settings - Fork 90
Is there a way to detect long press of volume button? #27
Comments
I haven't used this library myself for a few years now, so I'm not sure how you could go about doing this. I hope someone else who's used it more actively recently can chime in. Maybe @joestelmach? |
I think you'll continue to get notifications when you hold the button down, so you can do something like this:
You'll need some way of counting as well, since the timer will fire even if there's only one invocation of onVolumeUp Keep in mind that the onVolumeUp method will need to run on the same thread every time for the invalidate call to work (https://developer.apple.com/library/mac/documentation/Cocoa/Reference/Foundation/Classes/NSTimer_Class/) |
Thanks man! This works! |
@joestelmach Please excuse me for asking, Your solution works perfectly, and you are right, it also fires on short press of the button. Any hint as to how I can implement counting to differentiate between long and short press? Thanks! |
I did this but it's not working properly:
The DO SOMETHING block fires only when I release the button after long press. What happening is, I believe, that Any guides how can I fix this? @joestelmach Thanks in anticipation :) |
you just need to incremement a count within the |
Tried. Same issue. When release the button after long press, it fires the desired method. :( |
Still waiting for any more help :( |
paste your code and let's look at it |
|
How will secondsElapsed ever be greater than 1? |
Sorry.Edited.Please,check |
Hi, maybe this is a bit late, but maybe someone might find useful. If you would like to have methods called when there is long press detected you might verify secondsElapsed in onVolumeUp method like this:
}` |
@timov7 let me try and get back. Did you try it urself though? |
Yes, it is working for me. |
It looks good enough to detect long press yes. But does it also help u detect short press? |
You can detect short press in onTimeFire method
}` |
Hey @timov7 .. your solution does work, however it is never going in the following block
|
Yes, you need to make timer nil each time onTimeFire gets called. Otherwise secondsElapsed will increase continuously in onVolumeUp method. |
Still confused lol ... But thanks a lot for pitching in :) |
I am happy to help. :) See my edited answer for onTimeFire method. |
No description provided.
The text was updated successfully, but these errors were encountered: