mirror of
https://github.com/TTimo/GtkRadiant.git
synced 2025-01-20 16:41:03 +00:00
Merge pull request #483 from Pan7/entViewUpd
Entities/Entity View update
This commit is contained in:
commit
eba9e88981
1 changed files with 51 additions and 31 deletions
|
@ -35,8 +35,6 @@
|
||||||
#include "groupdialog.h"
|
#include "groupdialog.h"
|
||||||
|
|
||||||
GtkWidget* EntWidgets[EntLast];
|
GtkWidget* EntWidgets[EntLast];
|
||||||
GtkListStore* g_entlist_store;
|
|
||||||
GtkListStore* g_entprops_store;
|
|
||||||
int inspector_mode; // W_TEXTURE, W_ENTITY, or W_CONSOLE
|
int inspector_mode; // W_TEXTURE, W_ENTITY, or W_CONSOLE
|
||||||
qboolean multiple_entities;
|
qboolean multiple_entities;
|
||||||
qboolean disable_spawn_get = false;
|
qboolean disable_spawn_get = false;
|
||||||
|
@ -90,7 +88,10 @@ static void entity_check( GtkWidget *widget, gpointer data );
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void FillClassList(){
|
void FillClassList(){
|
||||||
GtkListStore* store = g_entlist_store;
|
GtkListStore *store;
|
||||||
|
GtkTreeModel * model;
|
||||||
|
model = GTK_TREE_MODEL( gtk_tree_view_get_model( GTK_TREE_VIEW( EntWidgets[EntList] ) ) );
|
||||||
|
store = GTK_LIST_STORE( model );
|
||||||
|
|
||||||
gtk_list_store_clear( store );
|
gtk_list_store_clear( store );
|
||||||
|
|
||||||
|
@ -109,7 +110,10 @@ void FillClassList(){
|
||||||
//
|
//
|
||||||
|
|
||||||
void SetKeyValuePairs( bool bClearMD3 ){
|
void SetKeyValuePairs( bool bClearMD3 ){
|
||||||
GtkListStore* store = g_entprops_store;
|
GtkListStore *store;
|
||||||
|
GtkTreeModel * model;
|
||||||
|
model = GTK_TREE_MODEL( gtk_tree_view_get_model( GTK_TREE_VIEW( EntWidgets[EntProps] ) ) );
|
||||||
|
store = GTK_LIST_STORE( model );
|
||||||
|
|
||||||
gtk_list_store_clear( store );
|
gtk_list_store_clear( store );
|
||||||
|
|
||||||
|
@ -347,7 +351,7 @@ bool UpdateEntitySel( eclass_t *pec ){
|
||||||
Sys_FPrintf( SYS_WRN, "UpdateEntitySel\n" );
|
Sys_FPrintf( SYS_WRN, "UpdateEntitySel\n" );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GtkTreeModel* model = GTK_TREE_MODEL( g_entlist_store );
|
GtkTreeModel* model = GTK_TREE_MODEL( gtk_tree_view_get_model( GTK_TREE_VIEW( EntWidgets[EntList] ) ) );
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
unsigned int i = 0;
|
unsigned int i = 0;
|
||||||
for ( gboolean good = gtk_tree_model_get_iter_first( model, &iter ); good != FALSE; good = gtk_tree_model_iter_next( model, &iter ) )
|
for ( gboolean good = gtk_tree_model_get_iter_first( model, &iter ); good != FALSE; good = gtk_tree_model_iter_next( model, &iter ) )
|
||||||
|
@ -1059,12 +1063,21 @@ static gint eclasslist_keypress( GtkWidget* widget, GdkEventKey* event, gpointer
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void proplist_selection_changed( GtkTreeSelection* selection, gpointer data ){
|
static void proplist_selection_changed( GtkTreeSelection* selection, gpointer data ){
|
||||||
// find out what type of entity we are trying to create
|
// find out what type of entity we are trying to create
|
||||||
GtkTreeModel* model;
|
GtkTreeModel* model;
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
if ( gtk_tree_selection_get_selected( selection, &model, &iter ) == FALSE ) {
|
GtkWidget *dialog, *del_button;
|
||||||
|
gboolean selected;
|
||||||
|
|
||||||
|
dialog = GTK_WIDGET( data );
|
||||||
|
del_button = GTK_WIDGET( g_object_get_data( G_OBJECT( dialog ), "del_button" ) );
|
||||||
|
|
||||||
|
selected = gtk_tree_selection_get_selected( selection, &model, &iter );
|
||||||
|
|
||||||
|
gtk_widget_set_sensitive( del_button, selected );
|
||||||
|
|
||||||
|
if ( selected == FALSE ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1078,6 +1091,10 @@ static void proplist_selection_changed( GtkTreeSelection* selection, gpointer da
|
||||||
g_free( key );
|
g_free( key );
|
||||||
g_free( val );
|
g_free( val );
|
||||||
}
|
}
|
||||||
|
static void proplist_view_realize( GtkWidget *widget, gpointer data )
|
||||||
|
{
|
||||||
|
proplist_selection_changed( gtk_tree_view_get_selection( GTK_TREE_VIEW( widget ) ), data );
|
||||||
|
}
|
||||||
|
|
||||||
static void entity_check( GtkWidget *widget, gpointer data ){
|
static void entity_check( GtkWidget *widget, gpointer data ){
|
||||||
if ( !disable_spawn_get ) {
|
if ( !disable_spawn_get ) {
|
||||||
|
@ -1215,30 +1232,34 @@ extern void PositionWindowOnPrimaryScreen( window_position_t& position );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void GroupDlg::Create(){
|
void GroupDlg::Create(){
|
||||||
|
GtkWidget *dialog, *content_area;
|
||||||
|
GtkDialogFlags flags = GTK_DIALOG_DESTROY_WITH_PARENT;
|
||||||
|
|
||||||
if ( m_pWidget != NULL ) {
|
if ( m_pWidget != NULL ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget* dlg = gtk_window_new( GTK_WINDOW_TOPLEVEL );
|
dialog = gtk_dialog_new_with_buttons( _( "Entities/Entity View" ), NULL, flags, NULL );
|
||||||
|
|
||||||
|
content_area = gtk_dialog_get_content_area( GTK_DIALOG( dialog ) );
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
if ( g_PrefsDlg.m_bStartOnPrimMon ) {
|
if ( g_PrefsDlg.m_bStartOnPrimMon ) {
|
||||||
PositionWindowOnPrimaryScreen( g_PrefsDlg.mWindowInfo.posEntityWnd );
|
PositionWindowOnPrimaryScreen( g_PrefsDlg.mWindowInfo.posEntityWnd );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
load_window_pos( dlg, g_PrefsDlg.mWindowInfo.posEntityWnd );
|
load_window_pos( dialog, g_PrefsDlg.mWindowInfo.posEntityWnd );
|
||||||
|
|
||||||
gtk_window_set_title( GTK_WINDOW( dlg ), _( "Entities" ) );
|
g_signal_connect( G_OBJECT( dialog ), "delete-event", G_CALLBACK( OnDeleteHide ), NULL );
|
||||||
g_signal_connect( G_OBJECT( dlg ), "delete-event", G_CALLBACK( OnDeleteHide ), NULL );
|
|
||||||
// catch 'Esc'
|
// catch 'Esc'
|
||||||
g_signal_connect( G_OBJECT( dlg ), "key-press-event", G_CALLBACK( OnDialogKey ), NULL );
|
g_signal_connect( G_OBJECT( dialog ), "key-press-event", G_CALLBACK( OnDialogKey ), NULL );
|
||||||
|
|
||||||
gtk_window_set_transient_for( GTK_WINDOW( dlg ), GTK_WINDOW( g_pParentWnd->m_pWidget ) );
|
gtk_window_set_transient_for( GTK_WINDOW( dialog ), GTK_WINDOW( g_pParentWnd->m_pWidget ) );
|
||||||
g_qeglobals_gui.d_entity = dlg;
|
g_qeglobals_gui.d_entity = dialog;
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkWidget* notebook = gtk_notebook_new();
|
GtkWidget* notebook = gtk_notebook_new();
|
||||||
gtk_container_add( GTK_CONTAINER( dlg ), notebook );
|
gtk_container_add( GTK_CONTAINER( content_area ), notebook );
|
||||||
gtk_notebook_set_tab_pos( GTK_NOTEBOOK( notebook ), GTK_POS_BOTTOM );
|
gtk_notebook_set_tab_pos( GTK_NOTEBOOK( notebook ), GTK_POS_BOTTOM );
|
||||||
gtk_widget_show( notebook );
|
gtk_widget_show( notebook );
|
||||||
m_pNotebook = notebook;
|
m_pNotebook = notebook;
|
||||||
|
@ -1261,20 +1282,20 @@ void GroupDlg::Create(){
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkWidget* split2 = gtk_vpaned_new();
|
GtkWidget* split2 = gtk_vpaned_new();
|
||||||
gtk_paned_add1( GTK_PANED( split1 ), split2 );
|
gtk_paned_pack1( GTK_PANED( split1 ), split2, TRUE, FALSE );
|
||||||
gtk_widget_show( split2 );
|
gtk_widget_show( split2 );
|
||||||
|
|
||||||
g_object_set_data( G_OBJECT( dlg ), "split1", split1 );
|
g_object_set_data( G_OBJECT( dialog ), "split1", split1 );
|
||||||
g_object_set_data( G_OBJECT( dlg ), "split2", split2 );
|
g_object_set_data( G_OBJECT( dialog ), "split2", split2 );
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkWidget* vbox2 = gtk_vbox_new( FALSE, 2 );
|
GtkWidget* vbox2 = gtk_vbox_new( FALSE, 2 );
|
||||||
gtk_paned_pack2( GTK_PANED( split1 ), vbox2, FALSE, FALSE );
|
gtk_paned_pack2( GTK_PANED( split1 ), vbox2, TRUE, FALSE );
|
||||||
gtk_widget_show( vbox2 );
|
gtk_widget_show( vbox2 );
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkWidget* scr = gtk_scrolled_window_new( NULL, NULL );
|
GtkWidget* scr = gtk_scrolled_window_new( NULL, NULL );
|
||||||
gtk_paned_add1( GTK_PANED( split2 ), scr );
|
gtk_paned_pack1( GTK_PANED( split2 ), scr, TRUE, FALSE );
|
||||||
gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scr ), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS );
|
gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scr ), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS );
|
||||||
gtk_scrolled_window_set_shadow_type( GTK_SCROLLED_WINDOW( scr ), GTK_SHADOW_IN );
|
gtk_scrolled_window_set_shadow_type( GTK_SCROLLED_WINDOW( scr ), GTK_SHADOW_IN );
|
||||||
gtk_widget_show( scr );
|
gtk_widget_show( scr );
|
||||||
|
@ -1295,22 +1316,21 @@ void GroupDlg::Create(){
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkTreeSelection* selection = gtk_tree_view_get_selection( GTK_TREE_VIEW( view ) );
|
GtkTreeSelection* selection = gtk_tree_view_get_selection( GTK_TREE_VIEW( view ) );
|
||||||
g_signal_connect( G_OBJECT( selection ), "changed", G_CALLBACK( eclasslist_selection_changed ), dlg );
|
g_signal_connect( G_OBJECT( selection ), "changed", G_CALLBACK( eclasslist_selection_changed ), dialog );
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_widget_show( view );
|
|
||||||
|
|
||||||
gtk_container_add( GTK_CONTAINER( scr ), view );
|
gtk_container_add( GTK_CONTAINER( scr ), view );
|
||||||
|
|
||||||
|
gtk_widget_show( view );
|
||||||
|
|
||||||
g_object_unref( G_OBJECT( store ) );
|
g_object_unref( G_OBJECT( store ) );
|
||||||
EntWidgets[EntList] = view;
|
EntWidgets[EntList] = view;
|
||||||
g_entlist_store = store;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkWidget* scr = gtk_scrolled_window_new( NULL, NULL );
|
GtkWidget* scr = gtk_scrolled_window_new( NULL, NULL );
|
||||||
gtk_paned_add2( GTK_PANED( split2 ), scr );
|
gtk_paned_pack2( GTK_PANED( split2 ), scr, TRUE, FALSE );
|
||||||
gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scr ), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS );
|
gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scr ), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS );
|
||||||
gtk_scrolled_window_set_shadow_type( GTK_SCROLLED_WINDOW( scr ), GTK_SHADOW_IN );
|
gtk_scrolled_window_set_shadow_type( GTK_SCROLLED_WINDOW( scr ), GTK_SHADOW_IN );
|
||||||
gtk_widget_show( scr );
|
gtk_widget_show( scr );
|
||||||
|
@ -1369,17 +1389,16 @@ void GroupDlg::Create(){
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkTreeSelection* selection = gtk_tree_view_get_selection( GTK_TREE_VIEW( view ) );
|
GtkTreeSelection* selection = gtk_tree_view_get_selection( GTK_TREE_VIEW( view ) );
|
||||||
g_signal_connect( G_OBJECT( selection ), "changed", G_CALLBACK( proplist_selection_changed ), dlg );
|
g_signal_connect( G_OBJECT( selection ), "changed", G_CALLBACK( proplist_selection_changed ), dialog );
|
||||||
|
g_signal_connect( G_OBJECT( view ), "realize", G_CALLBACK( proplist_view_realize ), dialog );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
gtk_container_add( GTK_CONTAINER( scr ), view );
|
gtk_container_add( GTK_CONTAINER( scr ), view );
|
||||||
|
|
||||||
gtk_widget_show( view );
|
gtk_widget_show( view );
|
||||||
g_object_unref( G_OBJECT( store ) );
|
g_object_unref( G_OBJECT( store ) );
|
||||||
|
|
||||||
EntWidgets[EntProps] = view;
|
EntWidgets[EntProps] = view;
|
||||||
g_entprops_store = store;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1539,9 +1558,9 @@ void GroupDlg::Create(){
|
||||||
|
|
||||||
{
|
{
|
||||||
GtkWidget* button = gtk_button_new_with_label( _( "Reset" ) );
|
GtkWidget* button = gtk_button_new_with_label( _( "Reset" ) );
|
||||||
|
gtk_box_pack_start( GTK_BOX( vbox2 ), button, FALSE, FALSE, 0 );
|
||||||
gtk_widget_show( button );
|
gtk_widget_show( button );
|
||||||
g_signal_connect( G_OBJECT( button ), "clicked", G_CALLBACK( ResetEntity ), NULL );
|
g_signal_connect( G_OBJECT( button ), "clicked", G_CALLBACK( ResetEntity ), NULL );
|
||||||
gtk_box_pack_start( GTK_BOX( vbox2 ), button, FALSE, FALSE, 0 );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -1570,6 +1589,7 @@ void GroupDlg::Create(){
|
||||||
gtk_box_pack_start( GTK_BOX( vbox2 ), button, FALSE, FALSE, 0 );
|
gtk_box_pack_start( GTK_BOX( vbox2 ), button, FALSE, FALSE, 0 );
|
||||||
gtk_widget_show( button );
|
gtk_widget_show( button );
|
||||||
g_signal_connect( G_OBJECT( button ), "clicked", G_CALLBACK( DelProp ), NULL );
|
g_signal_connect( G_OBJECT( button ), "clicked", G_CALLBACK( DelProp ), NULL );
|
||||||
|
g_object_set_data( G_OBJECT( dialog ), "del_button", button );
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -1630,7 +1650,7 @@ void GroupDlg::Create(){
|
||||||
}
|
}
|
||||||
|
|
||||||
inspector_mode = W_ENTITY;
|
inspector_mode = W_ENTITY;
|
||||||
m_pWidget = dlg;
|
m_pWidget = dialog;
|
||||||
g_signal_connect( G_OBJECT( notebook ), "switch-page", G_CALLBACK( switch_page ), dlg );
|
g_signal_connect( G_OBJECT( notebook ), "switch-page", G_CALLBACK( switch_page ), dialog );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue