-
-
Notifications
You must be signed in to change notification settings - Fork 10.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Improving border #447
Comments
You'd have to add two lines and a parameter to RenderFrame() to decide which of the two effects to use. Not a bad idea, may add that someday. |
I am going to have to bail out on that for master for now, but keep a note to it for when seriously working on #184 Maintaining borders has been already time confusing for little benefit (lots of those changes have subtle effects on five other things) and I would rather see how much we actually use them in an improved visuals. The library won't try to cater for every possible visual design. Windows-style border work if the background color is known and consistent but above variable or unreliable background color (e.g. transparent window over a game output) they don't, this is why I used a two color scheme for borders. |
If the buttons (areas) are flat - visually heavy understand is it action area or do nothing. |
Looks great! It really helps to give it more of a widget look. -Adam |
That's nice, how do it perform on the default theme? |
Don't make it look too much like Windows 3.1 :) |
:) I like XP and Classic theme. |
Next conception: |
Problem with using layers of filled rectangles is that it won't work with transparent windows. The hard part isn't coming with one design, but writing code that can be merged back in master for the larger interest. This design is nice but definitively can't become the default visual design for imgui. We should aim for something more modern and flat e.g #184. If the system can handle both types it is a nice extra but we still need to focus on one. So while your work on the code it's better if you can think of it as optional (e.g. the enum for border is a good idea). Also note that I made fixes a few days about about the positioning of AddRect, it was off by 1 (#457). |
Yes, but i do what i need. I am not a programmer - i am a user |
True, but that's not what Omar is saying. He cannot put your changes in the main code base because it causes problems with transparent windows. So your code has to stay your code. |
Well ideally green-zone's code could be designed in a way that I will want and be able to merge it because it is beneficial to ImGui for everyone. But it is also fine if you fork and it stays your code only. Either way are possible :) |
@green-zone This is really a nice work you did. :) |
The correct way is to render off-screen to an image then render the image On Tue, 29 Dec 2015 at 07:56 omar [email protected] wrote:
|
That wouldn't be practical nor efficient with the current system. |
Not my cup of tea, but I'm afraid if you go this path you will be faced with a sort of uncanny valley where people have different expectation of what the UI library can and should do for do. We have a lot of work to do with fill those features gap :) |
I'm doing it for themselves :) (developer interface - not for final-user) |
I solved all their questions with the border. |
Could you post your patch here, at least for the records? |
// IT QUICK DEV (NOT CLEAN)
// Need:
// 1 BorderType enum with (NO SOLID OUT_I OUT_II IN_I IN_II EXT) types in imgui_internal.h
// 2 In imgui.cpp found and change all RenderFrame functions (replace bool border param to BorderType)
void ImGui::RenderFrame(ImVec2 p_min, ImVec2 p_max, ImU32 fill_col, BorderType b_type, float rounding)
{
ImGuiWindow* window = GetCurrentWindow();
if (b_type != NO)
{
ImVec2 offset_i = ImVec2(1,1);
ImVec2 offset_ii = ImVec2(2,2);
if (b_type == SOLID) // single-border
{
// Black rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max + offset_i, GetColorU32(ImGuiCol_BorderShadow), rounding);
}
else if (b_type == OUT_I) // Out-screen level 1
{
// Black rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max + offset_i, GetColorU32(ImGuiCol_BorderShadow), rounding);
// White rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max, GetColorU32(ImGuiCol_Border), 1.0f);
}
else if (b_type == IN_I) // In-screen level 1
{
// White rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max + offset_i, GetColorU32(ImGuiCol_Border), 1.0f);
// Black rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max, GetColorU32(ImGuiCol_BorderShadow), rounding);
}
else if (b_type == OUT_II) // Out-screen level 2
{
ImGuiStyle& style = ImGui::GetStyle();
ImVec4 color = style.Colors[ImGuiCol_Button];
ImVec4 mid_col = ImVec4(color.x * 0.5f, color.y * 0.5f, color.z * 0.5f, 1.0f);
// Black rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max + offset_ii, GetColorU32(ImGuiCol_BorderShadow), rounding);
// White rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max + offset_i, GetColorU32(ImGuiCol_Border), rounding);
// Middle rectangle
style.Colors[ImGuiCol_Button] = mid_col;
window->DrawList->AddRectFilled(p_min, p_max + offset_i, GetColorU32(ImGuiCol_Button), rounding);
style.Colors[ImGuiCol_Button] = color;
}
else if (b_type == IN_II) // In-screen level 2
{
// White rectangle
window->DrawList->AddRectFilled(p_min - offset_ii, p_max + offset_ii, GetColorU32(ImGuiCol_Border), rounding);
ImGuiStyle& style = ImGui::GetStyle();
ImVec4 color = style.Colors[ImGuiCol_WindowBg];
ImVec4 mid_col = ImVec4(color.x * 0.5f, color.y * 0.5f, color.z * 0.5f, 1.0f);
// Middle rectangle
style.Colors[ImGuiCol_WindowBg] = mid_col;
window->DrawList->AddRectFilled(p_min - offset_ii, p_max + offset_i, GetColorU32(ImGuiCol_WindowBg), rounding);
style.Colors[ImGuiCol_WindowBg] = color;
// Neitral rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max + offset_i, GetColorU32(ImGuiCol_WindowBg), rounding);
// Black rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max, GetColorU32(ImGuiCol_BorderShadow), rounding);
}
else if (b_type == EXT) // OUT_II with advanced left and top border
{
// Black rectangle
window->DrawList->AddRectFilled(p_min - offset_ii, p_max + offset_ii, GetColorU32(ImGuiCol_BorderShadow), rounding);
// Neitral rectangle
window->DrawList->AddRectFilled(p_min - offset_ii, p_max + offset_i, GetColorU32(ImGuiCol_WindowBg), rounding);
ImGuiStyle& style = ImGui::GetStyle();
ImVec4 color = style.Colors[ImGuiCol_WindowBg];
ImVec4 mid_col = ImVec4(color.x * 0.5f, color.y * 0.5f, color.z * 0.5f, 1.0f);
// Middle rectangle
style.Colors[ImGuiCol_WindowBg] = mid_col;
window->DrawList->AddRectFilled(p_min - offset_i, p_max + offset_i, GetColorU32(ImGuiCol_WindowBg), rounding);
style.Colors[ImGuiCol_WindowBg] = color;
// White rectangle
window->DrawList->AddRectFilled(p_min - offset_i, p_max, GetColorU32(ImGuiCol_Border), rounding);
}
}
// target rectangle
window->DrawList->AddRectFilled(p_min, p_max, fill_col, rounding);
} |
Thanks! I'll keep this for reference. |
ProggyClean is a bitmap font so it can be rendered pixel perfect easily. For any other font, you can try with OversampleH=2, OversampleV=1, higher size, or use imgui_freetype to improve sharpness. It's not an easy problem to solve with the current rendering technique. |
This is all off-topic in a thread called "Improving border". |
I am reopening because the border discussion/references are useful. Please discuss fonts in a different thread. |
1) Please don’t delete posts unless they contains sensitive information.
2) I already said this topic has nothing to do with fonts. This is a topic about borders, please don’t mix unrelated topics.
|
The original border creates a 3D effect only for himself.
I illustrate this on screenshot:
And in the following screenshot you can see what the result I want to receive
and another screenshot (what i like)
Question: What i need change in RenderFrame() function of imgui.cpp?
Original actions:
window->DrawList->AddRect(p_min+ImVec2(1,1), p_max, window->Color(ImGuiCol_BorderShadow), rounding);
window->DrawList->AddRect(p_min, p_max-ImVec2(1,1), window->Color(ImGuiCol_Border), rounding);
May be remove one of them and add 2 functions AddLine()
Sorry, I'm not a programmer.
The text was updated successfully, but these errors were encountered: