.. _program_listing_file_include_miral_miral_hover_click.h: Program Listing for File hover_click.h ====================================== |exhale_lsh| :ref:`Return to documentation for file ` (``include/miral/miral/hover_click.h``) .. |exhale_lsh| unicode:: U+021B0 .. UPWARDS ARROW WITH TIP LEFTWARDS .. code-block:: cpp /* * Copyright © Canonical Ltd. * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 or 3 as * published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef MIRAL_HOVER_CLICK_H #define MIRAL_HOVER_CLICK_H namespace mir { class Server; } #include #include namespace miral { namespace live_config { class Store; } class HoverClick { public: explicit HoverClick(live_config::Store& config_store); auto static enabled() -> HoverClick; auto static disabled() -> HoverClick; void operator()(mir::Server& server); HoverClick& enable(); HoverClick& disable(); HoverClick& hover_duration(std::chrono::milliseconds hover_duration); // Configures the distance in pixels the pointer has to move from the // initial hover click position to cancel it. // \note The default cancel displacement threshold is 10 pixels. HoverClick& cancel_displacement_threshold(int displacement); // Configures the distance in pixels the pointer has to move from the last // hover click or hover click cancel position to initiate a new hover // click. // \note The default reclick displacement threshold is 5 pixels. HoverClick& reclick_displacement_threshold(int displacement); HoverClick& on_hover_start(std::function&&); // Called immediately when a hover click is cancelled. Should be used to // indicate to the user that the hover click was cancelled. HoverClick& on_hover_cancel(std::function&&); // Called immediately after a hover click is successfully dispatched. // Should be used to indicate to the user that the hover click was // successful. HoverClick& on_click_dispatched(std::function&&); private: struct Self; HoverClick(std::shared_ptr self); std::shared_ptr const self; }; } #endif