mirror of
https://github.com/TTimo/GtkRadiant.git
synced 2025-01-24 18:31:36 +00:00
8aeff6b09a
The STL now defines `std::byte` so doing `using namespace std` will conflict will custom definition of `byte`, which this legacy code is full of. It looks like NetRadiant went the route of making explicit usage of `std::` prefixed types and did not renamed the custom definition of byte, so doing the same reduces diff noise between the two trees. This also makes the code future proof if the STL decides to define some other types with common name. This patches replaces all usages of `map`, `pair` and `vector` with `std::map`, `std::pair` and `std::vector` and remove the `using namespace std` line in `stl_check.h`. ``` libs/mathlib.h:132:44: error: reference to ‘byte’ is ambiguous 132 | void NormalToLatLong( const vec3_t normal, byte bytes[2] ); | ^~~~ In file included from /usr/include/c++/11/bits/stl_algobase.h:61, from /usr/include/c++/11/bits/char_traits.h:39, from /usr/include/c++/11/ios:40, from /usr/include/c++/11/ostream:38, from /usr/include/c++/11/iostream:39, from libs/missing.h:76, from radiant/qe3.h:40, from radiant/stdafx.h:39, from radiant/bp_dlg.cpp:28: /usr/include/c++/11/bits/cpp_type_traits.h:404:30: note: candidates are: ‘enum class std::byte’ 404 | enum class byte : unsigned char; | ^~~~ ```
1245 lines
43 KiB
C++
1245 lines
43 KiB
C++
/*
|
|
Copyright (C) 1999-2007 id Software, Inc. and contributors.
|
|
For a list of contributors, see the accompanying CONTRIBUTORS file.
|
|
|
|
This file is part of GtkRadiant.
|
|
|
|
GtkRadiant is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
GtkRadiant is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GtkRadiant; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
//
|
|
// Surface Dialog Module
|
|
//
|
|
|
|
#include <gtk/gtk.h>
|
|
#include <gdk/gdkkeysyms.h>
|
|
#include <glib/gi18n.h>
|
|
|
|
#include "surfacedialog.h"
|
|
#include "surfaceflags.h"
|
|
|
|
#ifdef _DEBUG
|
|
//#define DBG_SI 1
|
|
#endif
|
|
|
|
#include "gtkr_vector.h"
|
|
|
|
std::vector<texdef_to_face_t> g_texdef_face_vector;
|
|
|
|
inline texdef_to_face_t* get_texdef_face_list(){
|
|
return &( *g_texdef_face_vector.begin() );
|
|
}
|
|
|
|
inline unsigned int texdef_face_list_empty(){
|
|
return g_texdef_face_vector.empty();
|
|
}
|
|
|
|
inline unsigned int texdef_face_list_size(){
|
|
return g_texdef_face_vector.size();
|
|
}
|
|
|
|
// For different faces having different values
|
|
bool is_HShift_conflicting;
|
|
bool is_VShift_conflicting;
|
|
bool is_HScale_conflicting;
|
|
bool is_VScale_conflicting;
|
|
bool is_Rotate_conflicting;
|
|
bool is_TextureName_conflicting;
|
|
|
|
// Dialog Data
|
|
int m_nHeight;
|
|
int m_nWidth;
|
|
|
|
// 0 is invalid, otherwise it's the ID of the last 'do' we are responsible for
|
|
int m_nUndoId;
|
|
|
|
texturewin_t *texturewin;
|
|
texdef_t *l_pIncrement;
|
|
texdef_t texdef_SI_values;
|
|
|
|
// For Texture Entry, activate only on entry change
|
|
char old_texture_entry[128];
|
|
|
|
// when TRUE, this thing means the surface inspector is currently being displayed
|
|
bool g_surfwin = FALSE;
|
|
// turn on/off processing of the "changed" "value-changed" messages
|
|
// (need to turn off when we are feeding data in)
|
|
bool g_bListenChanged = TRUE;
|
|
// turn on/off listening of the update messages
|
|
bool g_bListenUpdate = TRUE;
|
|
|
|
extern void *g_pMainWidget;
|
|
|
|
GtkWidget* create_SurfaceInspector( void );
|
|
GtkWidget *SurfaceInspector = NULL;
|
|
|
|
GtkWidget *GetWidget() { return SurfaceInspector; }
|
|
GtkWidget *Get_SI_Module_Widget() { return SurfaceInspector; }
|
|
void SetWidget( GtkWidget *new_widget ) { }
|
|
GtkWidget *GetDlgWidget( const char* name ) { return GTK_WIDGET( g_object_get_data( G_OBJECT( SurfaceInspector ), name ) ); }
|
|
|
|
GtkWidget *texture_combo;
|
|
GtkWidget *texture_combo_entry;
|
|
|
|
GtkWidget *match_grid_button;
|
|
|
|
GtkWidget *hshift_value_spinbutton;
|
|
GtkWidget *vshift_value_spinbutton;
|
|
GtkWidget *hscale_value_spinbutton;
|
|
GtkWidget *vscale_value_spinbutton;
|
|
GtkWidget *rotate_value_spinbutton;
|
|
|
|
GtkWidget *hshift_step_spinbutton;
|
|
GtkWidget *vshift_step_spinbutton;
|
|
GtkWidget *hscale_step_spinbutton;
|
|
GtkWidget *vscale_step_spinbutton;
|
|
GtkWidget *rotate_step_spinbutton;
|
|
|
|
GtkWidget *fit_width_spinbutton;
|
|
GtkWidget *fit_height_spinbutton;
|
|
GtkWidget *fit_button;
|
|
GtkWidget *axial_button;
|
|
|
|
// Callbacks
|
|
gboolean on_texture_combo_entry_key_press_event( GtkWidget *widget, GdkEventKey *event, gpointer user_data );
|
|
void on_texture_combo_entry_activate( GtkEntry *entry, gpointer user_data );
|
|
|
|
static void on_match_grid_button_clicked( GtkButton *button, gpointer user_data );
|
|
|
|
static void on_hshift_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_vshift_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_hscale_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_vscale_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_rotate_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
|
|
static void on_hshift_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_vshift_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_hscale_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_vscale_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_rotate_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
|
|
static void on_fit_width_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_fit_height_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data );
|
|
static void on_fit_button_clicked( GtkButton *button, gpointer user_data );
|
|
static void on_axial_button_clicked( GtkButton *button, gpointer user_data );
|
|
|
|
|
|
/*
|
|
===================================================
|
|
|
|
SURFACE INSPECTOR
|
|
|
|
===================================================
|
|
*/
|
|
|
|
|
|
void IsFaceConflicting(){
|
|
texdef_t* tmp_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
char texture_name[128];
|
|
|
|
if ( texdef_face_list_empty() ) {
|
|
gtk_entry_set_text( GTK_ENTRY( hshift_value_spinbutton ), "" );
|
|
gtk_entry_set_text( GTK_ENTRY( vshift_value_spinbutton ), "" );
|
|
gtk_entry_set_text( GTK_ENTRY( hscale_value_spinbutton ), "" );
|
|
gtk_entry_set_text( GTK_ENTRY( vscale_value_spinbutton ), "" );
|
|
gtk_entry_set_text( GTK_ENTRY( rotate_value_spinbutton ), "" );
|
|
gtk_entry_set_text( GTK_ENTRY( texture_combo_entry ), "" );
|
|
return;
|
|
}
|
|
|
|
g_bListenChanged = FALSE;
|
|
|
|
tmp_texdef = &get_texdef_face_list()->texdef;
|
|
|
|
strcpy( texture_name, tmp_texdef->GetName() );
|
|
|
|
texdef_SI_values.shift[0] = tmp_texdef->shift[0];
|
|
texdef_SI_values.shift[1] = tmp_texdef->shift[1];
|
|
texdef_SI_values.scale[0] = tmp_texdef->scale[0];
|
|
texdef_SI_values.scale[1] = tmp_texdef->scale[1];
|
|
texdef_SI_values.rotate = tmp_texdef->rotate;
|
|
texdef_SI_values.SetName( texture_name );
|
|
|
|
is_HShift_conflicting = FALSE;
|
|
is_VShift_conflicting = FALSE;
|
|
is_HScale_conflicting = FALSE;
|
|
is_VScale_conflicting = FALSE;
|
|
is_Rotate_conflicting = FALSE;
|
|
is_TextureName_conflicting = FALSE;
|
|
|
|
if ( texdef_face_list_size() > 1 ) {
|
|
temp_texdef_face_list = get_texdef_face_list()->next;
|
|
|
|
for (; temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = &temp_texdef_face_list->texdef;
|
|
if ( texdef_SI_values.shift[0] != tmp_texdef->shift[0] ) {
|
|
is_HShift_conflicting = TRUE;
|
|
}
|
|
|
|
if ( texdef_SI_values.shift[1] != tmp_texdef->shift[1] ) {
|
|
is_VShift_conflicting = TRUE;
|
|
}
|
|
|
|
if ( texdef_SI_values.scale[0] != tmp_texdef->scale[0] ) {
|
|
is_HScale_conflicting = TRUE;
|
|
}
|
|
|
|
if ( texdef_SI_values.scale[1] != tmp_texdef->scale[1] ) {
|
|
is_VScale_conflicting = TRUE;
|
|
}
|
|
|
|
if ( texdef_SI_values.rotate != tmp_texdef->rotate ) {
|
|
is_Rotate_conflicting = TRUE;
|
|
}
|
|
|
|
if ( strcmp( texture_name, tmp_texdef->GetName() ) ) {
|
|
is_TextureName_conflicting = TRUE;
|
|
}
|
|
}
|
|
}
|
|
|
|
if ( is_HShift_conflicting ) {
|
|
gtk_entry_set_text( GTK_ENTRY( hshift_value_spinbutton ), "" );
|
|
}
|
|
else{
|
|
gtk_spin_button_set_value( GTK_SPIN_BUTTON( hshift_value_spinbutton ), texdef_SI_values.shift[0] );
|
|
}
|
|
|
|
if ( is_VShift_conflicting ) {
|
|
gtk_entry_set_text( GTK_ENTRY( vshift_value_spinbutton ), "" );
|
|
}
|
|
else{
|
|
gtk_spin_button_set_value( GTK_SPIN_BUTTON( vshift_value_spinbutton ), texdef_SI_values.shift[1] );
|
|
}
|
|
|
|
if ( is_HScale_conflicting ) {
|
|
gtk_entry_set_text( GTK_ENTRY( hscale_value_spinbutton ), "" );
|
|
}
|
|
else{
|
|
gtk_spin_button_set_value( GTK_SPIN_BUTTON( hscale_value_spinbutton ), texdef_SI_values.scale[0] );
|
|
}
|
|
|
|
if ( is_VScale_conflicting ) {
|
|
gtk_entry_set_text( GTK_ENTRY( vscale_value_spinbutton ), "" );
|
|
}
|
|
else{
|
|
gtk_spin_button_set_value( GTK_SPIN_BUTTON( vscale_value_spinbutton ), texdef_SI_values.scale[1] );
|
|
}
|
|
|
|
if ( is_Rotate_conflicting ) {
|
|
gtk_entry_set_text( GTK_ENTRY( rotate_value_spinbutton ), "" );
|
|
}
|
|
else{
|
|
gtk_spin_button_set_value( GTK_SPIN_BUTTON( rotate_value_spinbutton ), texdef_SI_values.rotate );
|
|
}
|
|
|
|
g_bListenChanged = TRUE;
|
|
}
|
|
|
|
#define MAX_NUM_LIST_ITEMS 15
|
|
static void PopulateTextureComboList(){
|
|
texdef_t* tmp_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
char blank[1];
|
|
GList *items = NULL;
|
|
GList *lst;
|
|
int num_of_list_items = 0;
|
|
|
|
blank[0] = 0;
|
|
|
|
//clear combo box
|
|
#if GTK_CHECK_VERSION( 3, 0, 0 )
|
|
gtk_combo_box_text_remove_all( GTK_COMBO_BOX_TEXT( texture_combo ) );
|
|
#else
|
|
GtkListStore *store;
|
|
store = GTK_LIST_STORE( gtk_combo_box_get_model( GTK_COMBO_BOX( texture_combo ) ) );
|
|
gtk_list_store_clear( store );
|
|
#endif
|
|
|
|
if ( texdef_face_list_empty() ) {
|
|
items = g_list_append( items, (gpointer) blank );
|
|
// For Texture Entry, activate only on entry change
|
|
strcpy( old_texture_entry, blank );
|
|
}
|
|
else if ( !is_TextureName_conflicting ) {
|
|
temp_texdef_face_list = get_texdef_face_list();
|
|
tmp_texdef = (texdef_t *) &get_texdef_face_list()->texdef;
|
|
items = g_list_append( items, (gpointer) tmp_texdef->GetName() );
|
|
// For Texture Entry, activate only on entry change
|
|
strcpy( old_texture_entry, tmp_texdef->GetName() );
|
|
}
|
|
else
|
|
{
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
// Need to do a string compare, hence the custom search
|
|
if ( !( g_list_find_custom( items, tmp_texdef->GetName(), (GCompareFunc) strcmp ) ) ) {
|
|
items = g_list_append( items, (gpointer) tmp_texdef->GetName() );
|
|
num_of_list_items++;
|
|
}
|
|
// Make sure the combo list isn't too long
|
|
if ( num_of_list_items >= MAX_NUM_LIST_ITEMS ) {
|
|
break;
|
|
}
|
|
}
|
|
// If this isn't added last (to the top of the list), g_list_find freaks.
|
|
items = g_list_prepend( items, (gpointer) blank );
|
|
// For Texture Entry, activate only on entry change
|
|
strcpy( old_texture_entry, blank );
|
|
}
|
|
|
|
for( lst = items; lst != NULL; lst = g_list_next( lst ) )
|
|
{
|
|
gtk_combo_box_text_append_text( GTK_COMBO_BOX_TEXT( texture_combo ), (const char *)lst->data );
|
|
}
|
|
g_list_free( items );
|
|
|
|
// If the texture name is not conflicting for the faces list, select the newly added item
|
|
if ( !is_TextureName_conflicting ) {
|
|
gtk_combo_box_set_active( GTK_COMBO_BOX( texture_combo ), 0);
|
|
}
|
|
}
|
|
|
|
static void GetTexdefInfo_from_Radiant(){
|
|
g_texdef_face_vector.clear();
|
|
|
|
unsigned int count = GetSelectedFaceCountfromBrushes();
|
|
if ( count == 0 ) {
|
|
count = GetSelectedFaceCount();
|
|
}
|
|
|
|
g_texdef_face_vector.resize( count );
|
|
|
|
if ( !texdef_face_list_empty() ) {
|
|
GetSelFacesTexdef( get_texdef_face_list() );
|
|
}
|
|
|
|
IsFaceConflicting();
|
|
PopulateTextureComboList();
|
|
if ( texdef_face_list_empty() ) {
|
|
set_surface_flags_button_state( get_texdef_face_list(), TRUE );
|
|
}
|
|
else{
|
|
set_surface_flags_button_state( get_texdef_face_list(), FALSE );
|
|
}
|
|
}
|
|
|
|
static gint delete_event_callback( GtkWidget *widget, GdkEvent* event, gpointer data ){
|
|
HideDlg();
|
|
return TRUE;
|
|
}
|
|
|
|
static gint surface_inspector_key_press_event( GtkWidget *widget, GdkEventKey* event, gpointer data ) {
|
|
if ( event->keyval == GDK_KEY_Escape ) {
|
|
HideDlg();
|
|
return TRUE;
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
// make the shift increments match the grid settings
|
|
// the objective being that the shift+arrows shortcuts move the texture by the corresponding grid size
|
|
// this depends on a scale value if you have selected a particular texture on which you want it to work:
|
|
// we move the textures in pixels, not world units. (i.e. increment values are in pixel)
|
|
// depending on the texture scale it doesn't take the same amount of pixels to move of g_qeglobals.d_gridsize
|
|
// increment * scale = gridsize
|
|
// hscale and vscale are optional parameters, if they are zero they will be set to the default scale
|
|
// NOTE: the default scale depends if you are using BP mode or regular.
|
|
// For regular it's 0.5f (128 pixels cover 64 world units), for BP it's simply 1.0f
|
|
// see fenris #2810
|
|
void DoSnapTToGrid( float hscale, float vscale ){
|
|
l_pIncrement = Get_SI_Inc();
|
|
|
|
if ( hscale == 0.0f ) {
|
|
hscale = l_pIncrement->scale[0];
|
|
}
|
|
if ( vscale == 0.0f ) {
|
|
vscale = l_pIncrement->scale[1];
|
|
}
|
|
#ifdef _DEBUG
|
|
Sys_Printf( "DoSnapToGrid: grid %g hscale %g vscale %g\n", GridSize(), hscale, vscale );
|
|
#endif
|
|
l_pIncrement->shift[0] = GridSize() / hscale;
|
|
l_pIncrement->shift[1] = GridSize() / vscale;
|
|
// now some update work
|
|
// FIXME: doesn't look good here, seems to be called several times
|
|
SetTexMods();
|
|
}
|
|
|
|
void UpdateSurfaceDialog(){
|
|
if ( !g_bListenUpdate ) {
|
|
return;
|
|
}
|
|
|
|
if ( !SurfaceInspector ) {
|
|
return;
|
|
}
|
|
|
|
// avoid long delays on slow computers
|
|
while ( gtk_events_pending() )
|
|
gtk_main_iteration();
|
|
|
|
if ( g_surfwin ) {
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "UpdateSurfaceDialog\n" );
|
|
#endif
|
|
GetTexdefInfo_from_Radiant();
|
|
SetTexMods();
|
|
}
|
|
|
|
}
|
|
|
|
// DoSurface will always try to show the surface inspector
|
|
// or update it because something new has been selected
|
|
void DoSurface( void ){
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "DoSurface\n" );
|
|
#endif
|
|
if ( !SurfaceInspector ) {
|
|
create_SurfaceInspector();
|
|
}
|
|
|
|
ShowDlg();
|
|
SetTexMods();
|
|
}
|
|
|
|
void ToggleSurface(){
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "ToggleSurface Module\n" );
|
|
#endif
|
|
if ( !g_surfwin ) {
|
|
DoSurface();
|
|
}
|
|
else {
|
|
HideDlg();
|
|
}
|
|
}
|
|
|
|
// NOTE: will raise and show the Surface inspector and exec fit for patches and brushes
|
|
void SurfaceDlgFitAll(){
|
|
DoSurface();
|
|
FitAll();
|
|
}
|
|
|
|
// =============================================================================
|
|
// SurfaceDialog class
|
|
|
|
void ShowDlg(){
|
|
|
|
if ( !SurfaceInspector ) {
|
|
create_SurfaceInspector();
|
|
} else {
|
|
gtk_widget_show( SurfaceInspector );
|
|
}
|
|
|
|
GetTexdefInfo_from_Radiant();
|
|
GetTexMods( TRUE ); // Set Initial Undo Point
|
|
g_surfwin = TRUE;
|
|
}
|
|
|
|
void HideDlg(){
|
|
g_bListenUpdate = FALSE;
|
|
g_bListenChanged = FALSE;
|
|
g_surfwin = FALSE;
|
|
m_nUndoId = 0;
|
|
|
|
gtk_widget_hide( SurfaceInspector );
|
|
}
|
|
|
|
// set default values for increments (shift scale and rot)
|
|
// this is called by the prefs code if can't find the values
|
|
void InitDefaultIncrement( texdef_t *tex ){
|
|
tex->SetName( "" );
|
|
tex->shift[0] = 8;
|
|
tex->shift[1] = 8;
|
|
tex->scale[0] = 0.125;
|
|
tex->scale[1] = 0.125;
|
|
tex->rotate = 5;
|
|
}
|
|
|
|
void BuildDialog(){
|
|
if ( !SurfaceInspector ) {
|
|
create_SurfaceInspector();
|
|
}
|
|
}
|
|
|
|
/*
|
|
==============
|
|
SetTexMods
|
|
|
|
Set the fields to the current texdef (i.e. map/texdef -> dialog widgets)
|
|
===============
|
|
*/
|
|
|
|
void SetTexMods(){
|
|
texdef_t *pt;
|
|
GtkSpinButton *spin;
|
|
GtkAdjustment *adjust;
|
|
|
|
texturewin = Texturewin();
|
|
l_pIncrement = Get_SI_Inc();
|
|
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "SurfaceDlg SetTexMods\n" );
|
|
#endif
|
|
|
|
if ( !g_surfwin ) {
|
|
return;
|
|
}
|
|
|
|
pt = &texturewin->texdef;
|
|
|
|
g_bListenChanged = FALSE;
|
|
|
|
if ( strncmp( texturewin->texdef.GetName(), "textures/", 9 ) != 0 ) {
|
|
texdef_SI_values.SetName( SHADER_NOT_FOUND );
|
|
}
|
|
|
|
spin = GTK_SPIN_BUTTON( hshift_value_spinbutton );
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( spin ) );
|
|
gtk_adjustment_set_step_increment( adjust, l_pIncrement->shift[0] );
|
|
spin = GTK_SPIN_BUTTON( hshift_step_spinbutton );
|
|
gtk_spin_button_set_value( spin, l_pIncrement->shift[0] );
|
|
gtk_spin_button_set_increments( spin, l_pIncrement->shift[0], l_pIncrement->shift[0] );
|
|
|
|
spin = GTK_SPIN_BUTTON( vshift_value_spinbutton );
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( spin ) );
|
|
gtk_adjustment_set_step_increment( adjust, l_pIncrement->shift[1] );
|
|
spin = GTK_SPIN_BUTTON( vshift_step_spinbutton );
|
|
gtk_spin_button_set_value( spin, l_pIncrement->shift[1] );
|
|
gtk_spin_button_set_increments( spin, l_pIncrement->shift[1], l_pIncrement->shift[1] );
|
|
|
|
spin = GTK_SPIN_BUTTON( hscale_value_spinbutton );
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( spin ) );
|
|
gtk_adjustment_set_step_increment( adjust, l_pIncrement->scale[0] );
|
|
spin = GTK_SPIN_BUTTON( hscale_step_spinbutton );
|
|
gtk_spin_button_set_value( spin, l_pIncrement->scale[0] );
|
|
gtk_spin_button_set_increments( spin, l_pIncrement->scale[0], l_pIncrement->scale[0] );
|
|
|
|
spin = GTK_SPIN_BUTTON( vscale_value_spinbutton );
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( spin ) );
|
|
gtk_adjustment_set_step_increment( adjust, l_pIncrement->scale[1] );
|
|
spin = GTK_SPIN_BUTTON( vscale_step_spinbutton );
|
|
gtk_spin_button_set_value( spin, l_pIncrement->scale[1] );
|
|
gtk_spin_button_set_increments( spin, l_pIncrement->scale[1], l_pIncrement->scale[1] );
|
|
|
|
spin = GTK_SPIN_BUTTON( rotate_value_spinbutton );
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( spin ) );
|
|
gtk_adjustment_set_step_increment( adjust, l_pIncrement->rotate );
|
|
spin = GTK_SPIN_BUTTON( rotate_step_spinbutton );
|
|
gtk_spin_button_set_value( spin, l_pIncrement->rotate );
|
|
gtk_spin_button_set_increments( spin, l_pIncrement->rotate, l_pIncrement->rotate );
|
|
|
|
g_bListenChanged = TRUE;
|
|
}
|
|
|
|
/*
|
|
==============
|
|
GetTexMods
|
|
|
|
Shows any changes to the main Radiant windows
|
|
===============
|
|
*/
|
|
void GetTexMods( bool b_SetUndoPoint ){
|
|
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "SurfaceDlg GetTexMods\n" );
|
|
#endif
|
|
|
|
if ( !texdef_face_list_empty() ) {
|
|
g_bListenUpdate = FALSE;
|
|
apply_surface_flags( get_texdef_face_list() );
|
|
SetTexdef_FaceList( get_texdef_face_list(), b_SetUndoPoint, FALSE );
|
|
g_bListenUpdate = TRUE;
|
|
|
|
if ( b_SetUndoPoint ) {
|
|
m_nUndoId = Undo_GetUndoId();
|
|
}
|
|
}
|
|
}
|
|
|
|
void FitAll(){
|
|
on_fit_button_clicked( NULL, NULL );
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
//
|
|
// GUI Section
|
|
//
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
GtkWidget* create_SurfaceInspector( void ){
|
|
|
|
GtkWidget *label;
|
|
GtkAdjustment *adjustment;
|
|
GtkSizeGroup *size_group;
|
|
GtkWidget *table1;
|
|
GtkWidget *table2;
|
|
|
|
GtkWidget *frame1;
|
|
GtkWidget *frame2;
|
|
|
|
GtkWidget *vbox1;
|
|
GtkWidget *hbox1;
|
|
|
|
SurfaceInspector = gtk_window_new( GTK_WINDOW_TOPLEVEL );
|
|
gtk_window_set_transient_for( GTK_WINDOW( SurfaceInspector ), GTK_WINDOW( g_pMainWidget ) );
|
|
gtk_container_set_border_width( GTK_CONTAINER( SurfaceInspector ), 4 );
|
|
gtk_window_set_title( GTK_WINDOW( SurfaceInspector ), _( "Surface Inspector" ) );
|
|
|
|
SetWinPos_from_Prefs( SurfaceInspector );
|
|
|
|
vbox1 = gtk_vbox_new( FALSE, 5 );
|
|
gtk_container_add( GTK_CONTAINER( SurfaceInspector ), vbox1 );
|
|
gtk_widget_show( vbox1 );
|
|
|
|
hbox1 = gtk_hbox_new( FALSE, 5 );
|
|
gtk_container_add( GTK_CONTAINER( vbox1 ), hbox1 );
|
|
gtk_container_set_border_width( GTK_CONTAINER( hbox1 ), 4 );
|
|
gtk_widget_show( hbox1 );
|
|
|
|
label = gtk_label_new( _( "Texture: " ) );
|
|
gtk_box_pack_start( GTK_BOX( hbox1 ), label, FALSE, FALSE, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
texture_combo = gtk_combo_box_text_new_with_entry();
|
|
gtk_box_pack_start( GTK_BOX( hbox1 ), texture_combo, TRUE, TRUE, 0 );
|
|
gtk_widget_show( texture_combo );
|
|
|
|
texture_combo_entry = gtk_bin_get_child( GTK_BIN( texture_combo ) );
|
|
gtk_entry_set_max_length( GTK_ENTRY( texture_combo_entry ), 1024 );
|
|
gtk_widget_show( texture_combo_entry );
|
|
|
|
frame1 = gtk_frame_new( _( "Surface" ) );
|
|
gtk_container_add( GTK_CONTAINER( vbox1 ), frame1 );
|
|
gtk_widget_show( frame1 );
|
|
|
|
table1 = gtk_table_new( 7, 3, FALSE );
|
|
gtk_table_set_col_spacings( GTK_TABLE( table1 ), 5 );
|
|
gtk_table_set_row_spacings( GTK_TABLE( table1 ), 5 );
|
|
gtk_container_set_border_width( GTK_CONTAINER( table1 ), 5 );
|
|
gtk_container_add( GTK_CONTAINER( frame1 ), table1 );
|
|
gtk_widget_show( table1 );
|
|
|
|
label = gtk_label_new( _( "Step" ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), label, 2, 3, 0, 1,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Value" ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), label, 1, 2, 0, 1,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Horizontal shift: " ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), label, 0, 1, 1, 2,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( GTK_FILL ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Vertical shift: " ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), label, 0, 1, 2, 3,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( GTK_FILL ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Horizontal scale: " ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), label, 0, 1, 3, 4,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( GTK_FILL ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Vertical scale: " ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), label, 0, 1, 4, 5,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( GTK_FILL ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Rotate: " ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), label, 0, 1, 5, 6,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( GTK_FILL ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
// Value Spins
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -8192.0, 8192.0, 2.0, 8.0, 0.0 ) );
|
|
hshift_value_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 2 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), hshift_value_spinbutton, 1, 2, 1, 2,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( hshift_value_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( hshift_value_spinbutton ), TRUE );
|
|
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON( hshift_value_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( hshift_value_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( hshift_value_spinbutton );
|
|
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -8192.0, 8192.0, 2.0, 8.0, 0.0 ) );
|
|
vshift_value_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 2 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), vshift_value_spinbutton, 1, 2, 2, 3,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( vshift_value_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( vshift_value_spinbutton ), TRUE );
|
|
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON( vshift_value_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( vshift_value_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( vshift_value_spinbutton );
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -1024.0, 1024.0, 1.0, 4.0, 0.0 ) );
|
|
hscale_value_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 4 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), hscale_value_spinbutton, 1, 2, 3, 4,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( hscale_value_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( hscale_value_spinbutton ), TRUE );
|
|
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON( hscale_value_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( hscale_value_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( hscale_value_spinbutton );
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -1024.0, 1024.0, 1.0, 4.0, 0.0 ) );
|
|
vscale_value_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 4 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), vscale_value_spinbutton, 1, 2, 4, 5,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( vscale_value_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( vscale_value_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( vscale_value_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( vscale_value_spinbutton );
|
|
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -360.0, 360.0, 1.0, 10.0, 0.0 ) );
|
|
rotate_value_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 2 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), rotate_value_spinbutton, 1, 2, 5, 6,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( rotate_value_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( rotate_value_spinbutton ), TRUE );
|
|
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON( rotate_value_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( rotate_value_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( rotate_value_spinbutton );
|
|
|
|
// Step Spins
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -8192.0, 8192.0, 2.0, 8.0, 0.0 ) );
|
|
hshift_step_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 2 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), hshift_step_spinbutton, 2, 3, 1, 2,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( hshift_step_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( hshift_step_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( hshift_step_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( hshift_step_spinbutton );
|
|
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -8192.0, 8192.0, 2.0, 8.0, 0.0 ) );
|
|
vshift_step_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 2 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), vshift_step_spinbutton, 2, 3, 2, 3,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( vshift_step_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( vshift_step_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( vshift_step_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( vshift_step_spinbutton );
|
|
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -1024.0, 1024.0, 1.0, 4.0, 0.0 ) );
|
|
hscale_step_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 4 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), hscale_step_spinbutton, 2, 3, 3, 4,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( hscale_step_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( hscale_step_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( hscale_step_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( hscale_step_spinbutton );
|
|
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -1024.0, 1024.0, 1.0, 4.0, 0.0 ) );
|
|
vscale_step_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 4 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), vscale_step_spinbutton, 2, 3, 4, 5,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( vscale_step_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( vscale_step_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( vscale_step_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( vscale_step_spinbutton );
|
|
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 0.0, -360.0, 360.0, 1.0, 10.0, 0.0 ) );
|
|
rotate_step_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 2 );
|
|
gtk_table_attach( GTK_TABLE( table1 ), rotate_step_spinbutton, 2, 3, 5, 6,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( rotate_step_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( rotate_step_spinbutton ), TRUE );
|
|
gtk_entry_set_alignment( GTK_ENTRY( rotate_step_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( rotate_step_spinbutton );
|
|
|
|
|
|
match_grid_button = gtk_button_new_with_mnemonic( _( "Match Grid" ) );
|
|
gtk_table_attach( GTK_TABLE( table1 ), match_grid_button, 2, 3, 6, 7,
|
|
(GtkAttachOptions) ( GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_widget_show( match_grid_button );
|
|
|
|
frame2 = gtk_frame_new( _( "Tools" ) );
|
|
gtk_container_add( GTK_CONTAINER( vbox1 ), frame2 );
|
|
gtk_widget_show( frame2 );
|
|
|
|
table2 = gtk_table_new( 2, 4, TRUE );
|
|
gtk_table_set_col_spacings( GTK_TABLE( table2), 5 );
|
|
gtk_table_set_row_spacings( GTK_TABLE( table2 ), 0 );
|
|
gtk_container_set_border_width( GTK_CONTAINER( table2 ), 5 );
|
|
gtk_container_add( GTK_CONTAINER( frame2 ), table2 );
|
|
gtk_widget_show( table2 );
|
|
|
|
label = gtk_label_new( _( "Height" ) );
|
|
gtk_table_attach( GTK_TABLE( table2 ), label, 3, 4, 0, 1,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Width" ) );
|
|
gtk_table_attach( GTK_TABLE( table2 ), label, 2, 3, 0, 1,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
label = gtk_label_new( _( "Brush" ) );
|
|
gtk_table_attach( GTK_TABLE( table2 ), label, 0, 2, 0, 1,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0, 0.5 );
|
|
gtk_widget_show( label );
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 1, 1, 32, 1, 10, 0 ) );
|
|
fit_height_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 0 );
|
|
gtk_table_attach( GTK_TABLE( table2 ), fit_height_spinbutton, 3, 4, 1, 2,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( fit_height_spinbutton ), TRUE );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( fit_height_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_entry_set_alignment( GTK_ENTRY( fit_height_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( fit_height_spinbutton );
|
|
|
|
adjustment = GTK_ADJUSTMENT( gtk_adjustment_new( 1, 1, 32, 1, 10, 0 ) );
|
|
fit_width_spinbutton = gtk_spin_button_new( GTK_ADJUSTMENT( adjustment ), 1, 0 );
|
|
gtk_table_attach( GTK_TABLE( table2 ), fit_width_spinbutton, 2, 3, 1, 2,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_spin_button_set_numeric( GTK_SPIN_BUTTON( fit_width_spinbutton ), TRUE );
|
|
gtk_spin_button_set_update_policy( GTK_SPIN_BUTTON( fit_width_spinbutton ), GTK_UPDATE_IF_VALID );
|
|
gtk_entry_set_alignment( GTK_ENTRY( fit_width_spinbutton ), 1.0 ); //right
|
|
gtk_widget_show( fit_width_spinbutton );
|
|
|
|
fit_button = gtk_button_new_with_mnemonic( _( "Fit" ) );
|
|
gtk_table_attach( GTK_TABLE( table2 ), fit_button, 1, 2, 1, 2,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_widget_show( fit_button );
|
|
|
|
axial_button = gtk_button_new_with_mnemonic( _( "Axial" ) );
|
|
gtk_table_attach( GTK_TABLE( table2 ), axial_button, 0, 1, 1, 2,
|
|
(GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ),
|
|
(GtkAttachOptions) ( 0 ), 0, 0 );
|
|
gtk_widget_show( axial_button );
|
|
|
|
size_group = gtk_size_group_new( GTK_SIZE_GROUP_BOTH );
|
|
gtk_size_group_add_widget( size_group, axial_button );
|
|
gtk_size_group_add_widget( size_group, fit_button );
|
|
g_object_unref( size_group );
|
|
|
|
// Add the SURF_ and CONTENTS_ flags frame
|
|
create_SurfaceFlagsFrame( vbox1 );
|
|
|
|
g_signal_connect( (gpointer) SurfaceInspector,
|
|
"delete-event",
|
|
G_CALLBACK( delete_event_callback ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) SurfaceInspector, "destroy",
|
|
G_CALLBACK( gtk_widget_destroy ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) SurfaceInspector, "key-press-event",
|
|
G_CALLBACK( surface_inspector_key_press_event ),
|
|
NULL );
|
|
|
|
g_signal_connect( (gpointer) texture_combo_entry, "key-press-event",
|
|
G_CALLBACK( on_texture_combo_entry_key_press_event ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) texture_combo_entry, "activate",
|
|
G_CALLBACK( on_texture_combo_entry_activate ),
|
|
NULL );
|
|
|
|
g_signal_connect( (gpointer) hshift_value_spinbutton, "value-changed",
|
|
G_CALLBACK( on_hshift_value_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) vshift_value_spinbutton, "value-changed",
|
|
G_CALLBACK( on_vshift_value_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) hscale_value_spinbutton, "value-changed",
|
|
G_CALLBACK( on_hscale_value_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) vscale_value_spinbutton, "value-changed",
|
|
G_CALLBACK( on_vscale_value_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) rotate_value_spinbutton, "value-changed",
|
|
G_CALLBACK( on_rotate_value_spinbutton_value_changed ),
|
|
NULL );
|
|
|
|
g_signal_connect( (gpointer) hshift_step_spinbutton, "value-changed",
|
|
G_CALLBACK( on_hshift_step_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) vshift_step_spinbutton, "value-changed",
|
|
G_CALLBACK( on_vshift_step_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) hscale_step_spinbutton, "value-changed",
|
|
G_CALLBACK( on_hscale_step_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) vscale_step_spinbutton, "value-changed",
|
|
G_CALLBACK( on_vscale_step_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) rotate_step_spinbutton, "value-changed",
|
|
G_CALLBACK( on_rotate_step_spinbutton_value_changed ),
|
|
NULL );
|
|
|
|
g_signal_connect( (gpointer) match_grid_button, "clicked",
|
|
G_CALLBACK( on_match_grid_button_clicked ),
|
|
NULL );
|
|
|
|
g_signal_connect( (gpointer) fit_width_spinbutton, "value-changed",
|
|
G_CALLBACK( on_fit_width_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) fit_height_spinbutton, "value-changed",
|
|
G_CALLBACK( on_fit_height_spinbutton_value_changed ),
|
|
NULL );
|
|
g_signal_connect( (gpointer) fit_button, "clicked",
|
|
G_CALLBACK( on_fit_button_clicked ),
|
|
NULL );
|
|
|
|
g_signal_connect( (gpointer) axial_button, "clicked",
|
|
G_CALLBACK( on_axial_button_clicked ),
|
|
NULL );
|
|
|
|
return SurfaceInspector;
|
|
}
|
|
|
|
|
|
// Texture Combo
|
|
gboolean on_texture_combo_entry_key_press_event( GtkWidget *widget, GdkEventKey *event,
|
|
gpointer user_data ){
|
|
// Have Tab activate selection as well as Return
|
|
if ( event->keyval == GDK_KEY_Tab ) {
|
|
g_signal_emit_by_name( texture_combo_entry, "activate" );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
void on_texture_combo_entry_activate( GtkEntry *entry, gpointer user_data ){
|
|
texdef_t* tmp_texdef;
|
|
texdef_t* tmp_orig_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
char text[128] = { 0 };
|
|
|
|
if ( !texdef_face_list_empty() && g_bListenChanged ) {
|
|
// activate only on entry change
|
|
strcpy( text, gtk_entry_get_text( entry ) );
|
|
if ( strcmp( old_texture_entry, text ) ) {
|
|
// Check for spaces in shader name
|
|
if ( text[0] <= ' ' || strchr( text, ' ' ) ) {
|
|
Sys_FPrintf( SYS_WRN, "WARNING: spaces in shader names are not allowed, ignoring '%s'\n", text );
|
|
}
|
|
else
|
|
{
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
tmp_orig_texdef = (texdef_t *) &temp_texdef_face_list->orig_texdef;
|
|
strcpy( old_texture_entry, text );
|
|
tmp_texdef->SetName( text );
|
|
}
|
|
GetTexMods();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// Match Grid
|
|
static void on_match_grid_button_clicked( GtkButton *button, gpointer user_data ){
|
|
float hscale, vscale;
|
|
|
|
if ( !strcmp( gtk_entry_get_text( GTK_ENTRY( hscale_value_spinbutton ) ), "" ) ) {
|
|
hscale = 0.0;
|
|
}
|
|
else{
|
|
hscale = gtk_spin_button_get_value( GTK_SPIN_BUTTON( hscale_value_spinbutton ) );
|
|
}
|
|
|
|
if ( !strcmp( gtk_entry_get_text( GTK_ENTRY( vscale_value_spinbutton ) ), "" ) ) {
|
|
vscale = 0.0;
|
|
}
|
|
else{
|
|
vscale = gtk_spin_button_get_value( GTK_SPIN_BUTTON( vscale_value_spinbutton ) );
|
|
}
|
|
DoSnapTToGrid( hscale, vscale );
|
|
}
|
|
|
|
// Value Spins
|
|
static void on_hshift_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
texdef_t* tmp_texdef;
|
|
texdef_t* tmp_orig_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
|
|
texdef_SI_values.shift[0] = gtk_spin_button_get_value( GTK_SPIN_BUTTON( hshift_value_spinbutton ) );
|
|
|
|
if ( !texdef_face_list_empty() && g_bListenChanged ) {
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
tmp_orig_texdef = (texdef_t *) &temp_texdef_face_list->orig_texdef;
|
|
tmp_texdef->shift[0] = texdef_SI_values.shift[0];
|
|
is_HShift_conflicting = FALSE;
|
|
}
|
|
GetTexMods();
|
|
}
|
|
}
|
|
|
|
static void on_vshift_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
texdef_t* tmp_texdef;
|
|
texdef_t* tmp_orig_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
|
|
texdef_SI_values.shift[1] = gtk_spin_button_get_value( GTK_SPIN_BUTTON( vshift_value_spinbutton ) );
|
|
|
|
if ( !texdef_face_list_empty() && g_bListenChanged ) {
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
tmp_orig_texdef = (texdef_t *) &temp_texdef_face_list->orig_texdef;
|
|
tmp_texdef->shift[1] = texdef_SI_values.shift[1];
|
|
is_VShift_conflicting = FALSE;
|
|
}
|
|
GetTexMods();
|
|
}
|
|
}
|
|
|
|
static void on_hscale_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
texdef_t* tmp_texdef;
|
|
texdef_t* tmp_orig_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
|
|
texdef_SI_values.scale[0] = gtk_spin_button_get_value( GTK_SPIN_BUTTON( hscale_value_spinbutton ) );
|
|
|
|
if ( !texdef_face_list_empty() && g_bListenChanged ) {
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
tmp_orig_texdef = (texdef_t *) &temp_texdef_face_list->orig_texdef;
|
|
tmp_texdef->scale[0] = texdef_SI_values.scale[0];
|
|
is_HScale_conflicting = FALSE;
|
|
}
|
|
GetTexMods();
|
|
}
|
|
}
|
|
|
|
static void on_vscale_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
texdef_t* tmp_texdef;
|
|
texdef_t* tmp_orig_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
|
|
texdef_SI_values.scale[1] = gtk_spin_button_get_value( GTK_SPIN_BUTTON( vscale_value_spinbutton ) );
|
|
|
|
if ( !texdef_face_list_empty() && g_bListenChanged ) {
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
tmp_orig_texdef = (texdef_t *) &temp_texdef_face_list->orig_texdef;
|
|
tmp_texdef->scale[1] = texdef_SI_values.scale[1];
|
|
is_VScale_conflicting = FALSE;
|
|
}
|
|
GetTexMods();
|
|
}
|
|
}
|
|
|
|
static void on_rotate_value_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
texdef_t* tmp_texdef;
|
|
texdef_t* tmp_orig_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
|
|
texdef_SI_values.rotate = gtk_spin_button_get_value( GTK_SPIN_BUTTON( rotate_value_spinbutton ) );
|
|
|
|
if ( !texdef_face_list_empty() && g_bListenChanged ) {
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
tmp_orig_texdef = (texdef_t *) &temp_texdef_face_list->orig_texdef;
|
|
tmp_texdef->rotate = texdef_SI_values.rotate;
|
|
is_Rotate_conflicting = FALSE;
|
|
}
|
|
GetTexMods();
|
|
}
|
|
}
|
|
|
|
|
|
// Step Spins
|
|
static void on_hshift_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
gfloat val;
|
|
GtkAdjustment * adjust;
|
|
|
|
if ( !g_bListenChanged ) {
|
|
return;
|
|
}
|
|
|
|
l_pIncrement = Get_SI_Inc();
|
|
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "OnIncrementChanged HShift\n" );
|
|
#endif
|
|
|
|
val = gtk_spin_button_get_value( GTK_SPIN_BUTTON( hshift_step_spinbutton ) ) ;
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( hshift_value_spinbutton ) );
|
|
gtk_adjustment_set_step_increment( adjust, val );
|
|
l_pIncrement->shift[0] = val;
|
|
}
|
|
|
|
static void on_vshift_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
gfloat val;
|
|
GtkAdjustment * adjust;
|
|
|
|
if ( !g_bListenChanged ) {
|
|
return;
|
|
}
|
|
|
|
l_pIncrement = Get_SI_Inc();
|
|
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "OnIncrementChanged VShift\n" );
|
|
#endif
|
|
|
|
val = gtk_spin_button_get_value( GTK_SPIN_BUTTON( vshift_step_spinbutton ) ) ;
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( vshift_value_spinbutton ) );
|
|
gtk_adjustment_set_step_increment( adjust, val );
|
|
l_pIncrement->shift[1] = val;
|
|
}
|
|
|
|
static void on_hscale_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
gfloat val;
|
|
GtkAdjustment * adjust;
|
|
|
|
if ( !g_bListenChanged ) {
|
|
return;
|
|
}
|
|
|
|
l_pIncrement = Get_SI_Inc();
|
|
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "OnIncrementChanged HScale\n" );
|
|
#endif
|
|
|
|
val = gtk_spin_button_get_value( GTK_SPIN_BUTTON( hscale_step_spinbutton ) ) ;
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( hscale_value_spinbutton ) );
|
|
gtk_adjustment_set_step_increment( adjust, val );
|
|
l_pIncrement->scale[0] = val;
|
|
}
|
|
|
|
static void on_vscale_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
gfloat val;
|
|
GtkAdjustment * adjust;
|
|
|
|
if ( !g_bListenChanged ) {
|
|
return;
|
|
}
|
|
|
|
l_pIncrement = Get_SI_Inc();
|
|
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "OnIncrementChanged VScale\n" );
|
|
#endif
|
|
|
|
val = gtk_spin_button_get_value( GTK_SPIN_BUTTON( vscale_step_spinbutton ) ) ;
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( vscale_value_spinbutton ) );
|
|
gtk_adjustment_set_step_increment( adjust, val );
|
|
l_pIncrement->scale[1] = val;
|
|
}
|
|
|
|
static void on_rotate_step_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
gfloat val;
|
|
GtkAdjustment * adjust;
|
|
|
|
if ( !g_bListenChanged ) {
|
|
return;
|
|
}
|
|
|
|
l_pIncrement = Get_SI_Inc();
|
|
|
|
#ifdef DBG_SI
|
|
Sys_Printf( "OnIncrementChanged Rotate\n" );
|
|
#endif
|
|
|
|
val = gtk_spin_button_get_value( GTK_SPIN_BUTTON( rotate_step_spinbutton ) ) ;
|
|
adjust = gtk_spin_button_get_adjustment( GTK_SPIN_BUTTON( rotate_value_spinbutton ) );
|
|
gtk_adjustment_set_step_increment( adjust, val );
|
|
l_pIncrement->rotate = val;
|
|
}
|
|
|
|
|
|
// Fit Texture
|
|
static void on_fit_width_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
m_nWidth = gtk_spin_button_get_value_as_int( GTK_SPIN_BUTTON( fit_width_spinbutton ) );
|
|
}
|
|
|
|
static void on_fit_height_spinbutton_value_changed( GtkSpinButton *spinbutton, gpointer user_data ){
|
|
m_nHeight = gtk_spin_button_get_value_as_int( GTK_SPIN_BUTTON( fit_height_spinbutton ) );
|
|
}
|
|
|
|
static void on_fit_button_clicked( GtkButton *button, gpointer user_data ){
|
|
FaceList_FitTexture( get_texdef_face_list(), m_nHeight, m_nWidth );
|
|
Sys_UpdateWindows( W_ALL );
|
|
}
|
|
|
|
// Axial Button
|
|
static void on_axial_button_clicked( GtkButton *button, gpointer user_data ){
|
|
texdef_t* tmp_texdef;
|
|
texdef_to_face_t* temp_texdef_face_list;
|
|
|
|
if ( !texdef_face_list_empty() && g_bListenChanged ) {
|
|
for ( temp_texdef_face_list = get_texdef_face_list(); temp_texdef_face_list; temp_texdef_face_list = temp_texdef_face_list->next )
|
|
{
|
|
tmp_texdef = (texdef_t *) &temp_texdef_face_list->texdef;
|
|
tmp_texdef->shift[0] = 0.0;
|
|
tmp_texdef->shift[1] = 0.0;
|
|
tmp_texdef->scale[0] = 0.5;
|
|
tmp_texdef->scale[1] = 0.5;
|
|
tmp_texdef->rotate = 0.0;
|
|
}
|
|
}
|
|
|
|
SetTexdef_FaceList( get_texdef_face_list(), FALSE, TRUE );
|
|
Sys_UpdateWindows( W_ALL );
|
|
}
|