Skip to content
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

Palm rejection for stylus users: Documentation, possibly improvements #173

Open
xieve opened this issue Sep 24, 2024 · 1 comment
Open

Comments

@xieve
Copy link

xieve commented Sep 24, 2024

I've been trying to get a good handwriting experience with IPTSD on my Surface Pro 9 with a Slim Pen 2:

DisableOnStylus: Eliminates all random touches while writing, but can be irritating
DisableOnPalm: Almost there. Generally, writing feels okay and doable, but especially when leaving space before the next word (i.e. moving my palm across the screen), the canvas jumps a bit. Feels like this should be enabled by default, possibly?

These two parameters should definitely be mentioned in the wiki.

I've calibrated IPTSD like outlined in the wiki (those instructions are also slightly outdated, as the tool now writes three presets to current folder).

I would like to know what parameters are likely to influence palm rejection performance, and how I should go about tweaking them. Are some tweaks device-specific? If so, and if they are known, it'd be great to find them somewhere in the wiki.

Afaik, at least some Windows drivers do palm rejection heuristically based on stylus state, which I think IPTSD currently does not. I think that my Dell Latitude 5290 2-in-1 had a setting where you could change whether you're right- or left-handed, and it would reject touch points on the bottom left or right of the stylus more aggressively.

Simpler heuristics I made up on the spot:

  • When a stylus is in the vicinity, activate DisableOnPalm: This makes a lot of sense to me. When you're drawing with the stylus, you probably want DisableOnPalm to be enabled, in other cases, you might prefer it being disabled for a better touch experience. ← This heuristic should be the default in my opinion.
  • When a stylus is touching the screen, disable touch. ← I would use this, personally. I'm pretty sure I have never wanted to use touch with the other hand while the stylus touches the screen.
  • When a stylus is present or touching the screen, adjust palm rejection to be more aggressive.
  • When a stylus is touching the screen, accept only taps, but no gestures.

Generally, a "grace period" could be nice for these, i.e. after the stylus stops hovering, let the adjustments linger for a few seconds at most, in case it gets into range again. Scalar values could be eased (maybe even depending on the distance of the stylus to the screen? Not sure if that makes sense).

@juan11iguel
Copy link

Also would be nice to add documentation on which file specifically needs to be changed (/etc/iptsd.conf), and after changing it, if a command needs to be applied to reflect the changes. I assume the iptsd service needs to be restarted, but when I tried a command from the wiki I get a warning:

sudo systemctl start $(sudo iptsd-find-service)
[sudo] password for : 
[19:44:14.006] [warning] iptsd-find-service is deprecated, please use iptsd-systemd

Slightly off-topic, but I wonder if this is the right approach:

sudo iptsd-systemd -t any restart

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants