Columns() distinguish columns-set ID from other widgets as a convenience, added asserts, added more sailors

This commit is contained in:
ocornut 2015-04-28 18:09:38 +02:00
parent bd23c11a93
commit 2440a30444

View File

@ -7575,6 +7575,7 @@ static float GetDraggedColumnOffset(int column_index)
// window creates a feedback loop because we store normalized positions/ So while dragging we enforce absolute positioning // window creates a feedback loop because we store normalized positions/ So while dragging we enforce absolute positioning
ImGuiState& g = *GImGui; ImGuiState& g = *GImGui;
ImGuiWindow* window = GetCurrentWindow(); ImGuiWindow* window = GetCurrentWindow();
IM_ASSERT(column_index > 0); // We cannot drag column 0. If you get this assert you may have a conflict between the ID of your columns and another widgets.
IM_ASSERT(g.ActiveId == window->DC.ColumnsSetID + ImGuiID(column_index)); IM_ASSERT(g.ActiveId == window->DC.ColumnsSetID + ImGuiID(column_index));
float x = g.IO.MousePos.x + g.ActiveClickDeltaToCenter.x; float x = g.IO.MousePos.x + g.ActiveClickDeltaToCenter.x;
@ -7699,7 +7700,9 @@ void ImGui::Columns(int columns_count, const char* id, bool border)
} }
// Set state for first column // Set state for first column
ImGui::PushID(0x11223344); // Differentiate column ID with an arbitrary/random prefix for cases where users name their columns set the same as another non-scope widget
window->DC.ColumnsSetID = window->GetID(id ? id : ""); window->DC.ColumnsSetID = window->GetID(id ? id : "");
ImGui::PopID();
window->DC.ColumnsCurrent = 0; window->DC.ColumnsCurrent = 0;
window->DC.ColumnsCount = columns_count; window->DC.ColumnsCount = columns_count;
window->DC.ColumnsShowBorders = border; window->DC.ColumnsShowBorders = border;
@ -10251,12 +10254,12 @@ void ImGui::ShowTestWindow(bool* opened)
// Text // Text
ImGui::Text("Two items: Hello"); ImGui::Text("Two items: Hello");
ImGui::SameLine(); ImGui::SameLine();
ImGui::TextColored(ImVec4(1,1,0,1), "World"); ImGui::TextColored(ImVec4(1,1,0,1), "Sailor");
// Adjust spacing // Adjust spacing
ImGui::Text("More spacing: Hello"); ImGui::Text("More spacing: Hello");
ImGui::SameLine(0, 20); ImGui::SameLine(0, 20);
ImGui::TextColored(ImVec4(1,1,0,1), "World"); ImGui::TextColored(ImVec4(1,1,0,1), "Sailor");
// Button // Button
ImGui::AlignFirstTextHeightToWidgets(); ImGui::AlignFirstTextHeightToWidgets();
@ -10499,7 +10502,7 @@ void ImGui::ShowTestWindow(bool* opened)
ImGui::Text("An extra line here."); ImGui::Text("An extra line here.");
ImGui::NextColumn(); ImGui::NextColumn();
ImGui::Text("World!"); ImGui::Text("Sailor");
ImGui::Button("Corniflower"); ImGui::Button("Corniflower");
ImGui::RadioButton("radio c", &e, 2); ImGui::RadioButton("radio c", &e, 2);
static float bar = 1.0f; static float bar = 1.0f;
@ -10518,8 +10521,8 @@ void ImGui::ShowTestWindow(bool* opened)
ImGui::Text("Tree items:"); ImGui::Text("Tree items:");
ImGui::Columns(2, "tree items"); ImGui::Columns(2, "tree items");
ImGui::Separator(); ImGui::Separator();
if (ImGui::TreeNode("Hello")) { ImGui::BulletText("World"); ImGui::TreePop(); } ImGui::NextColumn(); if (ImGui::TreeNode("Hello")) { ImGui::BulletText("Sailor"); ImGui::TreePop(); } ImGui::NextColumn();
if (ImGui::TreeNode("Bonjour")) { ImGui::BulletText("Monde"); ImGui::TreePop(); } ImGui::NextColumn(); if (ImGui::TreeNode("Bonjour")) { ImGui::BulletText("Marin"); ImGui::TreePop(); } ImGui::NextColumn();
ImGui::Columns(1); ImGui::Columns(1);
ImGui::Separator(); ImGui::Separator();