mirror of
https://github.com/swaywm/sway
synced 2024-11-23 17:32:40 +01:00
send scroll events to swaybar blocks
This commit is contained in:
parent
79a998849b
commit
14511da75d
@ -155,11 +155,26 @@ static void wl_pointer_button(void *data, struct wl_pointer *wl_pointer,
|
|||||||
static void wl_pointer_axis(void *data, struct wl_pointer *wl_pointer,
|
static void wl_pointer_axis(void *data, struct wl_pointer *wl_pointer,
|
||||||
uint32_t time, uint32_t axis, wl_fixed_t value) {
|
uint32_t time, uint32_t axis, wl_fixed_t value) {
|
||||||
struct swaybar *bar = data;
|
struct swaybar *bar = data;
|
||||||
|
struct swaybar_pointer *pointer = &bar->pointer;
|
||||||
struct swaybar_output *output = bar->pointer.current;
|
struct swaybar_output *output = bar->pointer.current;
|
||||||
if (!sway_assert(output, "axis with no active output")) {
|
if (!sway_assert(output, "axis with no active output")) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct swaybar_hotspot *hotspot;
|
||||||
|
wl_list_for_each(hotspot, &output->hotspots, link) {
|
||||||
|
double x = pointer->x * output->scale;
|
||||||
|
double y = pointer->y * output->scale;
|
||||||
|
if (x >= hotspot->x
|
||||||
|
&& y >= hotspot->y
|
||||||
|
&& x < hotspot->x + hotspot->width
|
||||||
|
&& y < hotspot->y + hotspot->height) {
|
||||||
|
hotspot->callback(output, pointer->x, pointer->y,
|
||||||
|
wl_axis_to_x11_button(axis, value), hotspot->data);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
double amt = wl_fixed_to_double(value);
|
double amt = wl_fixed_to_double(value);
|
||||||
if (amt == 0.0) {
|
if (amt == 0.0) {
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user