web-dev-qa-db-ja.com

udevルールスクリプト "xinput --list"は、ターミナルとログで異なります

Huionタブレットのキャリブレーションを自動化しようとしていますが、あまり成功していません。

通常の端末でxinput --listから次の出力があります。

⎡ Virtual core pointer                          id=2    [master pointer  (3)]
⎜   ↳ Virtual core XTEST pointer                id=4    [slave  pointer  (2)]
⎜   ↳ USB USB Keyboard                          id=13   [slave  pointer  (2)]
⎜   ↳ SynPS/2 Synaptics TouchPad                id=16   [slave  pointer  (2)]
⎜   ↳ Logitech USB Receiver                     id=14   [slave  pointer  (2)]
⎜   ↳ HUION PenTablet                           id=18   [slave  pointer  (2)]
⎜   ↳ HUION PenTablet                           id=19   [slave  pointer  (2)]
⎜   ↳ HUION PenTablet                           id=20   [slave  pointer  (2)]
⎣ Virtual core keyboard                         id=3    [master keyboard (2)]
↳ Virtual core XTEST keyboard               id=5    [slave  keyboard (3)]
↳ Power Button                              id=6    [slave  keyboard (3)]
↳ Video Bus                                 id=7    [slave  keyboard (3)]
↳ Video Bus                                 id=8    [slave  keyboard (3)]
↳ Power Button                              id=9    [slave  keyboard (3)]
↳ Sleep Button                              id=10   [slave  keyboard (3)]
↳ Laptop_Integrated_Webcam_2HDM             id=11   [slave  keyboard (3)]
↳ USB USB Keyboard                          id=12   [slave  keyboard (3)]
↳ AT Translated Set 2 keyboard              id=15   [slave  keyboard (3)]
↳ Dell WMI hotkeys                          id=17   [slave  keyboard (3)]

udevログは、同じコマンドに対してこれだけを表示します。

⎡ Virtual core pointer id=2 [master pointer (3)] 
⎜ ↳ Virtual core XTEST pointer id=4 [slave pointer (2)] 
⎜ ↳ USB USB Keyboard id=13 [slave pointer (2)] 
⎜ ↳ SynPS/2 Synaptics TouchPad id=16 [slave pointer (2)] 
⎜ ↳ Logitech USB Receiver id=14 [slave pointer (2)] 
⎜ ↳ HUION PenTablet id=18 [slave pointer (2)] 
⎣ Virtual core keyboard id=3 [master keyboard (2)] 
↳ Virtual core XTEST keyboard id=5 [slave keyboard (3)] 
↳ Power Button id=6 [slave keyboard (3)] 
↳ Video Bus id=7 [slave keyboard (3)] 
↳ Video Bus id=8 [slave keyboard (3)] 
↳ Power Button id=9 [slave keyboard (3)] 
↳ Sleep Button id=10 [slave keyboard (3)] 
↳Laptop_Integrated_Webcam_2HDM id=11 [slave keyboard (3)] 
↳ USB USB Keyboard id=12 [slave keyboard (3)] 
↳ AT Translated Set 2 keyboard id=15 [slave keyboard (3)] 
↳ Dell WMI hotkeys id=17 [slave keyboard (3)]

id=19id=20の行が欠落していることに注意してください。

私が持っています:

/etc/udev/rules.d/huion.rules :

ATTRS{idVendor}=="256c", ATTRS{idProduct}=="006e", SYMLINK+="davesusb", ENV{DISPLAY}=":0.0", ENV{XAUTHORITY}="/home/romulo/.Xauthority", RUN+="/usr/local/Huion"

/usr/local/Huion :

#!/bin/bash
/home/romulo/.local/Huion &

~/.local/Huion :

#!/bin/bash

sleep 3
DISPLAY=":0.0"
HOME=/home/romulo/
XAUTHORITY=$HOME/.Xauthority
export DISPLAY XAUTHORITY HOME

if (xrandr | grep "HDMI1 connected" > /dev/null)
then
    LENGTH=$(/usr/bin/xrandr | grep 'HDMI1 connected primary' | uniq |  awk '{x=$4; split(x,a,"+"); split(a[1],b,"x"); print b[1]}')
    WIDTH=$(/usr/bin/xrandr | grep 'HDMI1 connected primary' | uniq |  awk '{x=$4; split(x,a,"+"); split(a[1],b,"x"); print b[2]}')
    DEVICE=$(/usr/bin/xinput --list | grep HUION | uniq | awk 'NR==2 {x=$5; split(x,a,"="); print a[2]}')

    echo $(/usr/bin/xinput --list)

    CORRECTION=$((40000*$WIDTH/$LENGTH))
    echo "$CORRECTION"

    if (glxinfo | grep "Intel" > /dev/null)
    then
        xsetwacom set $DEVICE MapToOutput HDMI1
        echo "device $DEVICE restricted to HDMI-1"
        xinput set-prop $DEVICE "Evdev Axis Calibration" 0 40000 0 $CORRECTION
        echo "correction of proportion : 40000x$CORRECTION"        
    else
        echo "error :("
    fi
else
    echo "error :("
fi

スクリプトは、2番目のHUIONデバイス(つまり、xinput --list | grep HUION | uniq | awk 'NR==2 …')のidをキャプチャしようとして19を実行するため、その情報が存在しないために失敗します。どうすればこの問題を克服できますか?

更新1

RootからSudo suは、通常のユーザーと同じxinput --listを返しますが、キャリブレーションを試みても効果はありませんでした。 udevシェルスクリプトの呼び出しでユーザーに切り替える必要がありますか?あまりエレガントではありません... :(

2

問題は、udevルールの処理後にxinputリストが更新され、バックグラウンドプロセスのタイムアウトでそれを克服できないことです。解決策は、inotifyを介してスクリプトをトリガーすることです。元の解決策と必要なスクリプトソースは https://bbs.archlinux.org/viewtopic.php?pid=1626055#p1626055 にあります。

3
Pavel Bazika

私も同じ問題を抱えていました。私の解決策は、ACTION=="bind"ではなくACTION=="add"を使用してudevルールをトリガーすることでした(udevadm monitorでマウスを接続したときの最後のアクションであることがわかったため)

0
AsVHEn