if(etype == MotionNotify) {
Time cur_motion_time = event->xmotion.time;
- int x = event->xmotion.x;
- int y = event->xmotion.y;
+ int x = event->xmotion.x_root;
+ int y = event->xmotion.y_root;
if(win->cursorhidden && cur_motion_time - win->player_event_time < IGNORE_MOTION_THRESHOLD_MS) {
- int diff_x = abs(x - win->mouse_x_orig);
- int diff_y = abs(y - win->mouse_y_orig);
+ int diff_x = abs(x - win->mouse_x);
+ int diff_y = abs(y - win->mouse_y);
if(diff_x > MOTION_POS_THRESHOLD_PIX || diff_y > MOTION_POS_THRESHOLD_PIX) {
WindowShowPlayerCursor(win);
}
} else {
- win->mouse_x_orig = x;
- win->mouse_y_orig = y;
+ win->mouse_x = x;
+ win->mouse_y = y;
}
win->player_event_time = cur_motion_time;
win->motion_playback_time = win->player->playback_time;
+
+
+
+ if(win->pwbuttonpressed) {
+ Display *dp = XtDisplay(win->window);
+
+ XtUngrabPointer(win->player_widget, CurrentTime);
+
+ XEvent xev;
+ memset(&xev, 0, sizeof(xev));
+ xev.type = ClientMessage;
+ xev.xclient.message_type = XInternAtom(dp, "_NET_WM_MOVERESIZE", False);
+ xev.xclient.window = XtWindow(win->window);
+ xev.xclient.format = 32;
+ xev.xclient.data.l[0] = x;
+ xev.xclient.data.l[1] = y;
+ xev.xclient.data.l[2] = 8; // _NET_WM_MOVERESIZE_MOVE
+ xev.xclient.data.l[3] = 1; // button1
+ xev.xclient.data.l[4] = 1; // source indication
+
+ XSendEvent(dp, DefaultRootWindow(dp), False, SubstructureRedirectMask | SubstructureNotifyMask, &xev);
+
+ win->pwbuttonpressed = FALSE;
+ }
} else if(etype == ButtonPress) {
Time t = event->xbutton.time;
if(t - win->button_press_time < DOUBLE_CLICK_TIME_MS) {
} else {
win->button_press_time = t;
}
+ win->pwbuttonpressed = 1;
} else if(etype == ButtonRelease) {
win->player_event_time = event->xbutton.time;
+ win->pwbuttonpressed = FALSE;
}
}