| Top | Description |  |  |  |  | 
#include <gtk/gtkx.h> struct GtkPlug; void gtk_plug_construct (GtkPlug *plug,Window socket_id); void gtk_plug_construct_for_display (GtkPlug *plug,GdkDisplay *display,Window socket_id); GtkWidget * gtk_plug_new (Window socket_id); GtkWidget * gtk_plug_new_for_display (GdkDisplay *display,Window socket_id); Window gtk_plug_get_id (GtkPlug *plug); gboolean gtk_plug_get_embedded (GtkPlug *plug); GdkWindow * gtk_plug_get_socket_window (GtkPlug *plug);
Together with GtkSocket, GtkPlug provides the ability to embed widgets from one process into another process in a fashion that is transparent to the user. One process creates a GtkSocket widget and passes the ID of that widget's window to the other process, which then creates a GtkPlug with that window ID. Any widgets contained in the GtkPlug then will appear inside the first application's window.
The communication between a GtkSocket and a GtkPlug follows the XEmbed protocol. This protocol has also been implemented in other toolkits, e.g. Qt, allowing the same level of integration when embedding a Qt widget in GTK+ or vice versa.
GDK_WINDOWING_X11 is defined.
They can only be used on a GdkX11Display. To use GtkPlug and
GtkSocket, you need to include the gtk/gtkx.h
header.
void gtk_plug_construct (GtkPlug *plug,Window socket_id);
Finish the initialization of plug for a given GtkSocket identified by
socket_id. This function will generally only be used by classes deriving from GtkPlug.
| 
 | a GtkPlug. | 
| 
 | the XID of the socket's window. | 
void gtk_plug_construct_for_display (GtkPlug *plug,GdkDisplay *display,Window socket_id);
Finish the initialization of plug for a given GtkSocket identified by
socket_id which is currently displayed on display.
This function will generally only be used by classes deriving from GtkPlug.
| 
 | a GtkPlug. | 
| 
 | the GdkDisplay associated with socket_id's
GtkSocket. | 
| 
 | the XID of the socket's window. | 
Since 2.2
GtkWidget *         gtk_plug_new                        (Window socket_id);
Creates a new plug widget inside the GtkSocket identified
by socket_id. If socket_id is 0, the plug is left "unplugged" and
can later be plugged into a GtkSocket by  gtk_socket_add_id().
| 
 | the window ID of the socket, or 0. | 
| Returns : | the new GtkPlug widget. | 
GtkWidget * gtk_plug_new_for_display (GdkDisplay *display,Window socket_id);
Create a new plug widget inside the GtkSocket identified by socket_id.
| 
 | the GdkDisplay on which socket_idis displayed | 
| 
 | the XID of the socket's window. | 
| Returns : | the new GtkPlug widget. | 
Since 2.2
Window              gtk_plug_get_id                     (GtkPlug *plug);
Gets the window ID of a GtkPlug widget, which can then
be used to embed this window inside another window, for
instance with gtk_socket_add_id().
| 
 | a GtkPlug. | 
| Returns : | the window ID for the plug | 
gboolean            gtk_plug_get_embedded               (GtkPlug *plug);
Determines whether the plug is embedded in a socket.
| 
 | a GtkPlug | 
| Returns : | TRUEif the plug is embedded in a socket | 
Since 2.14