mirror of
https://github.com/Drezil/imgui.git
synced 2025-01-11 16:26:35 +00:00
Drag and Drop: Made it legal to not call SetDragDropPayload() between BeginDragDropSource() and EndDragDropSource(). (#143)
This commit is contained in:
parent
3461a2f296
commit
553bdeedf7
12
imgui.cpp
12
imgui.cpp
@ -10706,7 +10706,6 @@ void ImGui::EndDragDropSource()
|
|||||||
{
|
{
|
||||||
ImGuiContext& g = *GImGui;
|
ImGuiContext& g = *GImGui;
|
||||||
IM_ASSERT(g.DragDropActive);
|
IM_ASSERT(g.DragDropActive);
|
||||||
IM_ASSERT(g.DragDropPayload.DataFrameCount != -1); // Forgot to call SetDragDropSourcePayload(), at least once on the first frame of a successful BeginDragDropSource()
|
|
||||||
|
|
||||||
if (!(g.DragDropSourceFlags & ImGuiDragDropFlags_SourceNoAutoTooltip))
|
if (!(g.DragDropSourceFlags & ImGuiDragDropFlags_SourceNoAutoTooltip))
|
||||||
{
|
{
|
||||||
@ -10714,9 +10713,16 @@ void ImGui::EndDragDropSource()
|
|||||||
PopStyleColor();
|
PopStyleColor();
|
||||||
//PopStyleVar();
|
//PopStyleVar();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Discard the drag if have not called SetDragDropPayload()
|
||||||
|
if (g.DragDropPayload.DataFrameCount == -1)
|
||||||
|
{
|
||||||
|
g.DragDropActive = false;
|
||||||
|
g.DragDropPayload.Clear();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use 'cond' to choose to submit paypload on drag start or every frame
|
// Use 'cond' to choose to submit payload on drag start or every frame
|
||||||
bool ImGui::SetDragDropPayload(const char* type, const void* data, size_t data_size, ImGuiCond cond)
|
bool ImGui::SetDragDropPayload(const char* type, const void* data, size_t data_size, ImGuiCond cond)
|
||||||
{
|
{
|
||||||
ImGuiContext& g = *GImGui;
|
ImGuiContext& g = *GImGui;
|
||||||
@ -10783,7 +10789,7 @@ const ImGuiPayload* ImGui::AcceptDragDropPayload(const char* type, ImGuiDragDrop
|
|||||||
ImGuiPayload& payload = g.DragDropPayload;
|
ImGuiPayload& payload = g.DragDropPayload;
|
||||||
IM_ASSERT(g.DragDropActive); // Not called between BeginDragDropTarget() and EndDragDropTarget() ?
|
IM_ASSERT(g.DragDropActive); // Not called between BeginDragDropTarget() and EndDragDropTarget() ?
|
||||||
IM_ASSERT(window->DC.LastItemRectHoveredRect); // Not called between BeginDragDropTarget() and EndDragDropTarget() ?
|
IM_ASSERT(window->DC.LastItemRectHoveredRect); // Not called between BeginDragDropTarget() and EndDragDropTarget() ?
|
||||||
IM_ASSERT(payload.DataFrameCount != -1); // Internal/usage error, please report!
|
IM_ASSERT(payload.DataFrameCount != -1); // Forgot to call EndDragDropTarget() ?
|
||||||
if (type != NULL && !payload.IsDataType(type))
|
if (type != NULL && !payload.IsDataType(type))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user