-
Notifications
You must be signed in to change notification settings - Fork 13
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
Tap and Send immediately #2
Comments
https://github.com/evilC/TapHoldManager#syntax |
Thanks for your reply. I tried different parameters combinations, and ended up on this one:
It works, but still there's a delay on the actual keypress. I think that's because of the IF statement logic processing cost. The following code doesn't have a delay:
While this one have:
Do you have any suggestion on what can be done to improve this? |
Are you saying that there is a delay with the second example if you tap s, whereas there is no delay with the first example if you tap s? That would be odd.
and
? Upon re-reading the documentation, I think it was unclear. My description of what |
Also added Timelines section to try and explain it further |
Yes, the delay is real. In the first example, I can type just fine. As you can see, the letter S is delayed with the if condition. Indeed, very odd. I don't believe this is related to your library, but maybe some autohotkey behavior. About the docs, great job! It is clearer than before, and that flowchart is really something! |
I tried to repro, but could not see any difference. |
I have this exact same issue. Exactly as eltoncezar describes. One thing I will add: If I set two keys, say, "e" and "j" to basic tap and holds as described in the OP, then typing them in succession seems fine. If I have one key set to a basic tap and hold and another key without a tap and hold, then I get the described behavior. (Many thanks for this otherwise awesome script!) |
I get similar behaviour, but I see it even with an immediate Send.
With this code, if I type at my normal typing speed, the 't' will always appear late, e.g. I'll always end up writing 'hte' instead of 'the'. I do notice that when I'm typing normally, I often hold some of the keys over the pressing of the other keys - e.g. if I type 'the', I might press 't' down, then press 'h' down, then release 't' then press 'e', then release 'h', then release 'e'. I can see why this is - TapHoldManager can't send the tap until it knows whether it's a tap or a hold, which isn't until after holdtime has passed or the key has been released, but it does mean that I can't really use it for what I was hoping to (normal typing with taps, chordal expansions with hold -e.g. t<hold>with h pressed becomes 'the' on release). I think the only way to avoid this really would be to queue up keypresses while you're deciding whether it's a tap or a hold, and replay them in the right order. Mod-Tap in QMK has a setting called "Permissive Hold" https://beta.docs.qmk.fm/using-qmk/software-features/tap_hold I think that this means that if your tap overlaps with another keys tap, it sends taps for both keys, which would probably fix @eltoncezar's problem, but wouldn't help me with mine. |
That is a great reply, kypernetikos. Great explanation. Yesterday, I rolled my own simple tap and hold, and I had the same issue. So, it does seem like it's just the physics of having to wait for the key release to know that it is not a hold. "Permissive Hold" sounds really interesting. :) |
Set the maxTaps parameter to avoid any delays. |
Implementing stuff like permissive mode would require quite a lot of changes I think. Currently, each key's processing is completely independent of another - there is no one piece of code which handles all keys - each key is handled by an instance of the KeyManager class, and each key's KeyManager is unaware that other key's KeyManagers exist. |
Above, I wrote:
I just tested doing that to all the letters. It seems to work fine. Here is why I think it works: By mapping all the letters, we are essentially adding the delay to all of them. That makes them all have the same delay, which means you do not have the typing issue as explained by the OP. I do not seem to notice the delay while I am typing. I only notice weirdness when there is a mismatch between the letters. Therefore, it is possible that TapHoldManager could be configured to optionally add a delay after each non-mapped key press. I.e., if the key is NOT setup in TapHoldManager, then add a configured offset in milliseconds to the key press. Presumably, this should be a parameter in the TapHoldManager constructor. I have no idea what side-effects there would be if this is done, so obviously, it would need to be well beta-tested. The basic idea is this: Creating a mapping for a given key as described by the OP induces a delay. Offsetting all other keys to have that same delay makes it seem like there is no delay. |
Quick update: I mapped all of the non-modifier keys, and it seems to be working fine so far. It was relatively easy to do them all, so perhaps it is not even worth updating TapHoldManager. I will report back on how it goes after more testing. |
@jbone1313, what config did you end up with? I'm, trying to achieve the same. Thanks! |
@mplattner I could never figure out a way to send immediately. So, I only do this on keys where I am OK with the lag. In any case, I cannot remember why I gave up on TapHoldManager (it is a fine piece of code, but I think it was more than I needed), and I am not sure how well that "map all the letters" thing I wrote in the above post from July works in practice. Sorry, it has been a while since I was messing with this.
|
Thank you @jbone1313! 👍 |
This code is likely to be buggy
Consider this snippet:
Press 6, press 7 within 100ms, release 6, release 7 Hell, if HoldTime was 1s, and you did 6 down <wait 100ms> 7 down <wait 100ms> 6 up (NOTHING HAPPENS YET) <wait 1 sec> 7 up - then it would send 7 then 6 when you wanted to send #d then 7 TLDR to code stuff like this you should really be using SetTimer and key up hotkeys, not blocking waits such as |
See here for an explanation of why this happens |
@evilC As a matter of interest, I might have found a way to implement tap/hold without the lag issue. Similar to what I wrote above, it essentially involves implementing the keystroke on the UP stroke for ALL keys. In that way, the user does not experience the weird typing, since all keystrokes are effectively delayed to fire after the key is released. I am thinking about coding up a script to do it. Here is an example for handling tap/hold for the a key, which does not use TapHoldManager.
Then, for all the other keys, I would do something like this. This is an example for b, which is a key on which no tap/hold would be configured. It starts to get tricky dealing with control key combinations, but it seems like it can work.
If you have any feedback, I am all ears. |
Quick update: In summary: setting up tap/holds as I described above is not a problem if one also implements Sends for all the other keys like this:
|
Hi, first of all, thanks for the amazing work with this library!
What I want to achieve is something like that:
I came up with the following code:
It works and sends the "s" correctly, but only after the default
tapTime
of 200ms, which is not desirable. I want to send the "s" immediately, but retaining the hold functionality.What is the right way to achieve this using your library?
The text was updated successfully, but these errors were encountered: