Demo: fixed multi-selection tree nodes demo to not replace selection when clicking on single-item that's already part of selection (#581)

features/sdl_renderer3_multiviewports
ocornut ago%!(EXTRA string=10 years)
parent 8f4b123e1b
commit b5521a81d4
  1. 6
      imgui_demo.cpp

@ -275,9 +275,9 @@ void ImGui::ShowTestWindow(bool* p_open)
{ {
// Update selection state. Process outside of tree loop to avoid visual inconsistencies during the clicking-frame. // Update selection state. Process outside of tree loop to avoid visual inconsistencies during the clicking-frame.
if (ImGui::GetIO().KeyCtrl) if (ImGui::GetIO().KeyCtrl)
selection_mask ^= (1 << node_clicked); // CTRL+click to toggle selection_mask ^= (1 << node_clicked); // CTRL+click to toggle
else else if (!(selection_mask & (1 << node_clicked))) // If there is already a selection don't replace we clicked node is part of it
selection_mask = (1 << node_clicked); // Click to single-select selection_mask = (1 << node_clicked); // Click to single-select
} }
ImGui::TreePop(); ImGui::TreePop();
} }

Loading…
Cancel
Save