1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
// Take a look at the license at the top of the repository in the LICENSE file. use glib::translate::*; /// Used for button press and button release events. The /// `type` field will be one of [`EventType::ButtonPress`][crate::EventType::ButtonPress], /// [`EventType::_2buttonPress`][crate::EventType::_2buttonPress], [`EventType::_3buttonPress`][crate::EventType::_3buttonPress] or [`EventType::ButtonRelease`][crate::EventType::ButtonRelease], /// /// Double and triple-clicks result in a sequence of events being received. /// For double-clicks the order of events will be: /// /// - [`EventType::ButtonPress`][crate::EventType::ButtonPress] /// - [`EventType::ButtonRelease`][crate::EventType::ButtonRelease] /// - [`EventType::ButtonPress`][crate::EventType::ButtonPress] /// - [`EventType::_2buttonPress`][crate::EventType::_2buttonPress] /// - [`EventType::ButtonRelease`][crate::EventType::ButtonRelease] /// /// Note that the first click is received just like a normal /// button press, while the second click results in a [`EventType::_2buttonPress`][crate::EventType::_2buttonPress] /// being received just after the [`EventType::ButtonPress`][crate::EventType::ButtonPress]. /// /// Triple-clicks are very similar to double-clicks, except that /// [`EventType::_3buttonPress`][crate::EventType::_3buttonPress] is inserted after the third click. The order of the /// events is: /// /// - [`EventType::ButtonPress`][crate::EventType::ButtonPress] /// - [`EventType::ButtonRelease`][crate::EventType::ButtonRelease] /// - [`EventType::ButtonPress`][crate::EventType::ButtonPress] /// - [`EventType::_2buttonPress`][crate::EventType::_2buttonPress] /// - [`EventType::ButtonRelease`][crate::EventType::ButtonRelease] /// - [`EventType::ButtonPress`][crate::EventType::ButtonPress] /// - [`EventType::_3buttonPress`][crate::EventType::_3buttonPress] /// - [`EventType::ButtonRelease`][crate::EventType::ButtonRelease] /// /// For a double click to occur, the second button press must occur within /// 1/4 of a second of the first. For a triple click to occur, the third /// button press must also occur within 1/2 second of the first button press. #[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)] pub struct EventButton(crate::Event); event_wrapper!(EventButton, GdkEventButton); event_subtype!( EventButton, ffi::GDK_BUTTON_PRESS | ffi::GDK_DOUBLE_BUTTON_PRESS | ffi::GDK_TRIPLE_BUTTON_PRESS | ffi::GDK_BUTTON_RELEASE ); impl EventButton { #[doc(alias = "get_position")] pub fn position(&self) -> (f64, f64) { let x = self.as_ref().x; let y = self.as_ref().y; (x, y) } #[doc(alias = "get_state")] pub fn state(&self) -> crate::ModifierType { unsafe { from_glib(self.as_ref().state) } } #[doc(alias = "get_time")] pub fn time(&self) -> u32 { self.as_ref().time } #[doc(alias = "get_button")] pub fn button(&self) -> u32 { self.as_ref().button } #[doc(alias = "get_device")] pub fn device(&self) -> Option<crate::Device> { unsafe { from_glib_none(self.as_ref().device) } } #[doc(alias = "get_axes")] pub fn axes(&self) -> Option<(f64, f64)> { let axes = self.as_ref().axes; if axes.is_null() { None } else { unsafe { Some((*axes, *axes.offset(1))) } } } #[doc(alias = "get_root")] pub fn root(&self) -> (f64, f64) { let x_root = self.as_ref().x_root; let y_root = self.as_ref().y_root; (x_root, y_root) } }