Connect up the brightness slider and the dim checkbox with gnome-power-manager
This commit is contained in:
parent
032d6326d5
commit
3b8ae693d5
1 changed files with 184 additions and 8 deletions
|
@ -30,7 +30,12 @@ G_DEFINE_DYNAMIC_TYPE (CcScreenPanel, cc_screen_panel, CC_TYPE_PANEL)
|
||||||
|
|
||||||
struct _CcScreenPanelPrivate
|
struct _CcScreenPanelPrivate
|
||||||
{
|
{
|
||||||
GSettings *lock_settings;
|
GSettings *lock_settings;
|
||||||
|
GSettings *gsd_settings;
|
||||||
|
GCancellable *cancellable;
|
||||||
|
GtkBuilder *builder;
|
||||||
|
GDBusProxy *proxy;
|
||||||
|
gboolean setting_brightness;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -70,6 +75,26 @@ cc_screen_panel_dispose (GObject *object)
|
||||||
g_object_unref (priv->lock_settings);
|
g_object_unref (priv->lock_settings);
|
||||||
priv->lock_settings = NULL;
|
priv->lock_settings = NULL;
|
||||||
}
|
}
|
||||||
|
if (priv->gsd_settings)
|
||||||
|
{
|
||||||
|
g_object_unref (priv->gsd_settings);
|
||||||
|
priv->gsd_settings = NULL;
|
||||||
|
}
|
||||||
|
if (priv->cancellable != NULL)
|
||||||
|
{
|
||||||
|
g_object_unref (priv->cancellable);
|
||||||
|
priv->cancellable = NULL;
|
||||||
|
}
|
||||||
|
if (priv->builder != NULL)
|
||||||
|
{
|
||||||
|
g_object_unref (priv->builder);
|
||||||
|
priv->builder = NULL;
|
||||||
|
}
|
||||||
|
if (priv->proxy != NULL)
|
||||||
|
{
|
||||||
|
g_object_unref (priv->proxy);
|
||||||
|
priv->proxy = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
G_OBJECT_CLASS (cc_screen_panel_parent_class)->dispose (object);
|
G_OBJECT_CLASS (cc_screen_panel_parent_class)->dispose (object);
|
||||||
}
|
}
|
||||||
|
@ -77,6 +102,8 @@ cc_screen_panel_dispose (GObject *object)
|
||||||
static void
|
static void
|
||||||
cc_screen_panel_finalize (GObject *object)
|
cc_screen_panel_finalize (GObject *object)
|
||||||
{
|
{
|
||||||
|
CcScreenPanelPrivate *priv = CC_SCREEN_PANEL (object)->priv;
|
||||||
|
g_cancellable_cancel (priv->cancellable);
|
||||||
G_OBJECT_CLASS (cc_screen_panel_parent_class)->finalize (object);
|
G_OBJECT_CLASS (cc_screen_panel_parent_class)->finalize (object);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -105,19 +132,150 @@ cc_screen_panel_class_finalize (CcScreenPanelClass *klass)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_signal (GDBusProxy *proxy,
|
||||||
|
gchar *sender_name,
|
||||||
|
gchar *signal_name,
|
||||||
|
GVariant *parameters,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
CcScreenPanelPrivate *priv = CC_SCREEN_PANEL (user_data)->priv;
|
||||||
|
|
||||||
|
if (g_strcmp0 (signal_name, "BrightnessChanged") == 0)
|
||||||
|
{
|
||||||
|
guint brightness;
|
||||||
|
GtkRange *range;
|
||||||
|
|
||||||
|
/* changed, but ignoring */
|
||||||
|
if (priv->setting_brightness)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* update the bar */
|
||||||
|
g_variant_get (parameters,
|
||||||
|
"(u)",
|
||||||
|
&brightness);
|
||||||
|
range = GTK_RANGE (gtk_builder_get_object (priv->builder,
|
||||||
|
"screen_brightness_hscale"));
|
||||||
|
gtk_range_set_value (range, brightness);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_brightness_cb (GObject *source_object, GAsyncResult *res, gpointer user_data)
|
||||||
|
{
|
||||||
|
GError *error = NULL;
|
||||||
|
GVariant *result;
|
||||||
|
|
||||||
|
CcScreenPanelPrivate *priv = CC_SCREEN_PANEL (user_data)->priv;
|
||||||
|
|
||||||
|
/* not setting, so pay attention to changed signals */
|
||||||
|
priv->setting_brightness = FALSE;
|
||||||
|
result = g_dbus_proxy_call_finish (G_DBUS_PROXY (source_object), res, &error);
|
||||||
|
if (result == NULL)
|
||||||
|
{
|
||||||
|
g_printerr ("Error setting brightness: %s\n", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
brightness_slider_value_changed_cb (GtkRange *range, gpointer user_data)
|
||||||
|
{
|
||||||
|
guint percentage;
|
||||||
|
CcScreenPanelPrivate *priv = CC_SCREEN_PANEL (user_data)->priv;
|
||||||
|
|
||||||
|
/* do not loop */
|
||||||
|
priv->setting_brightness = TRUE;
|
||||||
|
|
||||||
|
/* push this to g-p-m */
|
||||||
|
percentage = (guint) gtk_range_get_value (range);
|
||||||
|
g_dbus_proxy_call (priv->proxy,
|
||||||
|
"SetBrightness",
|
||||||
|
g_variant_new ("(u)",
|
||||||
|
percentage),
|
||||||
|
G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
-1,
|
||||||
|
priv->cancellable,
|
||||||
|
set_brightness_cb,
|
||||||
|
user_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
get_brightness_cb (GObject *source_object, GAsyncResult *res, gpointer user_data)
|
||||||
|
{
|
||||||
|
GError *error = NULL;
|
||||||
|
GVariant *result;
|
||||||
|
guint brightness;
|
||||||
|
GtkRange *range;
|
||||||
|
CcScreenPanelPrivate *priv = CC_SCREEN_PANEL (user_data)->priv;
|
||||||
|
|
||||||
|
result = g_dbus_proxy_call_finish (G_DBUS_PROXY (source_object), res, &error);
|
||||||
|
if (result == NULL)
|
||||||
|
{
|
||||||
|
g_printerr ("Error getting brightness: %s\n", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set the slider */
|
||||||
|
g_variant_get (result,
|
||||||
|
"(u)",
|
||||||
|
&brightness);
|
||||||
|
range = GTK_RANGE (gtk_builder_get_object (priv->builder, "screen_brightness_hscale"));
|
||||||
|
gtk_range_set_range (range, 0, 100);
|
||||||
|
gtk_range_set_increments (range, 1, 10);
|
||||||
|
gtk_range_set_value (range, brightness);
|
||||||
|
g_signal_connect (range,
|
||||||
|
"value-changed",
|
||||||
|
G_CALLBACK (brightness_slider_value_changed_cb),
|
||||||
|
user_data);
|
||||||
|
g_variant_unref (result);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
got_power_proxy_cb (GObject *source_object, GAsyncResult *res, gpointer user_data)
|
||||||
|
{
|
||||||
|
GError *error = NULL;
|
||||||
|
CcScreenPanelPrivate *priv = CC_SCREEN_PANEL (user_data)->priv;
|
||||||
|
|
||||||
|
priv->proxy = g_dbus_proxy_new_for_bus_finish (res, &error);
|
||||||
|
if (priv->proxy == NULL)
|
||||||
|
{
|
||||||
|
g_printerr ("Error creating proxy: %s\n", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* we want to change the bar if the user presses brightness buttons */
|
||||||
|
g_signal_connect (priv->proxy,
|
||||||
|
"g-signal",
|
||||||
|
G_CALLBACK (on_signal),
|
||||||
|
user_data);
|
||||||
|
|
||||||
|
/* get the initial state */
|
||||||
|
g_dbus_proxy_call (priv->proxy,
|
||||||
|
"GetBrightness",
|
||||||
|
NULL,
|
||||||
|
G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
200, /* we don't want to randomly move the bar */
|
||||||
|
priv->cancellable,
|
||||||
|
get_brightness_cb,
|
||||||
|
user_data);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
cc_screen_panel_init (CcScreenPanel *self)
|
cc_screen_panel_init (CcScreenPanel *self)
|
||||||
{
|
{
|
||||||
GError *error;
|
GError *error;
|
||||||
GtkBuilder *builder;
|
|
||||||
GtkWidget *widget;
|
GtkWidget *widget;
|
||||||
|
|
||||||
self->priv = SCREEN_PANEL_PRIVATE (self);
|
self->priv = SCREEN_PANEL_PRIVATE (self);
|
||||||
|
|
||||||
builder = gtk_builder_new ();
|
self->priv->builder = gtk_builder_new ();
|
||||||
|
|
||||||
error = NULL;
|
error = NULL;
|
||||||
gtk_builder_add_from_file (builder,
|
gtk_builder_add_from_file (self->priv->builder,
|
||||||
GNOMECC_UI_DIR "/screen.ui",
|
GNOMECC_UI_DIR "/screen.ui",
|
||||||
&error);
|
&error);
|
||||||
|
|
||||||
|
@ -125,20 +283,38 @@ cc_screen_panel_init (CcScreenPanel *self)
|
||||||
{
|
{
|
||||||
g_warning ("Could not load interface file: %s", error->message);
|
g_warning ("Could not load interface file: %s", error->message);
|
||||||
g_error_free (error);
|
g_error_free (error);
|
||||||
|
|
||||||
g_object_unref (builder);
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
self->priv->cancellable = g_cancellable_new ();
|
||||||
|
|
||||||
|
/* get initial brightness version */
|
||||||
|
g_dbus_proxy_new_for_bus (G_BUS_TYPE_SESSION,
|
||||||
|
G_DBUS_PROXY_FLAGS_NONE,
|
||||||
|
NULL,
|
||||||
|
"org.gnome.PowerManager",
|
||||||
|
"/org/gnome/PowerManager/Backlight",
|
||||||
|
"org.gnome.PowerManager.Backlight",
|
||||||
|
self->priv->cancellable,
|
||||||
|
got_power_proxy_cb,
|
||||||
|
self);
|
||||||
|
|
||||||
self->priv->lock_settings = g_settings_new ("org.gnome.desktop.interface");
|
self->priv->lock_settings = g_settings_new ("org.gnome.desktop.interface");
|
||||||
g_signal_connect (self->priv->lock_settings,
|
g_signal_connect (self->priv->lock_settings,
|
||||||
"changed",
|
"changed",
|
||||||
G_CALLBACK (on_lock_settings_changed),
|
G_CALLBACK (on_lock_settings_changed),
|
||||||
self);
|
self);
|
||||||
|
self->priv->gsd_settings = g_settings_new ("org.gnome.settings-daemon.plugins.power");
|
||||||
|
|
||||||
widget = WID (builder, "screen_vbox");
|
/* bind the auto dim checkbox */
|
||||||
|
widget = GTK_WIDGET (gtk_builder_get_object (self->priv->builder,
|
||||||
|
"screen_auto_reduce_checkbutton"));
|
||||||
|
g_settings_bind (self->priv->gsd_settings,
|
||||||
|
"idle-dim-battery",
|
||||||
|
widget, "active",
|
||||||
|
G_SETTINGS_BIND_DEFAULT);
|
||||||
|
|
||||||
|
widget = WID (self->priv->builder, "screen_vbox");
|
||||||
gtk_widget_reparent (widget, (GtkWidget *) self);
|
gtk_widget_reparent (widget, (GtkWidget *) self);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue