mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2025-01-11 02:09:48 +01:00
Improve xcursor docs
This commit is contained in:
parent
a43555d7f5
commit
8cf622f074
2 changed files with 36 additions and 11 deletions
|
@ -6,7 +6,7 @@
|
||||||
#include <wlr/xcursor.h>
|
#include <wlr/xcursor.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A scaled XCursor theme.
|
* An XCursor theme at a particular scale factor of the base size.
|
||||||
*/
|
*/
|
||||||
struct wlr_xcursor_manager_theme {
|
struct wlr_xcursor_manager_theme {
|
||||||
float scale;
|
float scale;
|
||||||
|
@ -15,11 +15,10 @@ struct wlr_xcursor_manager_theme {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Manage multiple XCursor themes with different scales and set `wlr_cursor`
|
* wlr_xcursor_manager dynamically loads xcursor themes at sizes necessary for
|
||||||
* images.
|
* use on outputs at arbitrary scale factors. You should call
|
||||||
*
|
* wlr_xcursor_manager_load for each output you will show your cursor on, with
|
||||||
* This manager can be used to display cursor images on multiple outputs having
|
* the scale factor parameter set to that output's scale factor.
|
||||||
* different scale factors.
|
|
||||||
*/
|
*/
|
||||||
struct wlr_xcursor_manager {
|
struct wlr_xcursor_manager {
|
||||||
char *name;
|
char *name;
|
||||||
|
@ -28,24 +27,33 @@ struct wlr_xcursor_manager {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new XCursor manager. After initialization, scaled themes need to be
|
* Creates a new XCursor manager with the given xcursor theme name and base size
|
||||||
* loaded with `wlr_xcursor_manager_load`. `size` is the unscaled cursor theme
|
* (for use when scale=1).
|
||||||
* size.
|
|
||||||
*/
|
*/
|
||||||
struct wlr_xcursor_manager *wlr_xcursor_manager_create(const char *name,
|
struct wlr_xcursor_manager *wlr_xcursor_manager_create(const char *name,
|
||||||
uint32_t size);
|
uint32_t size);
|
||||||
|
|
||||||
void wlr_xcursor_manager_destroy(struct wlr_xcursor_manager *manager);
|
void wlr_xcursor_manager_destroy(struct wlr_xcursor_manager *manager);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensures an xcursor theme at the given scale factor is loaded in the manager.
|
||||||
|
*/
|
||||||
int wlr_xcursor_manager_load(struct wlr_xcursor_manager *manager,
|
int wlr_xcursor_manager_load(struct wlr_xcursor_manager *manager,
|
||||||
float scale);
|
float scale);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves a wlr_xcursor reference for the given cursor name at the given
|
||||||
|
* scale factor, or NULL if this wlr_xcursor_manager has not loaded a cursor
|
||||||
|
* theme at the requested scale.
|
||||||
|
*/
|
||||||
struct wlr_xcursor *wlr_xcursor_manager_get_xcursor(
|
struct wlr_xcursor *wlr_xcursor_manager_get_xcursor(
|
||||||
struct wlr_xcursor_manager *manager, const char *name, float scale);
|
struct wlr_xcursor_manager *manager, const char *name, float scale);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a `wlr_cursor` image. The manager uses all currently loaded scaled
|
* Set a wlr_cursor's cursor image to the specified cursor name for all scale
|
||||||
* themes.
|
* factors. wlr_cursor will take over from this point and ensure the correct
|
||||||
|
* cursor is used on each output, assuming a wlr_output_layout is attached to
|
||||||
|
* it.
|
||||||
*/
|
*/
|
||||||
void wlr_xcursor_manager_set_cursor_image(struct wlr_xcursor_manager *manager,
|
void wlr_xcursor_manager_set_cursor_image(struct wlr_xcursor_manager *manager,
|
||||||
const char *name, struct wlr_cursor *cursor);
|
const char *name, struct wlr_cursor *cursor);
|
||||||
|
|
|
@ -50,6 +50,9 @@ struct wlr_xcursor {
|
||||||
uint32_t total_delay; /* length of the animation in ms */
|
uint32_t total_delay; /* length of the animation in ms */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Contanier for an Xcursor theme.
|
||||||
|
*/
|
||||||
struct wlr_xcursor_theme {
|
struct wlr_xcursor_theme {
|
||||||
unsigned int cursor_count;
|
unsigned int cursor_count;
|
||||||
struct wlr_xcursor **cursors;
|
struct wlr_xcursor **cursors;
|
||||||
|
@ -57,13 +60,27 @@ struct wlr_xcursor_theme {
|
||||||
int size;
|
int size;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads the named xcursor theme at the given cursor size (in pixels). This is
|
||||||
|
* useful if you need cursor images for your compositor to use when a
|
||||||
|
* client-side cursors is not available or you wish to override client-side
|
||||||
|
* cursors for a particular UI interaction (such as using a grab cursor when
|
||||||
|
* moving a window around).
|
||||||
|
*/
|
||||||
struct wlr_xcursor_theme *wlr_xcursor_theme_load(const char *name, int size);
|
struct wlr_xcursor_theme *wlr_xcursor_theme_load(const char *name, int size);
|
||||||
|
|
||||||
void wlr_xcursor_theme_destroy(struct wlr_xcursor_theme *theme);
|
void wlr_xcursor_theme_destroy(struct wlr_xcursor_theme *theme);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Obtains a wlr_xcursor image for the specified cursor name (e.g. "left_ptr").
|
||||||
|
*/
|
||||||
struct wlr_xcursor *wlr_xcursor_theme_get_cursor(
|
struct wlr_xcursor *wlr_xcursor_theme_get_cursor(
|
||||||
struct wlr_xcursor_theme *theme, const char *name);
|
struct wlr_xcursor_theme *theme, const char *name);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the current frame number for an animated cursor give a monotonic time
|
||||||
|
* reference.
|
||||||
|
*/
|
||||||
int wlr_xcursor_frame(struct wlr_xcursor *cursor, uint32_t time);
|
int wlr_xcursor_frame(struct wlr_xcursor *cursor, uint32_t time);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue