diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/empathy-call-window.c | 96 | ||||
-rw-r--r-- | src/empathy-call-window.ui | 157 |
2 files changed, 161 insertions, 92 deletions
diff --git a/src/empathy-call-window.c b/src/empathy-call-window.c index 48b6b6647..d7d79df90 100644 --- a/src/empathy-call-window.c +++ b/src/empathy-call-window.c @@ -69,6 +69,7 @@ struct _EmpathyCallWindowPriv gboolean connected; + GtkUIManager *ui_manager; GtkWidget *video_output; GtkWidget *video_preview; GtkWidget *sidebar; @@ -78,8 +79,8 @@ struct _EmpathyCallWindowPriv GtkWidget *mic_button; GtkWidget *camera_button; GtkWidget *toolbar; - GtkWidget *hangup; GtkWidget *pane; + GtkAction *send_video; gdouble volume; GtkAdjustment *audio_input_adj; @@ -124,13 +125,20 @@ static void empathy_call_window_sidebar_toggled_cb (GtkToggleButton *toggle, static void empathy_call_window_camera_toggled_cb (GtkToggleToolButton *toggle, EmpathyCallWindow *window); +static void empathy_call_window_send_video_toggled_cb (GtkToggleAction *toggle, + EmpathyCallWindow *window); + +static void empathy_call_window_show_preview_toggled_cb (GtkToggleAction *toggle, + EmpathyCallWindow *window); + static void empathy_call_window_mic_toggled_cb ( GtkToggleToolButton *toggle, EmpathyCallWindow *window); static void empathy_call_window_sidebar_hidden_cb (EmpathySidebar *sidebar, EmpathyCallWindow *window); -static void empathy_call_window_hangup (EmpathyCallWindow *window); +static void empathy_call_window_hangup_cb (gpointer object, + EmpathyCallWindow *window); static void empathy_call_window_status_message (EmpathyCallWindow *window, gchar *message); @@ -143,29 +151,11 @@ empathy_call_window_volume_changed_cb (GtkScaleButton *button, gdouble value, EmpathyCallWindow *window); static void -empathy_call_window_setup_menubar (EmpathyCallWindow *self) -{ - EmpathyCallWindowPriv *priv = GET_PRIV (self); - - g_signal_connect_swapped (priv->hangup, "activate", - G_CALLBACK (empathy_call_window_hangup), self); -} - -static void empathy_call_window_setup_toolbar (EmpathyCallWindow *self) { EmpathyCallWindowPriv *priv = GET_PRIV (self); GtkToolItem *tool_item; - g_signal_connect_swapped (priv->hangup, "clicked", - G_CALLBACK (empathy_call_window_hangup), self); - - gtk_toggle_tool_button_set_active (GTK_TOGGLE_TOOL_BUTTON (priv->mic_button), - TRUE); - - g_signal_connect (G_OBJECT (priv->mic_button), "toggled", - G_CALLBACK (empathy_call_window_mic_toggled_cb), self); - /* Add an empty expanded GtkToolItem so the volume button is at the end of * the toolbar. */ tool_item = gtk_tool_item_new (); @@ -185,13 +175,6 @@ empathy_call_window_setup_toolbar (EmpathyCallWindow *self) gtk_container_add (GTK_CONTAINER (tool_item), priv->volume_button); gtk_widget_show_all (GTK_WIDGET (tool_item)); gtk_toolbar_insert (GTK_TOOLBAR (priv->toolbar), tool_item, -1); - - gtk_toggle_tool_button_set_active (GTK_TOGGLE_TOOL_BUTTON (priv->camera_button), - FALSE); - gtk_widget_set_sensitive (priv->camera_button, FALSE); - - g_signal_connect (priv->camera_button, "toggled", - G_CALLBACK (empathy_call_window_camera_toggled_cb), self); } static void @@ -489,14 +472,23 @@ empathy_call_window_init (EmpathyCallWindow *self) "microphone", &priv->mic_button, "camera", &priv->camera_button, "toolbar", &priv->toolbar, - "hangup", &priv->hangup, + "send_video", &priv->send_video, + "ui_manager", &priv->ui_manager, + NULL); + + empathy_builder_connect (gui, self, + "menuhangup", "activate", empathy_call_window_hangup_cb, + "hangup", "clicked", empathy_call_window_hangup_cb, + "microphone", "toggled", empathy_call_window_mic_toggled_cb, + "camera", "toggled", empathy_call_window_camera_toggled_cb, + "send_video", "toggled", empathy_call_window_send_video_toggled_cb, + "show_preview", "toggled", empathy_call_window_show_preview_toggled_cb, NULL); priv->lock = g_mutex_new (); gtk_container_add (GTK_CONTAINER (self), top_vbox); - empathy_call_window_setup_menubar (self); empathy_call_window_setup_toolbar (self); priv->pipeline = gst_pipeline_new (NULL); @@ -582,6 +574,7 @@ empathy_call_window_init (EmpathyCallWindow *self) priv->timer = g_timer_new (); + g_object_ref (priv->ui_manager); g_object_unref (gui); } @@ -685,6 +678,10 @@ empathy_call_window_dispose (GObject *object) g_source_remove (priv->timer_id); priv->timer_id = 0; + if (priv->ui_manager != NULL) + g_object_unref (priv->ui_manager); + priv->ui_manager = NULL; + /* release any references held by the object here */ if (G_OBJECT_CLASS (empathy_call_window_parent_class)->dispose) G_OBJECT_CLASS (empathy_call_window_parent_class)->dispose (object); @@ -759,6 +756,7 @@ empathy_call_window_disconnected (EmpathyCallWindow *self) empathy_call_window_status_message (self, _("Disconnected")); gtk_widget_set_sensitive (priv->camera_button, FALSE); + gtk_action_set_sensitive (priv->send_video, FALSE); } @@ -857,7 +855,10 @@ empathy_call_window_connected (gpointer user_data) gtk_widget_set_sensitive (priv->dtmf_panel, TRUE); if (priv->video_input != NULL) - gtk_widget_set_sensitive (priv->camera_button, TRUE); + { + gtk_widget_set_sensitive (priv->camera_button, TRUE); + gtk_action_set_sensitive (priv->send_video, TRUE); + } g_object_unref (call); @@ -1141,20 +1142,42 @@ empathy_call_window_sidebar_toggled_cb (GtkToggleButton *toggle, } static void +empathy_call_window_set_send_video (EmpathyCallWindow *window, + gboolean send) +{ + EmpathyCallWindowPriv *priv = GET_PRIV (window); + EmpathyTpCall *call; + + g_object_get (priv->handler, "tp-call", &call, NULL); + empathy_tp_call_request_video_stream_direction (call, send); + g_object_unref (call); +} + +static void empathy_call_window_camera_toggled_cb (GtkToggleToolButton *toggle, EmpathyCallWindow *window) { - EmpathyCallWindowPriv *priv = GET_PRIV (window); gboolean active; - EmpathyTpCall *call; active = (gtk_toggle_tool_button_get_active (toggle)); + empathy_call_window_set_send_video (window, active); +} - g_object_get (priv->handler, "tp-call", &call, NULL); +static void +empathy_call_window_send_video_toggled_cb (GtkToggleAction *toggle, + EmpathyCallWindow *window) +{ + gboolean active; - empathy_tp_call_request_video_stream_direction (call, active); + active = (gtk_toggle_action_get_active (toggle)); + empathy_call_window_set_send_video (window, active); +} - g_object_unref (call); +static void +empathy_call_window_show_preview_toggled_cb (GtkToggleAction *toggle, + EmpathyCallWindow *window) +{ + /* FIXME: Not implemented */ } static void @@ -1196,7 +1219,8 @@ empathy_call_window_sidebar_hidden_cb (EmpathySidebar *sidebar, } static void -empathy_call_window_hangup (EmpathyCallWindow *window) +empathy_call_window_hangup_cb (gpointer object, + EmpathyCallWindow *window) { EmpathyCallWindowPriv *priv = GET_PRIV (window); diff --git a/src/empathy-call-window.ui b/src/empathy-call-window.ui index 8ac599989..00b8ffa88 100644 --- a/src/empathy-call-window.ui +++ b/src/empathy-call-window.ui @@ -1,93 +1,138 @@ <?xml version="1.0"?> +<!--Generated with glade3 3.4.5 on Mon Feb 16 12:31:56 2009 --> <interface> - <requires lib="gtk+" version="2.16"/> - <!-- interface-naming-policy toplevel-contextual --> - <object class="GtkUIManager" id="uimanager1"/> - <object class="GtkVBox" id="call_window_vbox"> - <property name="visible">True</property> - <property name="orientation">vertical</property> + <object class="GtkUIManager" id="ui_manager"> <child> - <object class="GtkHPaned" id="pane"> - <property name="visible">True</property> - <property name="can_focus">True</property> + <object class="GtkActionGroup" id="actiongroup1"> <child> - <placeholder/> + <object class="GtkAction" id="call"> + <property name="name">call</property> + <property name="label" translatable="yes">_Call</property> + </object> + </child> + <child> + <object class="GtkToggleAction" id="send_video"> + <property name="name">send_video</property> + <property name="label" translatable="yes">Send video</property> + </object> + </child> + <child> + <object class="GtkAction" id="menuhangup"> + <property name="stock_id">gtk-cancel</property> + <property name="name">menuhangup</property> + <property name="label" translatable="yes">Hang up</property> + </object> + </child> + <child> + <object class="GtkAction" id="view"> + <property name="name">view</property> + <property name="label" translatable="yes">_View</property> + </object> + </child> + <child> + <object class="GtkToggleAction" id="show_preview"> + <property name="name">show_preview</property> + <property name="label" translatable="yes">Video preview</property> + </object> </child> </object> - <packing> - <property name="position">0</property> - </packing> </child> - <child> - <object class="GtkToolbar" id="toolbar"> + <ui> + <menubar name="menubar1"> + <menu action="call"> + <menuitem action="send_video"/> + <menuitem action="menuhangup"/> + </menu> + <menu action="view"> + <menuitem action="show_preview"/> + </menu> + </menubar> + </ui> + </object> + <object class="GtkVBox" id="call_window_vbox"> <property name="visible">True</property> <child> - <object class="GtkToolButton" id="hangup"> + <object class="GtkMenuBar" constructor="ui_manager" id="menubar1"> <property name="visible">True</property> - <property name="is_important">True</property> - <property name="label" translatable="yes">Hang up</property> - <property name="stock_id">gtk-cancel</property> </object> <packing> <property name="expand">False</property> - <property name="homogeneous">True</property> </packing> </child> <child> - <object class="GtkSeparatorToolItem" id="toolbutton1"> + <object class="GtkToolbar" id="toolbar"> <property name="visible">True</property> + <child> + <object class="GtkToolButton" id="hangup"> + <property name="visible">True</property> + <property name="is_important">True</property> + <property name="label" translatable="yes">Hang up</property> + <property name="stock_id">gtk-cancel</property> + </object> + <packing> + <property name="homogeneous">True</property> + </packing> + </child> + <child> + <object class="GtkSeparatorToolItem" id="toolbutton1"> + <property name="visible">True</property> + </object> + <packing> + <property name="homogeneous">True</property> + </packing> + </child> + <child> + <object class="GtkToggleToolButton" id="microphone"> + <property name="visible">True</property> + <property name="active">True</property> + <property name="label" translatable="yes">Send Audio</property> + <property name="icon_name">gnome-stock-mic</property> + </object> + <packing> + <property name="homogeneous">True</property> + </packing> + </child> + <child> + <object class="GtkToggleToolButton" id="camera"> + <property name="visible">True</property> + <property name="label" translatable="yes">Send video</property> + <property name="icon_name">camera-web</property> + <property name="sensitive">False</property> + </object> + <packing> + <property name="homogeneous">True</property> + </packing> + </child> </object> <packing> <property name="expand">False</property> - <property name="homogeneous">True</property> + <property name="position">1</property> </packing> </child> <child> - <object class="GtkToggleToolButton" id="microphone"> + <object class="GtkHPaned" id="pane"> <property name="visible">True</property> - <property name="label" translatable="yes">Send Audio</property> - <property name="icon_name">gnome-stock-mic</property> + <property name="can_focus">True</property> + <child> + <placeholder/> + </child> + <child> + <placeholder/> + </child> </object> <packing> - <property name="expand">False</property> - <property name="homogeneous">True</property> + <property name="position">2</property> </packing> </child> <child> - <object class="GtkToggleToolButton" id="camera"> + <object class="GtkStatusbar" id="statusbar"> <property name="visible">True</property> - <property name="label" translatable="yes">Send video</property> - <property name="icon_name">camera-web</property> + <property name="spacing">2</property> </object> <packing> <property name="expand">False</property> - <property name="homogeneous">True</property> + <property name="position">3</property> </packing> </child> </object> - <packing> - <property name="expand">False</property> - <property name="position">1</property> - </packing> - </child> - <child> - <object class="GtkMenuBar" id="menubar1"> - <property name="visible">True</property> - </object> - <packing> - <property name="expand">False</property> - <property name="position">0</property> - </packing> - </child> - <child> - <object class="GtkStatusbar" id="statusbar"> - <property name="visible">True</property> - <property name="spacing">2</property> - </object> - <packing> - <property name="expand">False</property> - <property name="position">3</property> - </packing> - </child> - </object> </interface> |