X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;ds=sidebyside;f=contrib%2Fbkgrnd2d%2Fdialog.cpp;h=01a1b985b9b3e091bbcce460f1b22671cdfe12ae;hb=86e475a1a73f456e157273a14bd2e6e1d1a72b08;hp=6d63bc3fd80e8cba0bb60ddd484088da45f470bb;hpb=3c73487420fde8d4a3b5360d8b99e48132517900;p=xonotic%2Fnetradiant.git diff --git a/contrib/bkgrnd2d/dialog.cpp b/contrib/bkgrnd2d/dialog.cpp index 6d63bc3f..01a1b985 100644 --- a/contrib/bkgrnd2d/dialog.cpp +++ b/contrib/bkgrnd2d/dialog.cpp @@ -34,7 +34,7 @@ // spaces to make label nice and big #define NO_FILE_MSG " (no file loaded) " -static GtkWidget *pDialogWnd; +static ui::Window pDialogWnd{ui::null}; static GtkWidget *pNotebook; static GtkTooltips *pTooltips; @@ -43,7 +43,7 @@ class CBackgroundDialogPage private: GtkWidget *m_pWidget; GtkWidget *m_pTabLabel; -GtkWidget *m_pFileLabel; +ui::Label m_pFileLabel; GtkWidget *m_pPosLabel; VIEWTYPE m_vt; bool m_bValidFile; @@ -159,7 +159,7 @@ void CBackgroundDialogPage::Browse(){ if ( m_pImage->Load( newfile ) ) { m_bValidFile = true; - gtk_label_set_text( GTK_LABEL( m_pFileLabel ),newfile ); + m_pFileLabel.text(newfile); } } @@ -168,12 +168,10 @@ void CBackgroundDialogPage::SetPosLabel(){ // TODO no snprintf ? sprintf( s, "Size/Position (%d,%d) (%d,%d)",(int)( m_pImage->m_xmin ), (int)( m_pImage->m_ymin ),(int)( m_pImage->m_xmax ),(int)( m_pImage->m_ymax ) ); - gtk_label_set_text( GTK_LABEL( m_pPosLabel ),s ); + m_pPosLabel.text(s); } CBackgroundDialogPage::CBackgroundDialogPage( VIEWTYPE vt ){ - GtkWidget *frame; - GtkWidget *hbox; GtkWidget *w; m_vt = vt; @@ -183,108 +181,103 @@ CBackgroundDialogPage::CBackgroundDialogPage( VIEWTYPE vt ){ switch ( m_vt ) { case XY: - m_pTabLabel = gtk_label_new( "X/Y" ); + m_pTabLabel = ui::Label( "X/Y" ); m_pImage = &backgroundXY; break; case XZ: - m_pTabLabel = gtk_label_new( "X/Z" ); + m_pTabLabel = ui::Label( "X/Z" ); m_pImage = &backgroundXZ; break; case YZ: - m_pTabLabel = gtk_label_new( "Y/Z" ); + m_pTabLabel = ui::Label( "Y/Z" ); m_pImage = &backgroundYZ; break; } // A vbox to hold everything - m_pWidget = gtk_vbox_new( FALSE,0 ); + m_pWidget = ui::VBox( FALSE,0 ); // Frame for file row - frame = gtk_frame_new( "File" ); - gtk_box_pack_start( GTK_BOX( m_pWidget ),frame, FALSE, FALSE, 2 ); + auto frame = ui::Frame( "File" ); + m_pWidget.pack_start(frame, FALSE, FALSE, 2 ); // hbox for first row - hbox = gtk_hbox_new( FALSE,5 ); + auto hbox = ui::HBox( FALSE,5 ); gtk_container_set_border_width( GTK_CONTAINER( hbox ),4 ); - gtk_container_add( GTK_CONTAINER( frame ), hbox ); + frame.add(hbox); // label to display filename - m_pFileLabel = gtk_label_new( NO_FILE_MSG ); + m_pFileLabel = ui::Label( NO_FILE_MSG ); gtk_label_set_selectable( GTK_LABEL( m_pFileLabel ),TRUE ); //TODO set min size ? done with spaces right now - gtk_box_pack_start( GTK_BOX( hbox ),m_pFileLabel, TRUE, TRUE, 5 ); + hbox.pack_start(m_pFileLabel, TRUE, TRUE, 5 ); - gtk_widget_show( m_pFileLabel ); + m_pFileLabel.show(); - w = gtk_button_new_with_label( "Browse..." ); - g_signal_connect( G_OBJECT( w ), "clicked", G_CALLBACK( browse_callback ), - ( gpointer ) this ); - gtk_box_pack_start( GTK_BOX( hbox ),w, FALSE, FALSE, 5 ); + w = ui::Button( "Browse..." ); + w.connect( "clicked", G_CALLBACK( browse_callback ), ( gpointer ) this ); + hbox.pack_start(w, FALSE, FALSE, 5 ); gtk_tooltips_set_tip( pTooltips, w, "Select a file", NULL ); - gtk_widget_show( w ); + w.show(); - w = gtk_button_new_with_label( "Reload" ); - g_signal_connect( G_OBJECT( w ), "clicked", G_CALLBACK( reload_callback ), - ( gpointer ) this ); + w = ui::Button( "Reload" ); + w.connect( "clicked", G_CALLBACK( reload_callback ), ( gpointer ) this ); // TODO disable until we have file // gtk_widget_set_sensitive(w,FALSE); gtk_tooltips_set_tip( pTooltips, w, "Reload current file", NULL ); - gtk_box_pack_start( GTK_BOX( hbox ),w, FALSE, FALSE, 5 ); - gtk_widget_show( w ); + hbox.pack_start(w, FALSE, FALSE, 5 ); + w.show(); - gtk_widget_show( hbox ); - gtk_widget_show( frame ); + hbox.show(); + frame.show(); // second row (rendering options) - frame = gtk_frame_new( "Rendering" ); - gtk_box_pack_start( GTK_BOX( m_pWidget ),frame, FALSE, FALSE, 2 ); + frame = ui::Frame( "Rendering" ); + m_pWidget.pack_start(frame, FALSE, FALSE, 2 ); - hbox = gtk_hbox_new( FALSE,5 ); + hbox = ui::HBox( FALSE,5 ); gtk_container_set_border_width( GTK_CONTAINER( hbox ),4 ); - gtk_container_add( GTK_CONTAINER( frame ), hbox ); + frame.add(hbox); - w = gtk_label_new( "Vertex alpha:" ); - gtk_box_pack_start( GTK_BOX( hbox ),w, FALSE, FALSE, 5 ); - gtk_widget_show( w ); + w = ui::Label( "Vertex alpha:" ); + hbox.pack_start(w, FALSE, FALSE, 5 ); + w.show(); - w = gtk_hscale_new_with_range( 0.0,1.0,0.01 ); + w = ui::HScale( 0.0, 1.0, 0.01 ); gtk_range_set_value( GTK_RANGE( w ),0.5 ); gtk_scale_set_value_pos( GTK_SCALE( w ),GTK_POS_LEFT ); - g_signal_connect( G_OBJECT( w ), "value-changed", - G_CALLBACK( alpha_adjust_callback ), ( gpointer ) this ); - gtk_box_pack_start( GTK_BOX( hbox ),w, TRUE, TRUE, 5 ); + w.connect( "value-changed", G_CALLBACK( alpha_adjust_callback ), ( gpointer ) this ); + hbox.pack_start(w, TRUE, TRUE, 5 ); gtk_tooltips_set_tip( pTooltips, w, "Set image transparancy", NULL ); - gtk_widget_show( w ); + w.show(); - gtk_widget_show( hbox ); - gtk_widget_show( frame ); + hbox.show(); + frame.show(); // Third row (size and position) - frame = gtk_frame_new( "Size/Position (undefined)" ); + frame = ui::Frame( "Size/Position (undefined)" ); m_pPosLabel = gtk_frame_get_label_widget( GTK_FRAME( frame ) ); - gtk_box_pack_start( GTK_BOX( m_pWidget ), frame, FALSE, FALSE, 2 ); + m_pWidget.pack_start( frame, FALSE, FALSE, 2 ); - hbox = gtk_hbox_new( FALSE,5 ); - gtk_container_add( GTK_CONTAINER( frame ), hbox ); + hbox = ui::HBox( FALSE,5 ); + frame.add(hbox); gtk_container_set_border_width( GTK_CONTAINER( hbox ),4 ); - w = gtk_button_new_with_label( "from selection" ); - gtk_box_pack_start( GTK_BOX( hbox ),w, TRUE, FALSE, 5 ); - g_signal_connect( G_OBJECT( w ), "clicked", G_CALLBACK( size_sel_callback ), - ( gpointer ) this ); + w = ui::Button( "from selection" ); + hbox.pack_start(w, TRUE, FALSE, 5 ); + w.connect( "clicked", G_CALLBACK( size_sel_callback ), ( gpointer ) this ); gtk_tooltips_set_tip( pTooltips, w, "Set the size of the image to the bounding rectangle of all selected brushes and entities", NULL ); - gtk_widget_show( w ); + w.show(); if ( m_vt == XY ) { - w = gtk_button_new_with_label( "from map mins/maxs" ); - gtk_box_pack_start( GTK_BOX( hbox ),w, TRUE, FALSE, 2 ); - g_signal_connect( G_OBJECT( w ), "clicked", G_CALLBACK( size_mm_callback ), - ( gpointer ) this ); + w = ui::Button( "from map mins/maxs" ); + hbox.pack_start(w, TRUE, FALSE, 2 ); + w.connect( "clicked", G_CALLBACK( size_mm_callback ), ( gpointer ) this ); gtk_tooltips_set_tip( pTooltips, w, "Set the size of the image using the mapcoordsmins and mapcoordsmaxs keys of the worldspawn entity", NULL ); - gtk_widget_show( w ); + w.show(); } - gtk_widget_show( hbox ); - gtk_widget_show( frame ); + hbox.show(); + frame.show(); - gtk_widget_show( m_pWidget ); + m_pWidget.show(); } void CBackgroundDialogPage::Append( GtkWidget *notebook ){ @@ -314,17 +307,15 @@ void InitBackgroundDialog(){ CBackgroundDialogPage *pPage; pDialogWnd = gtk_dialog_new_with_buttons( "Background Images", - GTK_WINDOW( g_pMainWidget ), + g_pMainWidget, (GtkDialogFlags)( GTK_DIALOG_DESTROY_WITH_PARENT ), // TODO dialog with no buttons // GTK_STOCK_CLOSE, // GTK_RESPONSE_CLOSE, NULL ); - gtk_signal_connect( GTK_OBJECT( pDialogWnd ), "delete_event", - GTK_SIGNAL_FUNC( close_callback ), NULL ); - gtk_signal_connect( GTK_OBJECT( pDialogWnd ), "response", - GTK_SIGNAL_FUNC( response_callback ), NULL ); -// gtk_signal_connect( GTK_OBJECT (pDialogWnd), "expose_event", GTK_SIGNAL_FUNC( ci_expose ), NULL ); + pDialogWnd.connect( "delete_event", G_CALLBACK( close_callback ), NULL ); + pDialogWnd.connect( "response", G_CALLBACK( response_callback ), NULL ); +// pDialogWnd.connect( "expose_event", G_CALLBACK( ci_expose ), NULL ); pTooltips = gtk_tooltips_new(); @@ -338,13 +329,13 @@ void InitBackgroundDialog(){ gtk_box_pack_start( GTK_BOX( GTK_DIALOG( pDialogWnd )->vbox ), pNotebook, TRUE, TRUE, 0 ); - gtk_widget_show( pNotebook ); + pNotebook.show(); gtk_widget_realize( pDialogWnd ); } void ShowBackgroundDialog(){ - gtk_window_present( GTK_WINDOW( pDialogWnd ) ); + gtk_window_present( pDialogWnd ); } void ShowBackgroundDialogPG( int page ){