mirror of
https://github.com/TTimo/GtkRadiant.git
synced 2025-01-25 10:51:36 +00:00
- Changed ETB not to show any texture if a tag search doesn't match anything (Shaderman)
- Added View -> Filter -> Invert filters/Reset filters function (Shaderman) - Fixed (TODO) Textures: remove shaders only option for doom3 (Shaderman) - Fixed show shaders / shader only / shader info for doom3 and .wad file games (Shaderman) git-svn-id: svn://svn.icculus.org/gtkradiant/GtkRadiant/trunk@112 8a3a26a2-13c4-0310-b231-cf6edde360e5
This commit is contained in:
parent
48e07ba5f5
commit
049119a99d
4 changed files with 59 additions and 21 deletions
6
CHANGES
6
CHANGES
|
@ -1,6 +1,12 @@
|
||||||
This is the changelog for developers, != changelog for the end user
|
This is the changelog for developers, != changelog for the end user
|
||||||
that we distribute with the binaries. (see changelog)
|
that we distribute with the binaries. (see changelog)
|
||||||
|
|
||||||
|
06/10/2006
|
||||||
|
namespace
|
||||||
|
- Changed ETB not to show any texture if a tag search doesn't match anything (Shaderman)
|
||||||
|
- Added View -> Filter -> "Invert filters/Reset filters" function (Shaderman)
|
||||||
|
- Fixed (TODO) Textures: remove "shaders only" option for doom3 (Shaderman)
|
||||||
|
- Fixed show shaders / shader only / shader info for doom3 and .wad file games (Shaderman)
|
||||||
|
|
||||||
03/10/2006
|
03/10/2006
|
||||||
namespace
|
namespace
|
||||||
|
|
2
TODO
2
TODO
|
@ -87,7 +87,6 @@ Editing: add option to choose the default startup tool mode.
|
||||||
Renderer: lighting for doom3 materials without bumpmaps (e.g. mcity/mchangar2)
|
Renderer: lighting for doom3 materials without bumpmaps (e.g. mcity/mchangar2)
|
||||||
Renderer: realtime doom3 materials preview
|
Renderer: realtime doom3 materials preview
|
||||||
Renderer: realtime doom3 shadows preview
|
Renderer: realtime doom3 shadows preview
|
||||||
Renderer: add shortcut to toggle between lighting/textured modes.
|
|
||||||
Linux: Provide .tar.gz of example-map data for et/wolf.
|
Linux: Provide .tar.gz of example-map data for et/wolf.
|
||||||
Textures Window: add inner dark outline to distinguish 'is-shader' outline from white textures.
|
Textures Window: add inner dark outline to distinguish 'is-shader' outline from white textures.
|
||||||
HalfLife2: add HL2 map load/save.
|
HalfLife2: add HL2 map load/save.
|
||||||
|
@ -109,7 +108,6 @@ Model: support doom3 ragdolls
|
||||||
VFS: add ability to browse VFS from file-open dialogs.
|
VFS: add ability to browse VFS from file-open dialogs.
|
||||||
Installer: enable q3 brush-primitives map support.
|
Installer: enable q3 brush-primitives map support.
|
||||||
Installer: add editor manual to linux installer
|
Installer: add editor manual to linux installer
|
||||||
Textures: remove "shaders only" option for doom3
|
|
||||||
Map: add conversion between map formats
|
Map: add conversion between map formats
|
||||||
Map: add conversion between entity definition formats
|
Map: add conversion between entity definition formats
|
||||||
Build: add build-menu dmap support (doom3)
|
Build: add build-menu dmap support (doom3)
|
||||||
|
|
|
@ -150,6 +150,12 @@ public:
|
||||||
m_item.update();
|
m_item.update();
|
||||||
PerformFiltering();
|
PerformFiltering();
|
||||||
}
|
}
|
||||||
|
void reset()
|
||||||
|
{
|
||||||
|
g_filters_globals.exclude = 0;
|
||||||
|
m_item.update();
|
||||||
|
PerformFiltering();
|
||||||
|
}
|
||||||
typedef MemberCaller<ToggleFilterFlag, &ToggleFilterFlag::toggle> ToggleCaller;
|
typedef MemberCaller<ToggleFilterFlag, &ToggleFilterFlag::toggle> ToggleCaller;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -163,6 +169,26 @@ void add_filter_command(unsigned int flag, const char* command, const Accelerato
|
||||||
GlobalToggles_insert(command, ToggleFilterFlag::ToggleCaller(g_filter_items.back()), ToggleItem::AddCallbackCaller(g_filter_items.back().m_item), accelerator);
|
GlobalToggles_insert(command, ToggleFilterFlag::ToggleCaller(g_filter_items.back()), ToggleItem::AddCallbackCaller(g_filter_items.back().m_item), accelerator);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void InvertFilters()
|
||||||
|
{
|
||||||
|
std::list<ToggleFilterFlag>::iterator iter;
|
||||||
|
|
||||||
|
for(iter = g_filter_items.begin(); iter != g_filter_items.end(); ++iter)
|
||||||
|
{
|
||||||
|
iter->toggle();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ResetFilters()
|
||||||
|
{
|
||||||
|
std::list<ToggleFilterFlag>::iterator iter;
|
||||||
|
|
||||||
|
for(iter = g_filter_items.begin(); iter != g_filter_items.end(); ++iter)
|
||||||
|
{
|
||||||
|
iter->reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Filters_constructMenu(GtkMenu* menu_in_menu)
|
void Filters_constructMenu(GtkMenu* menu_in_menu)
|
||||||
{
|
{
|
||||||
create_check_menu_item_with_mnemonic(menu_in_menu, "World", "FilterWorldBrushes");
|
create_check_menu_item_with_mnemonic(menu_in_menu, "World", "FilterWorldBrushes");
|
||||||
|
@ -202,6 +228,10 @@ void Filters_constructMenu(GtkMenu* menu_in_menu)
|
||||||
{
|
{
|
||||||
create_check_menu_item_with_mnemonic(menu_in_menu, "Botclips", "FilterBotClips");
|
create_check_menu_item_with_mnemonic(menu_in_menu, "Botclips", "FilterBotClips");
|
||||||
}
|
}
|
||||||
|
// filter manipulation
|
||||||
|
menu_separator(menu_in_menu);
|
||||||
|
create_menu_item_with_mnemonic(menu_in_menu, "Invert filters", "InvertFilters");
|
||||||
|
create_menu_item_with_mnemonic(menu_in_menu, "Reset filters", "ResetFilters");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -212,6 +242,9 @@ void ConstructFilters()
|
||||||
{
|
{
|
||||||
GlobalPreferenceSystem().registerPreference("SI_Exclude", SizeImportStringCaller(g_filters_globals.exclude), SizeExportStringCaller(g_filters_globals.exclude));
|
GlobalPreferenceSystem().registerPreference("SI_Exclude", SizeImportStringCaller(g_filters_globals.exclude), SizeExportStringCaller(g_filters_globals.exclude));
|
||||||
|
|
||||||
|
GlobalCommands_insert("InvertFilters", FreeCaller<InvertFilters>());
|
||||||
|
GlobalCommands_insert("ResetFilters", FreeCaller<ResetFilters>());
|
||||||
|
|
||||||
add_filter_command(EXCLUDE_WORLD, "FilterWorldBrushes", Accelerator('1', (GdkModifierType)GDK_MOD1_MASK));
|
add_filter_command(EXCLUDE_WORLD, "FilterWorldBrushes", Accelerator('1', (GdkModifierType)GDK_MOD1_MASK));
|
||||||
add_filter_command(EXCLUDE_ENT, "FilterEntities", Accelerator('2', (GdkModifierType)GDK_MOD1_MASK));
|
add_filter_command(EXCLUDE_ENT, "FilterEntities", Accelerator('2', (GdkModifierType)GDK_MOD1_MASK));
|
||||||
if(g_pGameDescription->mGameType == "doom3")
|
if(g_pGameDescription->mGameType == "doom3")
|
||||||
|
|
|
@ -1595,7 +1595,6 @@ void TextureBrowser_createTreeViewTags()
|
||||||
GtkMenuItem* TextureBrowser_constructViewMenu(GtkMenu* menu)
|
GtkMenuItem* TextureBrowser_constructViewMenu(GtkMenu* menu)
|
||||||
{
|
{
|
||||||
GtkMenuItem* textures_menu_item = new_sub_menu_item_with_mnemonic("_View");
|
GtkMenuItem* textures_menu_item = new_sub_menu_item_with_mnemonic("_View");
|
||||||
GtkWidget* separator = gtk_separator_menu_item_new();
|
|
||||||
|
|
||||||
if(g_Layout_enableDetachableMenus.m_value)
|
if(g_Layout_enableDetachableMenus.m_value)
|
||||||
menu_tearoff (menu);
|
menu_tearoff (menu);
|
||||||
|
@ -1603,8 +1602,8 @@ GtkMenuItem* TextureBrowser_constructViewMenu(GtkMenu* menu)
|
||||||
create_check_menu_item_with_mnemonic(menu, "Hide _Unused", "ShowInUse");
|
create_check_menu_item_with_mnemonic(menu, "Hide _Unused", "ShowInUse");
|
||||||
create_menu_item_with_mnemonic(menu, "Show All", "ShowAllTextures");
|
create_menu_item_with_mnemonic(menu, "Show All", "ShowAllTextures");
|
||||||
|
|
||||||
// we always want to show shaders but don't want a "Show Shaders" menu for doom3 games
|
// we always want to show shaders but don't want a "Show Shaders" menu for doom3 and .wad file games
|
||||||
if(string_equal(g_pGameDescription->getRequiredKeyValue("shaders"), "doom3"))
|
if(g_pGameDescription->mGameType == "doom3" || !string_empty(g_pGameDescription->getKeyValue("show_wads")))
|
||||||
{
|
{
|
||||||
g_TextureBrowser.m_showShaders = true;
|
g_TextureBrowser.m_showShaders = true;
|
||||||
}
|
}
|
||||||
|
@ -1613,16 +1612,21 @@ GtkMenuItem* TextureBrowser_constructViewMenu(GtkMenu* menu)
|
||||||
create_check_menu_item_with_mnemonic(menu, "Show shaders", "ToggleShowShaders");
|
create_check_menu_item_with_mnemonic(menu, "Show shaders", "ToggleShowShaders");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(g_pGameDescription->mGameType != "doom3" && string_empty(g_pGameDescription->getKeyValue("show_wads")))
|
||||||
|
{
|
||||||
create_check_menu_item_with_mnemonic (menu, "Shaders Only", "ToggleShowShaderlistOnly");
|
create_check_menu_item_with_mnemonic (menu, "Shaders Only", "ToggleShowShaderlistOnly");
|
||||||
|
}
|
||||||
if(g_TextureBrowser.m_tags)
|
if(g_TextureBrowser.m_tags)
|
||||||
{
|
{
|
||||||
create_menu_item_with_mnemonic(menu, "Show Untagged", "ShowUntagged");
|
create_menu_item_with_mnemonic(menu, "Show Untagged", "ShowUntagged");
|
||||||
}
|
}
|
||||||
gtk_menu_shell_append(GTK_MENU_SHELL(menu), separator);
|
|
||||||
gtk_widget_show(separator);
|
|
||||||
|
|
||||||
|
if(string_empty(g_pGameDescription->getKeyValue("show_wads")))
|
||||||
|
{
|
||||||
|
menu_separator(menu);
|
||||||
g_TextureBrowser.m_shader_info_item = GTK_WIDGET(create_menu_item_with_mnemonic(menu, "Shader Info", "ShaderInfo"));
|
g_TextureBrowser.m_shader_info_item = GTK_WIDGET(create_menu_item_with_mnemonic(menu, "Shader Info", "ShaderInfo"));
|
||||||
gtk_widget_set_sensitive(g_TextureBrowser.m_shader_info_item, FALSE);
|
gtk_widget_set_sensitive(g_TextureBrowser.m_shader_info_item, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
return textures_menu_item;
|
return textures_menu_item;
|
||||||
}
|
}
|
||||||
|
@ -1643,7 +1647,6 @@ GtkMenuItem* TextureBrowser_constructToolsMenu(GtkMenu* menu)
|
||||||
GtkMenuItem* TextureBrowser_constructTagsMenu(GtkMenu* menu)
|
GtkMenuItem* TextureBrowser_constructTagsMenu(GtkMenu* menu)
|
||||||
{
|
{
|
||||||
GtkMenuItem* textures_menu_item = new_sub_menu_item_with_mnemonic("T_ags");
|
GtkMenuItem* textures_menu_item = new_sub_menu_item_with_mnemonic("T_ags");
|
||||||
GtkWidget* separator = gtk_separator_menu_item_new();
|
|
||||||
|
|
||||||
if (g_Layout_enableDetachableMenus.m_value)
|
if (g_Layout_enableDetachableMenus.m_value)
|
||||||
menu_tearoff (menu);
|
menu_tearoff (menu);
|
||||||
|
@ -1651,8 +1654,7 @@ GtkMenuItem* TextureBrowser_constructTagsMenu(GtkMenu* menu)
|
||||||
create_menu_item_with_mnemonic(menu, "Add tag", "AddTag");
|
create_menu_item_with_mnemonic(menu, "Add tag", "AddTag");
|
||||||
create_menu_item_with_mnemonic(menu, "Rename tag", "RenameTag");
|
create_menu_item_with_mnemonic(menu, "Rename tag", "RenameTag");
|
||||||
create_menu_item_with_mnemonic(menu, "Delete tag", "DeleteTag");
|
create_menu_item_with_mnemonic(menu, "Delete tag", "DeleteTag");
|
||||||
gtk_menu_shell_append(GTK_MENU_SHELL(menu), separator);
|
menu_separator(menu);
|
||||||
gtk_widget_show(separator);
|
|
||||||
create_menu_item_with_mnemonic(menu, "Copy tags from selected", "CopyTag");
|
create_menu_item_with_mnemonic(menu, "Copy tags from selected", "CopyTag");
|
||||||
create_menu_item_with_mnemonic(menu, "Paste tags to selected", "PasteTag");
|
create_menu_item_with_mnemonic(menu, "Paste tags to selected", "PasteTag");
|
||||||
|
|
||||||
|
@ -1843,7 +1845,7 @@ void TextureBrowser_searchTags()
|
||||||
path = path.substr(0, pos + 1);
|
path = path.substr(0, pos + 1);
|
||||||
TextureDirectory_loadTexture(path.c_str(), name.c_str());
|
TextureDirectory_loadTexture(path.c_str(), name.c_str());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
g_TextureBrowser.m_searchedTags = true;
|
g_TextureBrowser.m_searchedTags = true;
|
||||||
g_TextureBrowser_currentDirectory = tags_searched;
|
g_TextureBrowser_currentDirectory = tags_searched;
|
||||||
|
|
||||||
|
@ -1852,7 +1854,6 @@ void TextureBrowser_searchTags()
|
||||||
TextureBrowser_heightChanged(g_TextureBrowser);
|
TextureBrowser_heightChanged(g_TextureBrowser);
|
||||||
TextureBrowser_updateTitle();
|
TextureBrowser_updateTitle();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
g_slist_free(selected);
|
g_slist_free(selected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue