gtkmm: Gtk::GestureLongPress Class Reference

"Press and Hold" gesture. More...

#include <gtkmm/gesturelongpress.h>

Inheritance diagram for Gtk::GestureLongPress:

Public Member Functions

 GestureLongPress (GestureLongPress&& src) noexcept
 
GestureLongPressoperator= (GestureLongPress&& src) noexcept
 
 ~GestureLongPress () noexcept override
 
GtkGestureLongPress* gobj ()
 Provides access to the underlying C GObject. More...

 
const GtkGestureLongPress* gobj () const
 Provides access to the underlying C GObject. More...

 
GtkGestureLongPress* gobj_copy ()
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. More...

 
void set_delay_factor (double delay_factor)
 Applies the given delay factor. More...

 
double get_delay_factor () const
 Returns the delay factor as set by set_delay_factor(). More...

 
Glib::SignalProxy< void(double, double)> signal_pressed ()
 
Glib::SignalProxy< void()> signal_cancelled ()
 
Glib::PropertyProxy< double > property_delay_factor ()
 Factor by which to modify the default timeout. More...

 
Glib::PropertyProxy_ReadOnly< double > property_delay_factor () const
 Factor by which to modify the default timeout. More...

 
- Public Member Functions inherited from Gtk::GestureSingle
 GestureSingle (GestureSingle&& src) noexcept
 
GestureSingleoperator= (GestureSingle&& src) noexcept
 
 ~GestureSingle () noexcept override
 
GtkGestureSingle* gobj ()
 Provides access to the underlying C GObject. More...

 
const GtkGestureSingle* gobj () const
 Provides access to the underlying C GObject. More...

 
GtkGestureSingle* gobj_copy ()
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. More...

 
bool get_touch_only () const
 Returns true if the gesture is only triggered by touch events. More...

 
void set_touch_only (bool touch_only=true)
 If touch_only is true, gesture will only handle events of type Gdk::EventType::TOUCH_BEGIN, Gdk::EventType::TOUCH_UPDATE or Gdk::EventType::TOUCH_END. More...

 
bool get_exclusive () const
 Gets whether a gesture is exclusive. More...

 
void set_exclusive (bool exclusive=true) const
 Sets whether gesture is exclusive. More...

 
unsigned int get_button () const
 Returns the button number gesture listens for, or 0 if gesture reacts to any button press. More...

 
void set_button (unsigned int button=0)
 Sets the button number gesture listens to. More...

 
unsigned int get_current_button () const
 Returns the button number currently interacting with gesture, or 0 if there is none. More...

 
Gdk::EventSequence* get_current_sequence ()
 Returns the event sequence currently interacting with gesture. More...

 
const Gdk::EventSequence* get_current_sequence () const
 Returns the event sequence currently interacting with gesture. More...

 
Glib::PropertyProxy< bool > property_touch_only ()
 Whether the gesture handles only touch events. More...

 
Glib::PropertyProxy_ReadOnly< bool > property_touch_only () const
 Whether the gesture handles only touch events. More...

 
Glib::PropertyProxy< bool > property_exclusive ()
 Whether the gesture is exclusive. More...

 
Glib::PropertyProxy_ReadOnly< bool > property_exclusive () const
 Whether the gesture is exclusive. More...

 
Glib::PropertyProxy< unsigned int > property_button ()
 Mouse button number to listen to, or 0 to listen for any button. More...

 
Glib::PropertyProxy_ReadOnly< unsigned int > property_button () const
 Mouse button number to listen to, or 0 to listen for any button. More...

 
- Public Member Functions inherited from Gtk::Gesture
 Gesture (Gesture&& src) noexcept
 
Gestureoperator= (Gesture&& src) noexcept
 
 ~Gesture () noexcept override
 
GtkGesture* gobj ()
 Provides access to the underlying C GObject. More...

 
const GtkGesture* gobj () const
 Provides access to the underlying C GObject. More...

 
GtkGesture* gobj_copy ()
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. More...

 
Glib::RefPtr< Gdk::Deviceget_device ()
 Returns the logical Gdk::Device that is currently operating on gesture, or nullptr if the gesture is not being interacted. More...

 
Glib::RefPtr< const Gdk::Deviceget_device () const
 Returns the logical Gdk::Device that is currently operating on gesture, or nullptr if the gesture is not being interacted. More...

 
bool set_state (EventSequenceState state)
 Sets the state of all sequences that gesture is currently interacting with. More...

 
EventSequenceState get_sequence_state (Gdk::EventSequence* sequence) const
 Returns the sequence state, as seen by gesture. More...

 
bool set_sequence_state (Gdk::EventSequence* sequence, EventSequenceState state)
 Sets the state of sequence in gesture. More...

 
std::vector< const Gdk::EventSequence* > get_sequences () const
 Returns the list of Gdk::EventSequences currently being interpreted. More...

 
Gdk::EventSequence* get_last_updated_sequence ()
 Returns the Gdk::EventSequence that was last updated on gesture. More...

 
const Gdk::EventSequence* get_last_updated_sequence () const
 Returns the Gdk::EventSequence that was last updated on gesture. More...

 
bool handles_sequence (Gdk::EventSequence* sequence) const
 Returns true if gesture is currently handling events corresponding to sequence. More...

 
Glib::RefPtr< Gdk::Eventget_last_event (Gdk::EventSequence* sequence)
 Returns the last event that was processed for sequence. More...

 
Glib::RefPtr< const Gdk::Eventget_last_event (Gdk::EventSequence* sequence) const
 Returns the last event that was processed for sequence. More...

 
bool get_point (Gdk::EventSequence* sequence, double& x, double& y) const
 If sequence is currently being interpreted by gesture, this function returns true and fills in x and y with the last coordinates stored for that event sequence. More...

 
bool get_bounding_box (Gdk::Rectangle& rect) const
 If there are touch sequences being currently handled by gesture, this function returns true and fills in rect with the bounding box containing all active touches. More...

 
bool get_bounding_box_center (double& x, double& y) const
 If there are touch sequences being currently handled by gesture, this function returns true and fills in x and y with the center of the bounding box containing all active touches. More...

 
bool is_active () const
 Returns true if the gesture is currently active. More...

 
bool is_recognized () const
 Returns true if the gesture is currently recognized. More...

 
void group (const Glib::RefPtr< Gesture >& group_gesture)
 Adds gesture to the same group than group_gesture. More...

 
void ungroup ()
 Separates gesture into an isolated group. More...

 
std::vector< Glib::RefPtr< Gesture > > get_group ()
 Returns all gestures in the group of gesture. More...

 
std::vector< Glib::RefPtr< const Gesture > > get_group () const
 Returns all gestures in the group of gesture. More...

 
bool is_grouped_with (const Glib::RefPtr< Gesture >& other) const
 Returns true if both gestures pertain to the same group. More...

 
Glib::SignalProxy< void(Gdk::EventSequence*)> signal_begin ()
 
Glib::SignalProxy< void(Gdk::EventSequence*)> signal_end ()
 
Glib::SignalProxy< void(Gdk::EventSequence*)> signal_update ()
 
Glib::SignalProxy< void(Gdk::EventSequence*)> signal_cancel ()
 
Glib::SignalProxy< void(Gdk::EventSequence*, EventSequenceState)> signal_sequence_state_changed ()
 
Glib::PropertyProxy_ReadOnly< unsigned int > property_n_points () const
 The number of touch points that trigger recognition on this gesture,. More...

 
- Public Member Functions inherited from Gtk::EventController
 EventController (EventController&& src) noexcept
 
EventControlleroperator= (EventController&& src) noexcept
 
 ~EventController () noexcept override
 
GtkEventController* gobj ()
 Provides access to the underlying C GObject. More...

 
const GtkEventController* gobj () const
 Provides access to the underlying C GObject. More...

 
GtkEventController* gobj_copy ()
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. More...

 
Widgetget_widget ()
 Returns the Gtk::Widget this controller relates to. More...

 
const Widgetget_widget () const
 Returns the Gtk::Widget this controller relates to. More...

 
void reset ()
 Resets the controller to a clean state. More...

 
PropagationPhase get_propagation_phase () const
 Gets the propagation phase at which controller handles events. More...

 
void set_propagation_phase (PropagationPhase phase)
 Sets the propagation phase at which a controller handles events. More...

 
PropagationLimit get_propagation_limit () const
 Gets the propagation limit of the event controller. More...

 
void set_propagation_limit (PropagationLimit limit)
 Sets the event propagation limit on the event controller. More...

 
Glib::ustring get_name () const
 Gets the name of controller. More...

 
void set_name (const Glib::ustring& name)
 Sets a name on the controller that can be used for debugging. More...

 
Glib::RefPtr< const Gdk::Eventget_current_event () const
 Returns the event that is currently being handled by the controller, and nullptr at other times. More...

 
guint32 get_current_event_time () const
 Returns the timestamp of the event that is currently being handled by the controller, and 0 otherwise. More...

 
Glib::RefPtr< Gdk::Deviceget_current_event_device ()
 Returns the device of the event that is currently being handled by the controller, and nullptr otherwise. More...

 
Glib::RefPtr< const Gdk::Deviceget_current_event_device () const
 Returns the event that is currently being handled by the controller, and nullptr at other times. More...

 
Gdk::ModifierType get_current_event_state () const
 Returns the modifier state of the event that is currently being handled by the controller, and 0 otherwise. More...

 
Glib::PropertyProxy_ReadOnly< Widget* > property_widget () const
 The widget receiving the Gdk::Events that the controller will handle. More...

 
Glib::PropertyProxy< PropagationPhaseproperty_propagation_phase ()
 The propagation phase at which this controller will handle events. More...

 
Glib::PropertyProxy_ReadOnly< PropagationPhaseproperty_propagation_phase () const
 The propagation phase at which this controller will handle events. More...

 
Glib::PropertyProxy< PropagationLimitproperty_propagation_limit ()
 The limit for which events this controller will handle. More...

 
Glib::PropertyProxy_ReadOnly< PropagationLimitproperty_propagation_limit () const
 The limit for which events this controller will handle. More...

 
Glib::PropertyProxy< Glib::ustringproperty_name ()
 The name for this controller, typically used for debugging purposes. More...

 
Glib::PropertyProxy_ReadOnly< Glib::ustringproperty_name () const
 The name for this controller, typically used for debugging purposes. More...

 
- Public Member Functions inherited from Glib::Object
 Object (const Object &)=delete
 
Objectoperator= (const Object &)=delete
 
 Object (Object &&src) noexcept
 
Objectoperator= (Object &&src) noexcept
 
void * get_data (const QueryQuark &key)
 
void set_data (const Quark &key, void *data)
 
void set_data (const Quark &key, void *data, DestroyNotify notify)
 
void remove_data (const QueryQuark &quark)
 
void * steal_data (const QueryQuark &quark)
 
Glib::RefPtr< Glib::Objectwrap (GObject *object, bool take_copy=false)
 
- Public Member Functions inherited from Glib::ObjectBase
 ObjectBase (const ObjectBase &)=delete
 
ObjectBaseoperator= (const ObjectBase &)=delete
 
void set_property_value (const Glib::ustring &property_name, const Glib::ValueBase &value)
 
void get_property_value (const Glib::ustring &property_name, Glib::ValueBase &value) const
 
void set_property (const Glib::ustring &property_name, const PropertyType &value)
 
void get_property (const Glib::ustring &property_name, PropertyType &value) const
 
PropertyType get_property (const Glib::ustring &property_name) const
 
sigc::connection connect_property_changed (const Glib::ustring &property_name, const sigc::slot< void()> &slot)
 
sigc::connection connect_property_changed (const Glib::ustring &property_name, sigc::slot< void()> &&slot)
 
void freeze_notify ()
 
void thaw_notify ()
 
virtual void reference () const
 
virtual void unreference () const
 
GObject * gobj ()
 
const GObject * gobj () const
 
GObject * gobj_copy () const
 
- Public Member Functions inherited from sigc::trackable
 trackable () noexcept
 
 trackable (const trackable &src) noexcept
 
 trackable (trackable &&src) noexcept
 
 ~trackable ()
 
void add_destroy_notify_callback (notifiable *data, func_destroy_notify func) const
 
void notify_callbacks ()
 
trackableoperator= (const trackable &src)
 
trackableoperator= (trackable &&src) noexcept
 
void remove_destroy_notify_callback (notifiable *data) const
 

Static Public Member Functions

static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system. More...

 
static Glib::RefPtr< GestureLongPresscreate ()
 Creates a Gesture that recognizes long presses. More...

 
- Static Public Member Functions inherited from Gtk::GestureSingle
static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system. More...

 
- Static Public Member Functions inherited from Gtk::Gesture
static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system. More...

 
- Static Public Member Functions inherited from Gtk::EventController
static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system. More...

 

Protected Member Functions

 GestureLongPress ()
 Constructs a Gesture that recognizes long presses. More...

 
- Protected Member Functions inherited from Gtk::GestureSingle
 GestureSingle ()
 There is no create() method that corresponds to this constructor, because only derived classes shall be created. More...

 
- Protected Member Functions inherited from Gtk::Gesture
 Gesture ()
 There is no create() method that corresponds to this constructor, because only derived classes shall be created. More...

 
- Protected Member Functions inherited from Gtk::EventController
 EventController ()
 There is no create() method that corresponds to this constructor, because only derived classes shall be created. More...

 
- Protected Member Functions inherited from Glib::Object
 Object ()
 
 Object (const Glib::ConstructParams &construct_params)
 
 Object (GObject *castitem)
 
 ~Object () noexcept override
 
- Protected Member Functions inherited from Glib::ObjectBase
 ObjectBase ()
 
 ObjectBase (const char *custom_type_name)
 
 ObjectBase (const std::type_info &custom_type_info)
 
 ObjectBase (ObjectBase &&src) noexcept
 
ObjectBaseoperator= (ObjectBase &&src) noexcept
 
virtual ~ObjectBase () noexcept=0
 
void initialize (GObject *castitem)
 
void initialize_move (GObject *castitem, Glib::ObjectBase *previous_wrapper)
 

Related Functions

(Note that these are not member functions.)

Glib::RefPtr< Gtk::GestureLongPresswrap (GtkGestureLongPress* object, bool take_copy=false)
 A Glib::wrap() method for this object. More...

 

Additional Inherited Members

- Public Types inherited from Glib::Object
typedef void(*)(gpointer data DestroyNotify)
 
- Public Types inherited from sigc::trackable
typedef internal::func_destroy_notify func_destroy_notify
 
- Public Types inherited from sigc::notifiable
typedef internal::func_destroy_notify func_destroy_notify
 

Detailed Description

"Press and Hold" gesture.

This is a Gesture implementation able to recognize long presses, triggering signal_pressed() after the timeout is exceeded.

If the touchpoint is lifted before the timeout passes, or if it drifts too far of the initial press point, signal_cancelled() will be emitted.

Since gtkmm 3.14:

Constructor & Destructor Documentation

Gtk::GestureLongPress::GestureLongPress ( GestureLongPress&&  src)
noexcept
Gtk::GestureLongPress::~GestureLongPress ( )
overridenoexcept
Gtk::GestureLongPress::GestureLongPress ( )
protected

Constructs a Gesture that recognizes long presses.

Member Function Documentation

static Glib::RefPtr<GestureLongPress> Gtk::GestureLongPress::create ( )
static

Creates a Gesture that recognizes long presses.

Since gtkmm 3.14:
Returns
A RefPtr to a new GestureLongPress.
double Gtk::GestureLongPress::get_delay_factor ( ) const

Returns the delay factor as set by set_delay_factor().

Returns
The delay factor.
static GType Gtk::GestureLongPress::get_type ( )
static

Get the GType for this class, for use with the underlying GObject type system.

GtkGestureLongPress* Gtk::GestureLongPress::gobj ( )
inline

Provides access to the underlying C GObject.

const GtkGestureLongPress* Gtk::GestureLongPress::gobj ( ) const
inline

Provides access to the underlying C GObject.

GtkGestureLongPress* Gtk::GestureLongPress::gobj_copy ( )

Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.

GestureLongPress& Gtk::GestureLongPress::operator= ( GestureLongPress&&  src)
noexcept
Glib::PropertyProxy< double > Gtk::GestureLongPress::property_delay_factor ( )

Factor by which to modify the default timeout.

Since gtkmm 3.20:

Default value: 1

Returns
A PropertyProxy that allows you to get or set the value of the property, or receive notification when the value of the property changes.
Glib::PropertyProxy_ReadOnly< double > Gtk::GestureLongPress::property_delay_factor ( ) const

Factor by which to modify the default timeout.

Since gtkmm 3.20:

Default value: 1

Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.
void Gtk::GestureLongPress::set_delay_factor ( double  delay_factor)

Applies the given delay factor.

The default long press time will be multiplied by this value. Valid values are in the range [0.5..2.0].

Parameters
delay_factorThe delay factor to apply.
Glib::SignalProxy<void()> Gtk::GestureLongPress::signal_cancelled ( )
Slot Prototype:
void on_my_cancelled()

Flags: Run Last

This signal is emitted whenever a press moved too far, or was released before Gtk::GestureLongPress::signal_pressed() happened.

Glib::SignalProxy<void(double, double)> Gtk::GestureLongPress::signal_pressed ( )
Slot Prototype:
void on_my_pressed(double x, double y)

Flags: Run Last

This signal is emitted whenever a press goes unmoved/unreleased longer than what the GTK defaults tell.

Parameters
xThe X coordinate where the press happened, relative to the widget allocation.
yThe Y coordinate where the press happened, relative to the widget allocation.

Friends And Related Function Documentation

Glib::RefPtr< Gtk::GestureLongPress > wrap ( GtkGestureLongPress *  object,
bool  take_copy = false 
)
related

A Glib::wrap() method for this object.

Parameters
objectThe C instance.
take_copyFalse if the result should take ownership of the C instance. True if it should take a new copy or ref.
Returns
A C++ instance that wraps this C instance.