mirror of
https://github.com/TTimo/GtkRadiant.git
synced 2025-01-10 03:51:18 +00:00
Merge branch 'Pan7-hollow'
This commit is contained in:
commit
46480bc4cf
6 changed files with 40 additions and 15 deletions
|
@ -445,6 +445,7 @@ typedef void ( *PFN_QERAPP_POINTFILECLEAR )();
|
||||||
typedef void ( *PFN_QERAPP_SYSSETTITLE )( const char *text );
|
typedef void ( *PFN_QERAPP_SYSSETTITLE )( const char *text );
|
||||||
|
|
||||||
typedef void ( *PFN_QERAPP_CSGMAKEHOLLOW )();
|
typedef void ( *PFN_QERAPP_CSGMAKEHOLLOW )();
|
||||||
|
typedef void ( *PFN_QERAPP_CSGMAKEHOLLOWMODE )( int mode );
|
||||||
|
|
||||||
typedef void ( *PFN_QERAPP_REGIONSPAWNPOINT )( FILE *f );
|
typedef void ( *PFN_QERAPP_REGIONSPAWNPOINT )( FILE *f );
|
||||||
|
|
||||||
|
@ -490,13 +491,6 @@ typedef bfilter_t* ( *PFN_QERPLUG_FILTERADD )( int type, int bmask, const char *
|
||||||
|
|
||||||
typedef void ( *PFN_QERPLUG_FILTERACTIVATE )( void );
|
typedef void ( *PFN_QERPLUG_FILTERACTIVATE )( void );
|
||||||
|
|
||||||
// FIXME:
|
|
||||||
// add map format extensions
|
|
||||||
// add texture format handlers
|
|
||||||
// add surface dialog handler
|
|
||||||
// add model handler/displayer
|
|
||||||
|
|
||||||
// v1 func table
|
|
||||||
// Plugins need to declare one of these and implement the getfunctable as described above
|
// Plugins need to declare one of these and implement the getfunctable as described above
|
||||||
struct _QERFuncTable_1
|
struct _QERFuncTable_1
|
||||||
{
|
{
|
||||||
|
@ -530,7 +524,6 @@ struct _QERFuncTable_1
|
||||||
PFN_QERAPP_RELEASEACTIVEBRUSHHANDLES m_pfnReleaseActiveBrushHandles;
|
PFN_QERAPP_RELEASEACTIVEBRUSHHANDLES m_pfnReleaseActiveBrushHandles;
|
||||||
PFN_QERAPP_GETACTIVEBRUSHHANDLE m_pfnGetActiveBrushHandle;
|
PFN_QERAPP_GETACTIVEBRUSHHANDLE m_pfnGetActiveBrushHandle;
|
||||||
|
|
||||||
//++timo this would need to be removed and replaced by the IShaders interface
|
|
||||||
PFN_QERAPP_TEXTURECOUNT m_pfnTextureCount;
|
PFN_QERAPP_TEXTURECOUNT m_pfnTextureCount;
|
||||||
PFN_QERAPP_GETTEXTURE m_pfnGetTexture;
|
PFN_QERAPP_GETTEXTURE m_pfnGetTexture;
|
||||||
PFN_QERAPP_GETCURRENTTEXTURE m_pfnGetCurrentTexture;
|
PFN_QERAPP_GETCURRENTTEXTURE m_pfnGetCurrentTexture;
|
||||||
|
@ -616,11 +609,10 @@ struct _QERFuncTable_1
|
||||||
PFN_QERAPP_MAPSTARTPOSITION m_pfnMapStartPosition;
|
PFN_QERAPP_MAPSTARTPOSITION m_pfnMapStartPosition;
|
||||||
PFN_QERAPP_MAPREGIONOFF m_pfnMapRegionOff;
|
PFN_QERAPP_MAPREGIONOFF m_pfnMapRegionOff;
|
||||||
PFN_QERAPP_SETBUILDWINDINGSNOTEXBUILD m_pfnSetBuildWindingsNoTexBuild;
|
PFN_QERAPP_SETBUILDWINDINGSNOTEXBUILD m_pfnSetBuildWindingsNoTexBuild;
|
||||||
// PFN_QERAPP_SAVEASDIALOG m_pfnSaveAsDialog;
|
|
||||||
PFN_QERAPP_POINTFILECLEAR m_pfnPointFileClear;
|
PFN_QERAPP_POINTFILECLEAR m_pfnPointFileClear;
|
||||||
|
|
||||||
// FIXME TTimo prolly want to move that somewhere else
|
|
||||||
PFN_QERAPP_CSGMAKEHOLLOW m_pfnCSG_MakeHollow;
|
PFN_QERAPP_CSGMAKEHOLLOW m_pfnCSG_MakeHollow;
|
||||||
|
PFN_QERAPP_CSGMAKEHOLLOWMODE m_pfnCSG_MakeHollowMode;
|
||||||
|
|
||||||
PFN_QERAPP_REGIONSPAWNPOINT m_pfnRegionSpawnPoint;
|
PFN_QERAPP_REGIONSPAWNPOINT m_pfnRegionSpawnPoint;
|
||||||
PFN_QERAPP_GETTICKCOUNT m_pfnQGetTickCount;
|
PFN_QERAPP_GETTICKCOUNT m_pfnQGetTickCount;
|
||||||
|
@ -642,6 +634,7 @@ struct _QERFuncTable_1
|
||||||
#define __QERTABLENAME g_FuncTable
|
#define __QERTABLENAME g_FuncTable
|
||||||
#endif
|
#endif
|
||||||
#define CSG_MakeHollow __QERTABLENAME.m_pfnCSG_MakeHollow
|
#define CSG_MakeHollow __QERTABLENAME.m_pfnCSG_MakeHollow
|
||||||
|
#define CSG_MakeHollowMode __QERTABLENAME.m_pfnCSG_MakeHollowMode
|
||||||
#define Sys_Beep __QERTABLENAME.m_pfnSysBeep
|
#define Sys_Beep __QERTABLENAME.m_pfnSysBeep
|
||||||
#define Sys_Printf __QERTABLENAME.m_pfnSysPrintf
|
#define Sys_Printf __QERTABLENAME.m_pfnSysPrintf
|
||||||
#define Sys_FPrintf __QERTABLENAME.m_pfnSysFPrintf
|
#define Sys_FPrintf __QERTABLENAME.m_pfnSysFPrintf
|
||||||
|
|
|
@ -39,7 +39,10 @@ void Brush_Scale( brush_t* b ){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSG_MakeHollow( void ){
|
void CSG_MakeHollow(){
|
||||||
|
CSG_MakeHollowMode( CSG_HOLLOW_MODE_OVERLAP );
|
||||||
|
}
|
||||||
|
void CSG_MakeHollowMode( int mode ){
|
||||||
brush_t *b, *front, *back, *next;
|
brush_t *b, *front, *back, *next;
|
||||||
face_t *f;
|
face_t *f;
|
||||||
face_t split;
|
face_t split;
|
||||||
|
@ -59,8 +62,11 @@ void CSG_MakeHollow( void ){
|
||||||
split = *f;
|
split = *f;
|
||||||
VectorScale( f->plane.normal, g_qeglobals.d_gridsize, move );
|
VectorScale( f->plane.normal, g_qeglobals.d_gridsize, move );
|
||||||
for ( i = 0 ; i < 3 ; i++ )
|
for ( i = 0 ; i < 3 ; i++ )
|
||||||
VectorSubtract( split.planepts[i], move, split.planepts[i] );
|
if( mode == CSG_HOLLOW_MODE_TOUCH ) {
|
||||||
|
VectorAdd( f->planepts[i], move, f->planepts[i] );
|
||||||
|
} else {
|
||||||
|
VectorSubtract( split.planepts[i], move, split.planepts[i] );
|
||||||
|
}
|
||||||
Brush_SplitBrushByFace( b, &split, &front, &back );
|
Brush_SplitBrushByFace( b, &split, &front, &back );
|
||||||
if ( back ) {
|
if ( back ) {
|
||||||
Brush_Free( back );
|
Brush_Free( back );
|
||||||
|
@ -68,6 +74,9 @@ void CSG_MakeHollow( void ){
|
||||||
if ( front ) {
|
if ( front ) {
|
||||||
Brush_AddToList( front, &selected_brushes );
|
Brush_AddToList( front, &selected_brushes );
|
||||||
}
|
}
|
||||||
|
if( mode == CSG_HOLLOW_MODE_TOUCH ) {
|
||||||
|
*f = split;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Brush_Free( b );
|
Brush_Free( b );
|
||||||
}
|
}
|
||||||
|
|
|
@ -509,6 +509,7 @@ gint HandleCommand( GtkWidget *widget, gpointer data ){
|
||||||
case ID_SELECTION_ARBITRARYROTATION: g_pParentWnd->OnSelectionArbitraryrotation(); break;
|
case ID_SELECTION_ARBITRARYROTATION: g_pParentWnd->OnSelectionArbitraryrotation(); break;
|
||||||
case ID_SELECT_SCALE: g_pParentWnd->OnSelectScale(); break;
|
case ID_SELECT_SCALE: g_pParentWnd->OnSelectScale(); break;
|
||||||
case ID_SELECTION_MAKEHOLLOW: g_pParentWnd->OnSelectionMakehollow(); break;
|
case ID_SELECTION_MAKEHOLLOW: g_pParentWnd->OnSelectionMakehollow(); break;
|
||||||
|
case ID_SELECTION_MAKEHOLLOW_TOUCH: g_pParentWnd->OnSelectionMakehollowTouch(); break;
|
||||||
case ID_SELECTION_CSGSUBTRACT: g_pParentWnd->OnSelectionCsgsubtract(); break;
|
case ID_SELECTION_CSGSUBTRACT: g_pParentWnd->OnSelectionCsgsubtract(); break;
|
||||||
case ID_SELECTION_CSGMERGE: g_pParentWnd->OnSelectionCsgmerge(); break;
|
case ID_SELECTION_CSGMERGE: g_pParentWnd->OnSelectionCsgmerge(); break;
|
||||||
case ID_SELECTION_NOOUTLINE: g_pParentWnd->OnSelectionNoOutline(); break;
|
case ID_SELECTION_NOOUTLINE: g_pParentWnd->OnSelectionNoOutline(); break;
|
||||||
|
@ -1209,8 +1210,10 @@ void MainFrame::create_main_menu( GtkWidget *window, GtkWidget *vbox ){
|
||||||
menu_separator( menu );
|
menu_separator( menu );
|
||||||
create_menu_item_with_mnemonic( menu, _( "Scale..." ), GTK_SIGNAL_FUNC( HandleCommand ), ID_SELECT_SCALE );
|
create_menu_item_with_mnemonic( menu, _( "Scale..." ), GTK_SIGNAL_FUNC( HandleCommand ), ID_SELECT_SCALE );
|
||||||
menu_in_menu = create_menu_in_menu_with_mnemonic( menu, _( "CSG" ) );
|
menu_in_menu = create_menu_in_menu_with_mnemonic( menu, _( "CSG" ) );
|
||||||
create_menu_item_with_mnemonic( menu_in_menu, _( "Make _Hollow" ),
|
create_menu_item_with_mnemonic( menu_in_menu, _( "Make _Hollow Overlap" ),
|
||||||
GTK_SIGNAL_FUNC( HandleCommand ), ID_SELECTION_MAKEHOLLOW );
|
GTK_SIGNAL_FUNC( HandleCommand ), ID_SELECTION_MAKEHOLLOW );
|
||||||
|
create_menu_item_with_mnemonic( menu_in_menu, _( "Make _Hollow Touch" ),
|
||||||
|
G_CALLBACK( HandleCommand ), ID_SELECTION_MAKEHOLLOW_TOUCH );
|
||||||
create_menu_item_with_mnemonic( menu_in_menu, _( "CSG _Subtract" ),
|
create_menu_item_with_mnemonic( menu_in_menu, _( "CSG _Subtract" ),
|
||||||
GTK_SIGNAL_FUNC( HandleCommand ), ID_SELECTION_CSGSUBTRACT );
|
GTK_SIGNAL_FUNC( HandleCommand ), ID_SELECTION_CSGSUBTRACT );
|
||||||
create_menu_item_with_mnemonic( menu_in_menu, _( "CSG _Merge" ),
|
create_menu_item_with_mnemonic( menu_in_menu, _( "CSG _Merge" ),
|
||||||
|
@ -1768,10 +1771,14 @@ void MainFrame::create_main_toolbar( GtkWidget *window, GtkWidget *vbox ){
|
||||||
g_object_set_data( G_OBJECT( window ), "tb_selection_csgmerge", w );
|
g_object_set_data( G_OBJECT( window ), "tb_selection_csgmerge", w );
|
||||||
}
|
}
|
||||||
|
|
||||||
w = gtk_toolbar_append_item( GTK_TOOLBAR( toolbar ), "", _( "Hollow" ), "",
|
w = gtk_toolbar_append_item( GTK_TOOLBAR( toolbar ), "", _( "Hollow Overlap" ), "",
|
||||||
new_image_icon("selection_makehollow.png"),
|
new_image_icon("selection_makehollow.png"),
|
||||||
GTK_SIGNAL_FUNC( HandleCommand ), GINT_TO_POINTER( ID_SELECTION_MAKEHOLLOW ) );
|
GTK_SIGNAL_FUNC( HandleCommand ), GINT_TO_POINTER( ID_SELECTION_MAKEHOLLOW ) );
|
||||||
g_object_set_data( G_OBJECT( window ), "tb_selection_makehollow", w );
|
g_object_set_data( G_OBJECT( window ), "tb_selection_makehollow", w );
|
||||||
|
w = gtk_toolbar_append_item( GTK_TOOLBAR( toolbar ), "", _( "Hollow Touch" ), "",
|
||||||
|
new_image_icon("selection_makehollow.png"),
|
||||||
|
G_CALLBACK( HandleCommand ), GINT_TO_POINTER( ID_SELECTION_MAKEHOLLOW_TOUCH ) );
|
||||||
|
g_object_set_data( G_OBJECT( window ), "tb_selection_makehollow_touch", w );
|
||||||
|
|
||||||
if ( g_PrefsDlg.m_bWideToolbar ) {
|
if ( g_PrefsDlg.m_bWideToolbar ) {
|
||||||
w = gtk_toolbar_append_element( GTK_TOOLBAR( toolbar ), GTK_TOOLBAR_CHILD_TOGGLEBUTTON, NULL,
|
w = gtk_toolbar_append_element( GTK_TOOLBAR( toolbar ), GTK_TOOLBAR_CHILD_TOGGLEBUTTON, NULL,
|
||||||
|
@ -5381,6 +5388,16 @@ void MainFrame::OnSelectionMakehollow(){
|
||||||
Undo_End();
|
Undo_End();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainFrame::OnSelectionMakehollowTouch(){
|
||||||
|
//if (ActiveXY())
|
||||||
|
// ActiveXY()->UndoCopy();
|
||||||
|
Undo_Start( "hollow" );
|
||||||
|
Undo_AddBrushList( &selected_brushes );
|
||||||
|
CSG_MakeHollowMode( CSG_HOLLOW_MODE_TOUCH );
|
||||||
|
Undo_EndBrushList( &selected_brushes );
|
||||||
|
Undo_End();
|
||||||
|
}
|
||||||
|
|
||||||
void MainFrame::OnSelectionCsgsubtract(){
|
void MainFrame::OnSelectionCsgsubtract(){
|
||||||
Undo_Start( "CSG subtract" );
|
Undo_Start( "CSG subtract" );
|
||||||
CSG_Subtract();
|
CSG_Subtract();
|
||||||
|
|
|
@ -263,6 +263,7 @@ struct SKeyInfo
|
||||||
#define ID_REGION_SETXY 40044
|
#define ID_REGION_SETXY 40044
|
||||||
#define ID_REGION_SETBRUSH 40045
|
#define ID_REGION_SETBRUSH 40045
|
||||||
#define ID_SELECTION_MAKEHOLLOW 40046
|
#define ID_SELECTION_MAKEHOLLOW 40046
|
||||||
|
#define ID_SELECTION_MAKEHOLLOW_TOUCH 40051
|
||||||
#define ID_SELECTION_SELECTPARTIALTALL 40047
|
#define ID_SELECTION_SELECTPARTIALTALL 40047
|
||||||
#define ID_SELECTION_SELECTCOMPLETETALL 40048
|
#define ID_SELECTION_SELECTCOMPLETETALL 40048
|
||||||
#define ID_SELECTION_CSGSUBTRACT 40049
|
#define ID_SELECTION_CSGSUBTRACT 40049
|
||||||
|
@ -682,6 +683,7 @@ void OnSelectionDragvertecies();
|
||||||
void OnSelectionMakeDetail();
|
void OnSelectionMakeDetail();
|
||||||
void OnSelectionMakeStructural();
|
void OnSelectionMakeStructural();
|
||||||
void OnSelectionMakehollow();
|
void OnSelectionMakehollow();
|
||||||
|
void OnSelectionMakehollowTouch();
|
||||||
void OnSelectionSelectcompletetall();
|
void OnSelectionSelectcompletetall();
|
||||||
void OnSelectionSelectinside();
|
void OnSelectionSelectinside();
|
||||||
void OnSelectionSelectpartialtall();
|
void OnSelectionSelectpartialtall();
|
||||||
|
|
|
@ -2063,6 +2063,7 @@ bool CSynapseClientRadiant::RequestAPI( APIDescriptor_t *pAPI ){
|
||||||
pTable->m_pfnSetBuildWindingsNoTexBuild = &Brush_SetBuildWindingsNoTexBuild;
|
pTable->m_pfnSetBuildWindingsNoTexBuild = &Brush_SetBuildWindingsNoTexBuild;
|
||||||
pTable->m_pfnPointFileClear = &Pointfile_Clear;
|
pTable->m_pfnPointFileClear = &Pointfile_Clear;
|
||||||
pTable->m_pfnCSG_MakeHollow = &CSG_MakeHollow;
|
pTable->m_pfnCSG_MakeHollow = &CSG_MakeHollow;
|
||||||
|
pTable->m_pfnCSG_MakeHollowMode = &CSG_MakeHollowMode;
|
||||||
pTable->m_pfnRegionSpawnPoint = &Region_SpawnPoint;
|
pTable->m_pfnRegionSpawnPoint = &Region_SpawnPoint;
|
||||||
pTable->m_pfnQGetTickCount = &QERApp_GetTickCount;
|
pTable->m_pfnQGetTickCount = &QERApp_GetTickCount;
|
||||||
pTable->m_pfnGetModelCache = &GetModelCache;
|
pTable->m_pfnGetModelCache = &GetModelCache;
|
||||||
|
|
|
@ -222,7 +222,10 @@ void Drag_MouseUp( int nButtons = 0 );
|
||||||
//
|
//
|
||||||
// csg.c
|
// csg.c
|
||||||
//
|
//
|
||||||
|
#define CSG_HOLLOW_MODE_OVERLAP (0)
|
||||||
|
#define CSG_HOLLOW_MODE_TOUCH (1)
|
||||||
void CSG_MakeHollow( void );
|
void CSG_MakeHollow( void );
|
||||||
|
void CSG_MakeHollowMode( int mode );
|
||||||
void CSG_Subtract( void );
|
void CSG_Subtract( void );
|
||||||
void CSG_Merge( void );
|
void CSG_Merge( void );
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue