Unfortunately xinput-calibrator does not work at all for calibrating a
touchscreen in Debian9. This is apparently because X server now uses libinput
to handle input devices instead of evdev. I spent huge amount of trying to
fiddling with xinput-calibrator and 99-calibration.conf files until I finely
found this issue on GitHub that gave me some hints as how to proceed. This
is mostly for my own reference, but I hope it might also help others in the same
situation.
This not not seem to be installed by defaults on Debian9
$ sudo apt-get install xinput
You probably already know this, but if you have multiple screens they might be see as one big screen. So to determine the total size run
$ xrandr
This will print out a good bit of information, but what you are interested in is
the current vales in the first line, which will look something like this:
Screen 0: minimum 320 x 200, current 1440 x 900, maximum 8192 x 8192
Next step it to find the touch device's name
$ xinput list
Look for the touch device in the Virtual core pointer section. In my case the
device name is Elo TouchSystems 2700 IntelliTouch(r).
⎡ Virtual core pointer                          id=2    [master pointer  (3)]
⎜   ↳ Virtual core XTEST pointer                id=4    [slave  pointer  (2)]
⎜   ↳ Elo TouchSystems 2700 IntelliTouch(r)     id=12   [slave  pointer  (2)]
⎜   ↳ 2.4G Mouse                                id=10   [slave  pointer  (2)]
⎣ Virtual core keyboard                         id=3    [master keyboard (2)]
    ↳ Virtual core XTEST keyboard               id=5    [slave  keyboard (3)]
...
Now run
$ xinput list-props <device name>
were <device-name> is the name you determined in the last step.
Confirm that the list of properties includes near the top a property called
Coordinate Transformation Matrix. If it does not, you probably have the wrong
device name.
The screen is calibrated using a Coordinate Transformation Matrix, which
defaults to the identity matrix.
[1 0 0]
[0 1 0]
[0 0 1]
for convenient entry, the matrix is flatted into a single line like this
1 0 0 0 1 0 0 0 1
were the valuse seem to map like this
[hscale] [vskew] [hoffset] [hskew] [vscale] [voffset] 0 0 1
Here is a very nice interactive tool for visualizing the effect of the various values: https://codepen.io/GottZ/full/d73f2f844b52b91b7457febce2d1b18c/
Apply the calibration matrix by saying
xinput set-prop '<device name>' 'Coordinate Transformation Matrix' 1.04 0 -0.02 0 1.04 -0.02 0 0 1
I just experimented with the values until I had the scree calibrated, it only took a few iterations to get so the pointer was exactly under were I touched.
References: https://wiki.archlinux.org/index.php/Calibrating_Touchscreen https://wiki.ubuntu.com/X/InputCoordinateTransformation
This was super helpful for me, thanks for posting it!