Added SliderInt2(), SliderInt3(), SliderInt4() for consistency
This commit is contained in:
parent
60b4389ac1
commit
929f127d06
69
imgui.cpp
69
imgui.cpp
@ -4124,6 +4124,56 @@ bool ImGui::SliderFloat4(const char* label, float v[4], float v_min, float v_max
|
|||||||
return SliderFloatN(label, v, 4, v_min, v_max, display_format, power);
|
return SliderFloatN(label, v, 4, v_min, v_max, display_format, power);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool SliderIntN(const char* label, int v[3], int components, int v_min, int v_max, const char* display_format)
|
||||||
|
{
|
||||||
|
ImGuiState& g = GImGui;
|
||||||
|
ImGuiWindow* window = GetCurrentWindow();
|
||||||
|
if (window->SkipItems)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
const ImGuiStyle& style = g.Style;
|
||||||
|
const float w_full = window->DC.ItemWidth.back();
|
||||||
|
const float w_item_one = ImMax(1.0f, (float)(int)((w_full - (style.FramePadding.x*2.0f + style.ItemInnerSpacing.x)*(components-1)) / (float)components));
|
||||||
|
const float w_item_last = ImMax(1.0f, (float)(int)(w_full - (w_item_one + style.FramePadding.x*2.0f + style.ItemInnerSpacing.x)*(components-1)));
|
||||||
|
|
||||||
|
bool value_changed = false;
|
||||||
|
ImGui::PushID(label);
|
||||||
|
ImGui::PushItemWidth(w_item_one);
|
||||||
|
for (int i = 0; i < components; i++)
|
||||||
|
{
|
||||||
|
ImGui::PushID(i);
|
||||||
|
if (i + 1 == components)
|
||||||
|
{
|
||||||
|
ImGui::PopItemWidth();
|
||||||
|
ImGui::PushItemWidth(w_item_last);
|
||||||
|
}
|
||||||
|
value_changed |= ImGui::SliderInt("##v", &v[i], v_min, v_max, display_format);
|
||||||
|
ImGui::SameLine(0, (int)style.ItemInnerSpacing.x);
|
||||||
|
ImGui::PopID();
|
||||||
|
}
|
||||||
|
ImGui::PopItemWidth();
|
||||||
|
ImGui::PopID();
|
||||||
|
|
||||||
|
ImGui::TextUnformatted(label, FindTextDisplayEnd(label));
|
||||||
|
|
||||||
|
return value_changed;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ImGui::SliderInt2(const char* label, int v[2], int v_min, int v_max, const char* display_format)
|
||||||
|
{
|
||||||
|
return SliderIntN(label, v, 2, v_min, v_max, display_format);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ImGui::SliderInt3(const char* label, int v[3], int v_min, int v_max, const char* display_format)
|
||||||
|
{
|
||||||
|
return SliderIntN(label, v, 3, v_min, v_max, display_format);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ImGui::SliderInt4(const char* label, int v[4], int v_min, int v_max, const char* display_format)
|
||||||
|
{
|
||||||
|
return SliderIntN(label, v, 4, v_min, v_max, display_format);
|
||||||
|
}
|
||||||
|
|
||||||
enum ImGuiPlotType
|
enum ImGuiPlotType
|
||||||
{
|
{
|
||||||
ImGuiPlotType_Lines,
|
ImGuiPlotType_Lines,
|
||||||
@ -5243,8 +5293,8 @@ bool ImGui::ColorEdit4(const char* label, float col[4], bool alpha)
|
|||||||
case ImGuiColorEditMode_RGB:
|
case ImGuiColorEditMode_RGB:
|
||||||
case ImGuiColorEditMode_HSV:
|
case ImGuiColorEditMode_HSV:
|
||||||
{
|
{
|
||||||
// 0: RGB 0..255
|
// 0: RGB 0..255 Sliders
|
||||||
// 1: HSV 0.255 Sliders
|
// 1: HSV 0..255 Sliders
|
||||||
const float w_items_all = w_full - (square_sz + style.ItemInnerSpacing.x);
|
const float w_items_all = w_full - (square_sz + style.ItemInnerSpacing.x);
|
||||||
const float w_item_one = ImMax(1.0f, (float)(int)((w_items_all - (style.FramePadding.x*2.0f + style.ItemInnerSpacing.x) * (components-1)) / (float)components));
|
const float w_item_one = ImMax(1.0f, (float)(int)((w_items_all - (style.FramePadding.x*2.0f + style.ItemInnerSpacing.x) * (components-1)) / (float)components));
|
||||||
const float w_item_last = ImMax(1.0f, (float)(int)(w_items_all - (w_item_one + style.FramePadding.x*2.0f + style.ItemInnerSpacing.x) * (components-1)));
|
const float w_item_last = ImMax(1.0f, (float)(int)(w_items_all - (w_item_one + style.FramePadding.x*2.0f + style.ItemInnerSpacing.x) * (components-1)));
|
||||||
@ -7025,15 +7075,16 @@ void ImGui::ShowTestWindow(bool* opened)
|
|||||||
static float angle = 0.0f;
|
static float angle = 0.0f;
|
||||||
ImGui::SliderAngle("angle", &angle);
|
ImGui::SliderAngle("angle", &angle);
|
||||||
|
|
||||||
//static float vec2b[3] = { 0.10f, 0.20f };
|
static float vec4b[4] = { 0.10f, 0.20f, 0.30f, 0.40f };
|
||||||
//ImGui::SliderFloat2("slider float2", vec2b, 0.0f, 1.0f);
|
//ImGui::SliderFloat2("slider float2", vec4b, 0.0f, 1.0f);
|
||||||
|
ImGui::SliderFloat3("slider float3", vec4b, 0.0f, 1.0f);
|
||||||
static float vec3b[3] = { 0.10f, 0.20f, 0.30f };
|
|
||||||
ImGui::SliderFloat3("slider float3", vec3b, 0.0f, 1.0f);
|
|
||||||
|
|
||||||
//static float vec4b[4] = { 0.10f, 0.20f, 0.30f, 0.40f };
|
|
||||||
//ImGui::SliderFloat4("slider float4", vec4b, 0.0f, 1.0f);
|
//ImGui::SliderFloat4("slider float4", vec4b, 0.0f, 1.0f);
|
||||||
|
|
||||||
|
//static int vec4i[4] = { 1, 5, 100, 255 };
|
||||||
|
//ImGui::SliderInt2("slider int2", vec4i, 0, 255);
|
||||||
|
//ImGui::SliderInt3("slider int3", vec4i, 0, 255);
|
||||||
|
//ImGui::SliderInt4("slider int4", vec4i, 0, 255);
|
||||||
|
|
||||||
static float col1[3] = { 1.0f,0.0f,0.2f };
|
static float col1[3] = { 1.0f,0.0f,0.2f };
|
||||||
static float col2[4] = { 0.4f,0.7f,0.0f,0.5f };
|
static float col2[4] = { 0.4f,0.7f,0.0f,0.5f };
|
||||||
ImGui::ColorEdit3("color 1", col1);
|
ImGui::ColorEdit3("color 1", col1);
|
||||||
|
3
imgui.h
3
imgui.h
@ -241,6 +241,9 @@ namespace ImGui
|
|||||||
IMGUI_API bool SliderFloat4(const char* label, float v[4], float v_min, float v_max, const char* display_format = "%.3f", float power = 1.0f);
|
IMGUI_API bool SliderFloat4(const char* label, float v[4], float v_min, float v_max, const char* display_format = "%.3f", float power = 1.0f);
|
||||||
IMGUI_API bool SliderAngle(const char* label, float* v, float v_degrees_min = -360.0f, float v_degrees_max = +360.0f); // *v in radians
|
IMGUI_API bool SliderAngle(const char* label, float* v, float v_degrees_min = -360.0f, float v_degrees_max = +360.0f); // *v in radians
|
||||||
IMGUI_API bool SliderInt(const char* label, int* v, int v_min, int v_max, const char* display_format = "%.0f");
|
IMGUI_API bool SliderInt(const char* label, int* v, int v_min, int v_max, const char* display_format = "%.0f");
|
||||||
|
IMGUI_API bool SliderInt2(const char* label, int v[2], int v_min, int v_max, const char* display_format = "%.0f");
|
||||||
|
IMGUI_API bool SliderInt3(const char* label, int v[3], int v_min, int v_max, const char* display_format = "%.0f");
|
||||||
|
IMGUI_API bool SliderInt4(const char* label, int v[4], int v_min, int v_max, const char* display_format = "%.0f");
|
||||||
IMGUI_API void PlotLines(const char* label, const float* values, int values_count, int values_offset = 0, const char* overlay_text = NULL, float scale_min = FLT_MAX, float scale_max = FLT_MAX, ImVec2 graph_size = ImVec2(0,0), size_t stride = sizeof(float));
|
IMGUI_API void PlotLines(const char* label, const float* values, int values_count, int values_offset = 0, const char* overlay_text = NULL, float scale_min = FLT_MAX, float scale_max = FLT_MAX, ImVec2 graph_size = ImVec2(0,0), size_t stride = sizeof(float));
|
||||||
IMGUI_API void PlotLines(const char* label, float (*values_getter)(void* data, int idx), void* data, int values_count, int values_offset = 0, const char* overlay_text = NULL, float scale_min = FLT_MAX, float scale_max = FLT_MAX, ImVec2 graph_size = ImVec2(0,0));
|
IMGUI_API void PlotLines(const char* label, float (*values_getter)(void* data, int idx), void* data, int values_count, int values_offset = 0, const char* overlay_text = NULL, float scale_min = FLT_MAX, float scale_max = FLT_MAX, ImVec2 graph_size = ImVec2(0,0));
|
||||||
IMGUI_API void PlotHistogram(const char* label, const float* values, int values_count, int values_offset = 0, const char* overlay_text = NULL, float scale_min = FLT_MAX, float scale_max = FLT_MAX, ImVec2 graph_size = ImVec2(0,0), size_t stride = sizeof(float));
|
IMGUI_API void PlotHistogram(const char* label, const float* values, int values_count, int values_offset = 0, const char* overlay_text = NULL, float scale_min = FLT_MAX, float scale_max = FLT_MAX, ImVec2 graph_size = ImVec2(0,0), size_t stride = sizeof(float));
|
||||||
|
Loading…
Reference in New Issue
Block a user