mirror of
https://github.com/SerenityOS/serenity
synced 2024-10-04 23:19:27 +00:00
GSpinBox: Put nice little arrow glyphs on the buttons.
This commit is contained in:
parent
a00a2a9db5
commit
4abffa4dbe
Binary file not shown.
|
@ -15,10 +15,10 @@ GSpinBox::GSpinBox(GWidget* parent)
|
|||
m_editor->set_text(String::format("%d", m_value));
|
||||
};
|
||||
m_increment_button = new GButton(this);
|
||||
m_increment_button->set_caption("+");
|
||||
m_increment_button->set_caption("\xf6");
|
||||
m_increment_button->on_click = [this] (GButton&) { set_value(m_value + 1); };
|
||||
m_decrement_button = new GButton(this);
|
||||
m_decrement_button->set_caption("-");
|
||||
m_decrement_button->set_caption("\xf7");
|
||||
m_decrement_button->on_click = [this] (GButton&) { set_value(m_value - 1); };
|
||||
}
|
||||
|
||||
|
@ -64,7 +64,7 @@ void GSpinBox::set_range(int min, int max)
|
|||
void GSpinBox::resize_event(GResizeEvent& event)
|
||||
{
|
||||
int button_height = event.size().height() / 2;
|
||||
int button_width = 16;
|
||||
int button_width = 15;
|
||||
m_increment_button->set_relative_rect(width() - button_width, 0, button_width, button_height);
|
||||
m_decrement_button->set_relative_rect(width() - button_width, button_height, button_width, button_height);
|
||||
m_editor->set_relative_rect(0, 0, width() - button_width, height());
|
||||
|
|
|
@ -6,6 +6,7 @@
|
|||
#include <AK/StdLibExtras.h>
|
||||
#include <AK/StringBuilder.h>
|
||||
#include <unistd.h>
|
||||
#include <stdio.h>
|
||||
|
||||
Painter::Painter(GraphicsBitmap& bitmap)
|
||||
: m_target(bitmap)
|
||||
|
@ -348,27 +349,30 @@ void Painter::draw_text(const Rect& rect, const char* text, int length, const Fo
|
|||
{
|
||||
String elided_text;
|
||||
if (elision == TextElision::Right) {
|
||||
int text_width = font.width(text, length);
|
||||
if (font.width(text, length) > rect.width()) {
|
||||
int glyph_spacing = font.glyph_spacing();
|
||||
int new_length = 0;
|
||||
int new_width = font.width("...");
|
||||
for (int i = 0; i < length; ++i) {
|
||||
int glyph_width = font.glyph_width(text[i]);
|
||||
// NOTE: Glyph spacing should not be added after the last glyph on the line,
|
||||
// but since we are here because the last glyph does not actually fit on the line,
|
||||
// we don't have to worry about spacing.
|
||||
int width_with_this_glyph_included = new_width + glyph_width + glyph_spacing;
|
||||
if (width_with_this_glyph_included > rect.width())
|
||||
break;
|
||||
++new_length;
|
||||
new_width += glyph_width + glyph_spacing;
|
||||
if (new_width < text_width) {
|
||||
for (int i = 0; i < length; ++i) {
|
||||
int glyph_width = font.glyph_width(text[i]);
|
||||
// NOTE: Glyph spacing should not be added after the last glyph on the line,
|
||||
// but since we are here because the last glyph does not actually fit on the line,
|
||||
// we don't have to worry about spacing.
|
||||
int width_with_this_glyph_included = new_width + glyph_width + glyph_spacing;
|
||||
if (width_with_this_glyph_included > rect.width())
|
||||
break;
|
||||
++new_length;
|
||||
new_width += glyph_width + glyph_spacing;
|
||||
}
|
||||
StringBuilder builder;
|
||||
builder.append(text, new_length);
|
||||
builder.append("...");
|
||||
elided_text = builder.to_string();
|
||||
text = elided_text.characters();
|
||||
length = elided_text.length();
|
||||
}
|
||||
StringBuilder builder;
|
||||
builder.append(text, new_length);
|
||||
builder.append("...");
|
||||
elided_text = builder.to_string();
|
||||
text = elided_text.characters();
|
||||
length = elided_text.length();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue