2012-05-28 03:33:41 +00:00
|
|
|
|
|
|
|
#include "window.h"
|
|
|
|
|
|
|
|
#include <gtk/gtkscrolledwindow.h>
|
|
|
|
|
|
|
|
#include "pointer.h"
|
|
|
|
#include "accelerator.h"
|
|
|
|
|
|
|
|
inline void CHECK_RESTORE( GtkWidget* w ){
|
|
|
|
if ( gpointer_to_int( g_object_get_data( G_OBJECT( w ), "was_mapped" ) ) != 0 ) {
|
|
|
|
gtk_widget_show( w );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void CHECK_MINIMIZE( GtkWidget* w ){
|
|
|
|
g_object_set_data( G_OBJECT( w ), "was_mapped", gint_to_pointer( GTK_WIDGET_VISIBLE( w ) ) );
|
|
|
|
gtk_widget_hide( w );
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean main_window_iconified( GtkWidget* widget, GdkEventWindowState* event, gpointer data ){
|
|
|
|
if ( ( event->changed_mask & ( GDK_WINDOW_STATE_ICONIFIED | GDK_WINDOW_STATE_WITHDRAWN ) ) != 0 ) {
|
|
|
|
if ( ( event->new_window_state & ( GDK_WINDOW_STATE_ICONIFIED | GDK_WINDOW_STATE_WITHDRAWN ) ) != 0 ) {
|
|
|
|
CHECK_MINIMIZE( GTK_WIDGET( data ) );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
CHECK_RESTORE( GTK_WIDGET( data ) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned int connect_floating( GtkWindow* main_window, GtkWindow* floating ){
|
|
|
|
return g_signal_connect( G_OBJECT( main_window ), "window_state_event", G_CALLBACK( main_window_iconified ), floating );
|
|
|
|
}
|
|
|
|
|
|
|
|
gboolean destroy_disconnect_floating( GtkWindow* widget, gpointer data ){
|
|
|
|
g_signal_handler_disconnect( G_OBJECT( data ), gpointer_to_int( g_object_get_data( G_OBJECT( widget ), "floating_handler" ) ) );
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
gboolean floating_window_delete_present( GtkWindow* floating, GdkEventFocus *event, GtkWindow* main_window ){
|
|
|
|
if ( gtk_window_is_active( floating ) || gtk_window_is_active( main_window ) ) {
|
|
|
|
gtk_window_present( main_window );
|
|
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
guint connect_floating_window_delete_present( GtkWindow* floating, GtkWindow* main_window ){
|
|
|
|
return g_signal_connect( G_OBJECT( floating ), "delete_event", G_CALLBACK( floating_window_delete_present ), main_window );
|
|
|
|
}
|
|
|
|
|
|
|
|
gboolean floating_window_destroy_present( GtkWindow* floating, GtkWindow* main_window ){
|
|
|
|
if ( gtk_window_is_active( floating ) || gtk_window_is_active( main_window ) ) {
|
|
|
|
gtk_window_present( main_window );
|
|
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
guint connect_floating_window_destroy_present( GtkWindow* floating, GtkWindow* main_window ){
|
|
|
|
return g_signal_connect( G_OBJECT( floating ), "destroy", G_CALLBACK( floating_window_destroy_present ), main_window );
|
|
|
|
}
|
|
|
|
|
|
|
|
GtkWindow* create_floating_window( const char* title, GtkWindow* parent ){
|
|
|
|
GtkWindow* window = GTK_WINDOW( gtk_window_new( GTK_WINDOW_TOPLEVEL ) );
|
|
|
|
gtk_window_set_title( window, title );
|
|
|
|
|
|
|
|
if ( parent != 0 ) {
|
|
|
|
gtk_window_set_transient_for( window, parent );
|
|
|
|
connect_floating_window_destroy_present( window, parent );
|
|
|
|
g_object_set_data( G_OBJECT( window ), "floating_handler", gint_to_pointer( connect_floating( parent, window ) ) );
|
|
|
|
g_signal_connect( G_OBJECT( window ), "destroy", G_CALLBACK( destroy_disconnect_floating ), parent );
|
|
|
|
}
|
|
|
|
|
|
|
|
return window;
|
|
|
|
}
|
|
|
|
|
|
|
|
void destroy_floating_window( GtkWindow* window ){
|
|
|
|
gtk_widget_destroy( GTK_WIDGET( window ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
gint window_realize_remove_sysmenu( GtkWidget* widget, gpointer data ){
|
|
|
|
gdk_window_set_decorations( widget->window, (GdkWMDecoration)( GDK_DECOR_ALL | GDK_DECOR_MENU ) );
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
gboolean persistent_floating_window_delete( GtkWindow* floating, GdkEvent *event, GtkWindow* main_window ){
|
|
|
|
gtk_widget_hide( GTK_WIDGET( floating ) );
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
GtkWindow* create_persistent_floating_window( const char* title, GtkWindow* main_window ){
|
|
|
|
GtkWindow* window = GTK_WINDOW( create_floating_window( title, main_window ) );
|
|
|
|
|
|
|
|
gtk_widget_set_events( GTK_WIDGET( window ), GDK_KEY_PRESS_MASK | GDK_KEY_RELEASE_MASK );
|
|
|
|
|
|
|
|
connect_floating_window_delete_present( window, main_window );
|
|
|
|
g_signal_connect( G_OBJECT( window ), "delete_event", G_CALLBACK( persistent_floating_window_delete ), 0 );
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
if ( g_multimon_globals.m_bStartOnPrimMon && g_multimon_globals.m_bNoSysMenuPopups ) {
|
|
|
|
g_signal_connect( G_OBJECT( window ), "realize", G_CALLBACK( window_realize_remove_sysmenu ), 0 );
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return window;
|
|
|
|
}
|
|
|
|
|
|
|
|
gint window_realize_remove_minmax( GtkWidget* widget, gpointer data ){
|
|
|
|
gdk_window_set_decorations( widget->window, (GdkWMDecoration)( GDK_DECOR_ALL | GDK_DECOR_MINIMIZE | GDK_DECOR_MAXIMIZE ) );
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void window_remove_minmax( GtkWindow* window ){
|
|
|
|
g_signal_connect( G_OBJECT( window ), "realize", G_CALLBACK( window_realize_remove_minmax ), 0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
GtkScrolledWindow* create_scrolled_window( GtkPolicyType hscrollbar_policy, GtkPolicyType vscrollbar_policy, int border ){
|
|
|
|
GtkScrolledWindow* scr = GTK_SCROLLED_WINDOW( gtk_scrolled_window_new( 0, 0 ) );
|
|
|
|
gtk_widget_show( GTK_WIDGET( scr ) );
|
|
|
|
gtk_scrolled_window_set_policy( scr, hscrollbar_policy, vscrollbar_policy );
|
|
|
|
gtk_scrolled_window_set_shadow_type( scr, GTK_SHADOW_IN );
|
|
|
|
gtk_container_set_border_width( GTK_CONTAINER( scr ), border );
|
|
|
|
return scr;
|
|
|
|
}
|