UnrealImGui/Source/ImGui/Private/ImGuiContextProxy.h

123 lines
3.7 KiB
C
Raw Permalink Normal View History

// Distributed under the MIT License (MIT) (see accompanying LICENSE file)
#pragma once
#include "ImGuiDrawData.h"
#include "ImGuiInputState.h"
#include "Utilities/WorldContextIndex.h"
#include <GenericPlatform/ICursor.h>
#include <imgui.h>
#include <string>
// Represents a single ImGui context. All the context updates should be done through this proxy. During update it
// broadcasts draw events to allow listeners draw their controls. After update it stores draw data.
class FImGuiContextProxy
{
public:
FImGuiContextProxy(const FString& Name, int32 InContextIndex, ImFontAtlas* InFontAtlas, float InDPIScale);
~FImGuiContextProxy();
FImGuiContextProxy(const FImGuiContextProxy&) = delete;
FImGuiContextProxy& operator=(const FImGuiContextProxy&) = delete;
FImGuiContextProxy(FImGuiContextProxy&&) = delete;
FImGuiContextProxy& operator=(FImGuiContextProxy&&) = delete;
// Get the name of this context.
const FString& GetName() const { return Name; }
// Get draw data from the last frame.
const TArray<FImGuiDrawList>& GetDrawData() const { return DrawLists; }
// Get input state used by this context.
FImGuiInputState& GetInputState() { return InputState; }
const FImGuiInputState& GetInputState() const { return InputState; }
// Is this context the current ImGui context.
bool IsCurrentContext() const { return ImGui::GetCurrentContext() == Context; }
// Set this context as current ImGui context.
void SetAsCurrent() { ImGui::SetCurrentContext(Context); }
// Get the desired context display size.
const FVector2D& GetDisplaySize() const { return DisplaySize; }
// Set the desired context display size.
void SetDisplaySize(const FVector2D& Size) { DisplaySize = Size; }
// Reset the desired context display size to default size.
void ResetDisplaySize();
// Get the DPI scale set for this context.
float GetDPIScale() const { return DPIScale; }
// Set the DPI scale for this context.
void SetDPIScale(float Scale);
// Whether this context has an active item (read once per frame during context update).
bool HasActiveItem() const { return bHasActiveItem; }
// Whether ImGui will use the mouse inputs (read once per frame during context update).
bool WantsMouseCapture() const { return bWantsMouseCapture; }
// Cursor type desired by this context (updated once per frame during context update).
EMouseCursor::Type GetMouseCursor() const { return MouseCursor; }
// Internal draw event used to draw module's examples and debug widgets. Unlike the delegates container, it is not
// passed when the module is reloaded, so all objects that are unloaded with the module should register here.
FSimpleMulticastDelegate& OnDraw() { return DrawEvent; }
// Call early debug events to allow listeners draw their debug widgets.
void DrawEarlyDebug();
// Call debug events to allow listeners draw their debug widgets.
void DrawDebug();
// Tick to advance context to the next frame. Only one call per frame will be processed.
void Tick(float DeltaSeconds);
private:
void BeginFrame(float DeltaTime = 1.f / 60.f);
void EndFrame();
void UpdateDrawData(ImDrawData* DrawData);
void BroadcastWorldEarlyDebug();
void BroadcastMultiContextEarlyDebug();
void BroadcastWorldDebug();
void BroadcastMultiContextDebug();
ImGuiContext* Context;
FVector2D DisplaySize = FVector2D::ZeroVector;
float DPIScale = 1.f;
EMouseCursor::Type MouseCursor = EMouseCursor::None;
bool bHasActiveItem = false;
bool bWantsMouseCapture = false;
bool bIsFrameStarted = false;
bool bIsDrawEarlyDebugCalled = false;
bool bIsDrawDebugCalled = false;
FImGuiInputState InputState;
TArray<FImGuiDrawList> DrawLists;
2019-05-05 18:59:19 +00:00
FString Name;
int32 ContextIndex = Utilities::INVALID_CONTEXT_INDEX;
2019-05-05 18:59:19 +00:00
uint32 LastFrameNumber = 0;
FSimpleMulticastDelegate DrawEvent;
std::string IniFilename;
};