mirror of
				https://github.com/Drezil/imgui.git
				synced 2025-10-25 03:01:07 +02:00 
			
		
		
		
	SelectableEx - replaced unnecessary extra size_draw parameter by a flag.
This commit is contained in:
		
							
								
								
									
										23
									
								
								imgui.cpp
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								imgui.cpp
									
									
									
									
									
								
							| @@ -988,9 +988,10 @@ enum ImGuiButtonFlags_ | |||||||
|  |  | ||||||
| enum ImGuiSelectableFlags_ | enum ImGuiSelectableFlags_ | ||||||
| { | { | ||||||
|     ImGuiSelectableFlags_MenuItem        = (1 << 0), |     ImGuiSelectableFlags_MenuItem           = (1 << 0), | ||||||
|     ImGuiSelectableFlags_DontClosePopups = (1 << 1), |     ImGuiSelectableFlags_DontClosePopups    = (1 << 1), | ||||||
|     ImGuiSelectableFlags_Disabled        = (1 << 2) |     ImGuiSelectableFlags_Disabled           = (1 << 2), | ||||||
|  |     ImGuiSelectableFlags_DrawFillAvailWidth = (1 << 3) | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -7406,7 +7407,7 @@ bool ImGui::Combo(const char* label, int* current_item, bool (*items_getter)(voi | |||||||
|     return value_changed; |     return value_changed; | ||||||
| } | } | ||||||
|  |  | ||||||
| static bool SelectableEx(const char* label, bool selected, const ImVec2& size_arg, const ImVec2 size_draw_arg, ImGuiSelectableFlags flags) | static bool SelectableEx(const char* label, bool selected, const ImVec2& size_arg, ImGuiSelectableFlags flags) | ||||||
| { | { | ||||||
|     ImGuiState& g = *GImGui; |     ImGuiState& g = *GImGui; | ||||||
|     ImGuiWindow* window = GetCurrentWindow(); |     ImGuiWindow* window = GetCurrentWindow(); | ||||||
| @@ -7425,9 +7426,9 @@ static bool SelectableEx(const char* label, bool selected, const ImVec2& size_ar | |||||||
|     // Fill horizontal space. |     // Fill horizontal space. | ||||||
|     ImVec2 window_padding = window->WindowPadding(); |     ImVec2 window_padding = window->WindowPadding(); | ||||||
|     float w_draw = ImMax(label_size.x, window->Pos.x + ImGui::GetContentRegionMax().x - window_padding.x - window->DC.CursorPos.x); |     float w_draw = ImMax(label_size.x, window->Pos.x + ImGui::GetContentRegionMax().x - window_padding.x - window->DC.CursorPos.x); | ||||||
|     ImVec2 size_draw(size_draw_arg.x != 0.0f ? size_draw_arg.x : w_draw, size_draw_arg.y != 0.0f ? size_draw_arg.y : size.y); |     ImVec2 size_draw((size_arg.x != 0 && !(flags & ImGuiSelectableFlags_DrawFillAvailWidth)) ? size_arg.x : w_draw, size_arg.y != 0.0f ? size_arg.y : size.y); | ||||||
|     ImRect bb_with_spacing(pos, pos + size_draw); |     ImRect bb_with_spacing(pos, pos + size_draw); | ||||||
|     if (size_draw_arg.x == 0.0f) |     if (size_arg.x == 0.0f || (flags & ImGuiSelectableFlags_DrawFillAvailWidth)) | ||||||
|         bb_with_spacing.Max.x += window_padding.x; |         bb_with_spacing.Max.x += window_padding.x; | ||||||
|  |  | ||||||
|     // Selectables are tightly packed together, we extend the box to cover spacing between selectable. |     // Selectables are tightly packed together, we extend the box to cover spacing between selectable. | ||||||
| @@ -7467,12 +7468,12 @@ static bool SelectableEx(const char* label, bool selected, const ImVec2& size_ar | |||||||
| // But you need to make sure the ID is unique, e.g. enclose calls in PushID/PopID. | // But you need to make sure the ID is unique, e.g. enclose calls in PushID/PopID. | ||||||
| bool ImGui::Selectable(const char* label, bool selected, const ImVec2& size_arg) | bool ImGui::Selectable(const char* label, bool selected, const ImVec2& size_arg) | ||||||
| { | { | ||||||
|     return SelectableEx(label, selected, size_arg, size_arg, 0); |     return SelectableEx(label, selected, size_arg, 0); | ||||||
| } | } | ||||||
|  |  | ||||||
| bool ImGui::Selectable(const char* label, bool* p_selected, const ImVec2& size_arg) | bool ImGui::Selectable(const char* label, bool* p_selected, const ImVec2& size_arg) | ||||||
| { | { | ||||||
|     if (SelectableEx(label, *p_selected, size_arg, size_arg, 0)) |     if (SelectableEx(label, *p_selected, size_arg, 0)) | ||||||
|     { |     { | ||||||
|         *p_selected = !*p_selected; |         *p_selected = !*p_selected; | ||||||
|         return true; |         return true; | ||||||
| @@ -7588,7 +7589,7 @@ bool ImGui::MenuItem(const char* label, const char* shortcut, bool selected, boo | |||||||
|     float w = window->MenuColumns.DeclColumns(label_size.x, shortcut_size.x, (float)(int)(g.FontSize * 1.20f)); // Feedback for next frame |     float w = window->MenuColumns.DeclColumns(label_size.x, shortcut_size.x, (float)(int)(g.FontSize * 1.20f)); // Feedback for next frame | ||||||
|     float extra_w = ImMax(0.0f, window->Pos.x + ImGui::GetContentRegionMax().x - pos.x - w); |     float extra_w = ImMax(0.0f, window->Pos.x + ImGui::GetContentRegionMax().x - pos.x - w); | ||||||
|  |  | ||||||
|     bool pressed = SelectableEx(label, false, ImVec2(w, 0.0f), ImVec2(0.0f, 0.0f), ImGuiSelectableFlags_MenuItem | (!enabled ? ImGuiSelectableFlags_Disabled : 0)); |     bool pressed = SelectableEx(label, false, ImVec2(w, 0.0f), ImGuiSelectableFlags_MenuItem | ImGuiSelectableFlags_DrawFillAvailWidth | (!enabled ? ImGuiSelectableFlags_Disabled : 0)); | ||||||
|     if (shortcut_size.x > 0.0f) |     if (shortcut_size.x > 0.0f) | ||||||
|     { |     { | ||||||
|         ImGui::PushStyleColor(ImGuiCol_Text, g.Style.Colors[ImGuiCol_TextDisabled]); |         ImGui::PushStyleColor(ImGuiCol_Text, g.Style.Colors[ImGuiCol_TextDisabled]); | ||||||
| @@ -7701,7 +7702,7 @@ bool ImGui::BeginMenu(const char* label, bool enabled) | |||||||
|         window->DC.CursorPos.x += (float)(int)(style.ItemSpacing.x * 0.5f); |         window->DC.CursorPos.x += (float)(int)(style.ItemSpacing.x * 0.5f); | ||||||
|         ImGui::PushStyleVar(ImGuiStyleVar_ItemSpacing, style.ItemSpacing * 2.0f); |         ImGui::PushStyleVar(ImGuiStyleVar_ItemSpacing, style.ItemSpacing * 2.0f); | ||||||
|         float w = label_size.x; |         float w = label_size.x; | ||||||
|         pressed = SelectableEx(label, opened, ImVec2(w, 0.0f), ImVec2(w, 0.0f), ImGuiSelectableFlags_MenuItem | ImGuiSelectableFlags_DontClosePopups | (!enabled ? ImGuiSelectableFlags_Disabled : 0)); |         pressed = SelectableEx(label, opened, ImVec2(w, 0.0f), ImGuiSelectableFlags_MenuItem | ImGuiSelectableFlags_DontClosePopups | (!enabled ? ImGuiSelectableFlags_Disabled : 0)); | ||||||
|         ImGui::PopStyleVar(); |         ImGui::PopStyleVar(); | ||||||
|         ImGui::SameLine(); |         ImGui::SameLine(); | ||||||
|         window->DC.CursorPos.x += (float)(int)(style.ItemSpacing.x * 0.5f); |         window->DC.CursorPos.x += (float)(int)(style.ItemSpacing.x * 0.5f); | ||||||
| @@ -7711,7 +7712,7 @@ bool ImGui::BeginMenu(const char* label, bool enabled) | |||||||
|         popup_pos = ImVec2(pos.x, pos.y - style.WindowPadding.y); |         popup_pos = ImVec2(pos.x, pos.y - style.WindowPadding.y); | ||||||
|         float w = window->MenuColumns.DeclColumns(label_size.x, 0.0f, (float)(int)(g.FontSize * 1.20f)); // Feedback to next frame |         float w = window->MenuColumns.DeclColumns(label_size.x, 0.0f, (float)(int)(g.FontSize * 1.20f)); // Feedback to next frame | ||||||
|         float extra_w = ImMax(0.0f, window->Pos.x + ImGui::GetContentRegionMax().x - pos.x - w); |         float extra_w = ImMax(0.0f, window->Pos.x + ImGui::GetContentRegionMax().x - pos.x - w); | ||||||
|         pressed = SelectableEx(label, opened, ImVec2(w, 0.0f), ImVec2(0.0f, 0.0f), ImGuiSelectableFlags_MenuItem | ImGuiSelectableFlags_DontClosePopups | (!enabled ? ImGuiSelectableFlags_Disabled : 0)); |         pressed = SelectableEx(label, opened, ImVec2(w, 0.0f), ImGuiSelectableFlags_MenuItem | ImGuiSelectableFlags_DontClosePopups | ImGuiSelectableFlags_DrawFillAvailWidth | (!enabled ? ImGuiSelectableFlags_Disabled : 0)); | ||||||
|         if (!enabled) ImGui::PushStyleColor(ImGuiCol_Text, g.Style.Colors[ImGuiCol_TextDisabled]); |         if (!enabled) ImGui::PushStyleColor(ImGuiCol_Text, g.Style.Colors[ImGuiCol_TextDisabled]); | ||||||
|         RenderCollapseTriangle(pos + ImVec2(window->MenuColumns.Pos[2] + extra_w + g.FontSize * 0.20f, 0.0f), false); |         RenderCollapseTriangle(pos + ImVec2(window->MenuColumns.Pos[2] + extra_w + g.FontSize * 0.20f, 0.0f), false); | ||||||
|         if (!enabled) ImGui::PopStyleColor(); |         if (!enabled) ImGui::PopStyleColor(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user