diff options
author | kotontrion <[email protected]> | 2024-08-15 10:11:16 +0200 |
---|---|---|
committer | kotontrion <[email protected]> | 2024-08-15 10:11:16 +0200 |
commit | e14677c877bb591ed496e60ad37113e1dc41d509 (patch) | |
tree | 53601e1a9048e780735d0d45fc00467f7b05f128 /src/endpoint.c | |
parent | 8f3eca7c0876fc8daf2cbc86bb7b83dd01fc2845 (diff) |
add volume-icon
Diffstat (limited to 'src/endpoint.c')
-rw-r--r-- | src/endpoint.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/endpoint.c b/src/endpoint.c index e479d5b..4a11b9f 100644 --- a/src/endpoint.c +++ b/src/endpoint.c @@ -54,6 +54,7 @@ typedef enum { ASTAL_WP_ENDPOINT_PROP_MEDIA_CLASS, ASTAL_WP_ENDPOINT_PROP_DEFAULT, ASTAL_WP_ENDPOINT_PROP_ICON, + ASTAL_WP_ENDPOINT_PROP_VOLUME_ICON, ASTAL_WP_ENDPOINT_N_PROPERTIES, } AstalWpEndpointProperties; @@ -93,6 +94,7 @@ void astal_wp_endpoint_update_volume(AstalWpEndpoint *self) { g_object_notify(G_OBJECT(self), "volume"); } + g_object_notify(G_OBJECT(self), "volume-icon"); g_signal_emit_by_name(self, "changed"); } @@ -145,6 +147,13 @@ void astal_wp_endpoint_set_is_default(AstalWpEndpoint *self, gboolean is_default &ret); } +const gchar *astal_wp_endpoint_get_volume_icon(AstalWpEndpoint *self) { + if (self->mute) return "audio-volume-muted-symbolic"; + if (self->volume < 0.33) return "audio-volume-low-symbolic"; + if (self->volume < 0.66) return "audio-volume-medium-symbolic"; + return "audio-volume-high-symbolic"; +} + static void astal_wp_endpoint_get_property(GObject *object, guint property_id, GValue *value, GParamSpec *pspec) { AstalWpEndpoint *self = ASTAL_WP_ENDPOINT(object); @@ -168,6 +177,9 @@ static void astal_wp_endpoint_get_property(GObject *object, guint property_id, G case ASTAL_WP_ENDPOINT_PROP_ICON: g_value_set_string(value, self->icon); break; + case ASTAL_WP_ENDPOINT_PROP_VOLUME_ICON: + g_value_set_string(value, astal_wp_endpoint_get_volume_icon(self)); + break; case ASTAL_WP_ENDPOINT_PROP_MEDIA_CLASS: g_value_set_enum(value, self->type); break; @@ -401,7 +413,7 @@ static void astal_wp_endpoint_class_init(AstalWpEndpointClass *class) { astal_wp_endpoint_properties[ASTAL_WP_ENDPOINT_PROP_ID] = g_param_spec_uint("id", "id", "id", 0, UINT_MAX, 0, G_PARAM_READABLE); astal_wp_endpoint_properties[ASTAL_WP_ENDPOINT_PROP_VOLUME] = - g_param_spec_double("volume", "volume", "volume", 0, 1, 0, G_PARAM_READWRITE); + g_param_spec_double("volume", "volume", "volume", 0, G_MAXFLOAT, 0, G_PARAM_READWRITE); astal_wp_endpoint_properties[ASTAL_WP_ENDPOINT_PROP_MUTE] = g_param_spec_boolean("mute", "mute", "mute", TRUE, G_PARAM_READWRITE); astal_wp_endpoint_properties[ASTAL_WP_ENDPOINT_PROP_DESCRIPTION] = @@ -410,6 +422,8 @@ static void astal_wp_endpoint_class_init(AstalWpEndpointClass *class) { g_param_spec_string("name", "name", "name", NULL, G_PARAM_READABLE); astal_wp_endpoint_properties[ASTAL_WP_ENDPOINT_PROP_ICON] = g_param_spec_string( "icon", "icon", "icon", "audio-card-symbolic", G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY); + astal_wp_endpoint_properties[ASTAL_WP_ENDPOINT_PROP_VOLUME_ICON] = g_param_spec_string( + "volume-icon", "volume-icon", "volume-icon", "audio-volume-muted", G_PARAM_READABLE); /** * AstalWpEndpoint:media-class: (type AstalWpMediaClass) * |