Struct gtk::EventControllerScroll [−][src]
pub struct EventControllerScroll(_);
Expand description
EventControllerScroll is an event controller meant to handle
scroll events from mice and touchpads. It is capable of handling
both discrete and continuous scroll events, abstracting them both
on the signal::EventControllerScroll::scroll signal (deltas in the
discrete case are multiples of 1).
In the case of continuous scroll events, EventControllerScroll
encloses all signal::EventControllerScroll::scroll events between two
signal::EventControllerScroll::scroll-begin and signal::EventControllerScroll::scroll-end
signals.
The behavior of the event controller can be modified by the
flags given at creation time, or modified at a later point through
set_flags() (e.g. because the scrolling
conditions of the widget changed).
The controller can be set up to emit motion for either/both vertical
and horizontal scroll events through EventControllerScrollFlags::VERTICAL,
EventControllerScrollFlags::HORIZONTAL and GTK_EVENT_CONTROLLER_SCROLL_BOTH.
If any axis is disabled, the respective signal::EventControllerScroll::scroll
delta will be 0. Vertical scroll events will be translated to horizontal
motion for the devices incapable of horizontal scrolling.
The event controller can also be forced to emit discrete events on all devices
through EventControllerScrollFlags::DISCRETE. This can be used to implement
discrete actions triggered through scroll events (e.g. switching across
combobox options).
The EventControllerScrollFlags::KINETIC flag toggles the emission of the
signal::EventControllerScroll::decelerate signal, emitted at the end of scrolling
with two X/Y velocity arguments that are consistent with the motion that
was received.
This object was added in 3.24.
Implements
Implementations
pub fn new<P: IsA<Widget>>(
widget: &P,
flags: EventControllerScrollFlags
) -> EventControllerScrollThis is supported on crate feature v3_24 only.
pub fn new<P: IsA<Widget>>(
widget: &P,
flags: EventControllerScrollFlags
) -> EventControllerScrollv3_24 only.Creates a new event controller that will handle scroll events
for the given widget.
widget
a Widget
flags
behavior flags
Returns
a new EventControllerScroll
This is supported on crate feature v3_24 only.
v3_24 only.This is supported on crate feature v3_24 only.
v3_24 only.This is supported on crate feature v3_24 only.
v3_24 only.Emitted after scroll is finished if the EventControllerScrollFlags::KINETIC
flag is set. vel_x and vel_y express the initial velocity that was
imprinted by the scroll events. vel_x and vel_y are expressed in
pixels/ms.
vel_x
X velocity
vel_y
Y velocity
This is supported on crate feature v3_24 only.
v3_24 only.This is supported on crate feature v3_24 only.
v3_24 only.Signals that a new scrolling operation has begun. It will only be emitted on devices capable of it.
This is supported on crate feature v3_24 only.
v3_24 only.Signals that a new scrolling operation has finished. It will only be emitted on devices capable of it.
v3_24 only.Trait Implementations
type Parent = EventControllerimpl<T: ObjectType> PartialEq<T> for EventControllerScrollThis is supported on crate feature v3_24 only.
impl<T: ObjectType> PartialEq<T> for EventControllerScrollv3_24 only.impl<T: ObjectType> PartialOrd<T> for EventControllerScrollThis is supported on crate feature v3_24 only.
impl<T: ObjectType> PartialOrd<T> for EventControllerScrollv3_24 only.This method returns an ordering between self and other values if one exists. Read more
This method tests less than (for self and other) and is used by the < operator. Read more
This method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
This method tests greater than (for self and other) and is used by the > operator. Read more
Returns the type identifier of Self.
Auto Trait Implementations
impl RefUnwindSafe for EventControllerScrollimpl !Send for EventControllerScrollimpl !Sync for EventControllerScrollimpl Unpin for EventControllerScrollimpl UnwindSafe for EventControllerScrollBlanket Implementations
Mutably borrows from an owned value. Read more
Upcasts an object to a superclass or interface T. Read more
Upcasts an object to a reference of its superclass or interface T. Read more
Tries to downcast to a subclass or interface implementor T. Read more
Tries to downcast to a reference of its subclass or interface implementor T. Read more
Tries to cast to an object of type T. This handles upcasting, downcasting
and casting between interface and interface implementors. All checks are performed at
runtime, while downcast and upcast will do many checks at compile-time already. Read more
Tries to cast to reference to an object of type T. This handles upcasting, downcasting
and casting between interface and interface implementors. All checks are performed at
runtime, while downcast and upcast will do many checks at compile-time already. Read more
Casts to T unconditionally. Read more
Casts to &T unconditionally. Read more
Returns true if the object is an instance of (can be cast to) T.
pub fn set_properties_from_value(
&self,
property_values: &[(&str, Value)]
) -> Result<(), BoolError>pub fn set_property<'a, N, V>(
&self,
property_name: N,
value: V
) -> Result<(), BoolError> where
V: ToValue,
N: Into<&'a str>, pub fn set_property_from_value<'a, N>(
&self,
property_name: N,
value: &Value
) -> Result<(), BoolError> where
N: Into<&'a str>, Safety Read more
Safety Read more
Safety Read more
Safety Read more
pub fn connect_notify<F>(&self, name: Option<&str>, f: F) -> SignalHandlerId where
F: 'static + Fn(&T, &ParamSpec) + Send + Sync, pub fn connect_notify_local<F>(
&self,
name: Option<&str>,
f: F
) -> SignalHandlerId where
F: 'static + Fn(&T, &ParamSpec), pub unsafe fn connect_notify_unsafe<F>(
&self,
name: Option<&str>,
f: F
) -> SignalHandlerId where
F: Fn(&T, &ParamSpec), pub fn has_property<'a, N>(&self, property_name: N, type_: Option<Type>) -> bool where
N: Into<&'a str>, pub fn find_property<'a, N>(&self, property_name: N) -> Option<ParamSpec> where
N: Into<&'a str>, pub fn connect<'a, N, F>(
&self,
signal_name: N,
after: bool,
callback: F
) -> Result<SignalHandlerId, BoolError> where
F: Fn(&[Value]) -> Option<Value> + Send + Sync + 'static,
N: Into<&'a str>, Same as connect but takes a SignalId instead of a signal name.
pub fn connect_local<'a, N, F>(
&self,
signal_name: N,
after: bool,
callback: F
) -> Result<SignalHandlerId, BoolError> where
F: Fn(&[Value]) -> Option<Value> + 'static,
N: Into<&'a str>, Same as connect_local but takes a SignalId instead of a signal name.
pub unsafe fn connect_unsafe<'a, N, F>(
&self,
signal_name: N,
after: bool,
callback: F
) -> Result<SignalHandlerId, BoolError> where
F: Fn(&[Value]) -> Option<Value>,
N: Into<&'a str>, Same as connect_unsafe but takes a SignalId instead of a signal name.
Emit signal by signal id.
Emit signal with details by signal id.
Emit signal by it’s name.
pub fn bind_property<'a, O, N, M>(
&'a self,
source_property: N,
target: &'a O,
target_property: M
) -> BindingBuilder<'a> where
O: ObjectType,
N: Into<&'a str>,
M: Into<&'a str>, Same as emit but takes Value for the arguments.
Same as emit_by_name but takes Value for the arguments.
Returns a SendValue clone of self.
impl<'a, T, C> FromValueOptional<'a> for T where
C: ValueTypeChecker<Error = ValueTypeMismatchOrNoneError>,
T: FromValue<'a, Checker = C>,