1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-05-31 11:38:11 +00:00

LibGUI: Allow specifying per-column text alignment.

This commit is contained in:
Andreas Kling 2019-02-28 11:27:04 +01:00
parent ce7019f38c
commit b4c20789fb
6 changed files with 35 additions and 23 deletions

View file

@ -7,7 +7,7 @@ enum Column {
State,
Priority,
Linear,
Committed,
Physical,
CPU,
Name,
__Count
@ -38,23 +38,23 @@ String ProcessTableModel::column_name(int column) const
case Column::State: return "State";
case Column::Priority: return "Priority";
case Column::Linear: return "Linear";
case Column::Committed: return "Committed";
case Column::Physical: return "Physical";
case Column::CPU: return "CPU";
case Column::Name: return "Name";
default: ASSERT_NOT_REACHED();
}
}
int ProcessTableModel::column_width(int column) const
GTableModel::ColumnMetadata ProcessTableModel::column_metadata(int column) const
{
switch (column) {
case Column::PID: return 30;
case Column::State: return 80;
case Column::Priority: return 80;
case Column::Linear: return 80;
case Column::Committed: return 80;
case Column::CPU: return 30;
case Column::Name: return 200;
case Column::PID: return { 30, TextAlignment::CenterRight };
case Column::State: return { 80, TextAlignment::CenterLeft };
case Column::Priority: return { 80, TextAlignment::CenterLeft };
case Column::Linear: return { 70, TextAlignment::CenterRight };
case Column::Physical: return { 70, TextAlignment::CenterRight };
case Column::CPU: return { 30, TextAlignment::CenterRight };
case Column::Name: return { 200, TextAlignment::CenterLeft };
default: ASSERT_NOT_REACHED();
}
}
@ -85,7 +85,7 @@ String ProcessTableModel::data(int row, int column) const
case Column::State: return process.current_state.state;
case Column::Priority: return process.current_state.priority;
case Column::Linear: return pretty_byte_size(process.current_state.linear);
case Column::Committed: return pretty_byte_size(process.current_state.committed);
case Column::Physical: return pretty_byte_size(process.current_state.physical);
case Column::CPU: return String::format("%d", (int)process.current_state.cpu_percent);
case Column::Name: return process.current_state.name;
}
@ -131,7 +131,7 @@ void ProcessTableModel::update()
state.name = parts[11];
state.linear = parts[12].to_uint(ok);
ASSERT(ok);
state.committed = parts[13].to_uint(ok);
state.physical = parts[13].to_uint(ok);
ASSERT(ok);
{

View file

@ -14,7 +14,7 @@ public:
virtual int row_count() const override;
virtual int column_count() const override;
virtual String column_name(int column) const override;
virtual int column_width(int column) const override;
virtual ColumnMetadata column_metadata(int column) const override;
virtual GModelIndex selected_index() const override;
virtual void set_selected_index(GModelIndex) override;
virtual String data(int row, int column) const override;
@ -30,8 +30,8 @@ private:
String state;
String user;
String priority;
unsigned linear;
unsigned committed;
size_t linear;
size_t physical;
float cpu_percent;
};

View file

@ -5,18 +5,24 @@
#include <AK/Function.h>
#include <AK/HashTable.h>
#include <LibGUI/GModelIndex.h>
#include <SharedGraphics/TextAlignment.h>
class GTableView;
class GTableModel {
public:
struct ColumnMetadata {
int preferred_width { 0 };
TextAlignment text_alignment { TextAlignment::CenterLeft };
};
virtual ~GTableModel();
virtual int row_count() const = 0;
virtual int column_count() const = 0;
virtual String row_name(int) const { return { }; }
virtual String column_name(int) const { return { }; }
virtual int column_width(int) const { return 0; }
virtual ColumnMetadata column_metadata(int) const { return { }; }
virtual String data(int row, int column) const = 0;
virtual void set_selected_index(GModelIndex) { }
virtual GModelIndex selected_index() const { return GModelIndex(); }

View file

@ -87,9 +87,11 @@ void GTableView::paint_event(GPaintEvent&)
int x_offset = 0;
for (int column_index = 0; column_index < m_model->column_count(); ++column_index) {
Rect cell_rect(horizontal_padding + x_offset, y, m_model->column_width(column_index), item_height());
painter.draw_text(cell_rect, m_model->data(row_index, column_index), TextAlignment::CenterLeft, text_color);
x_offset += m_model->column_width(column_index) + horizontal_padding;
auto column_metadata = m_model->column_metadata(column_index);
int column_width = column_metadata.preferred_width;
Rect cell_rect(horizontal_padding + x_offset, y, column_width, item_height());
painter.draw_text(cell_rect, m_model->data(row_index, column_index), column_metadata.text_alignment, text_color);
x_offset += column_width + horizontal_padding;
}
++painted_item_index;
};
@ -103,9 +105,11 @@ void GTableView::paint_event(GPaintEvent&)
painter.fill_rect({ 0, 0, width(), header_height() }, Color::LightGray);
int x_offset = 0;
for (int column_index = 0; column_index < m_model->column_count(); ++column_index) {
Rect cell_rect(x_offset, 0, m_model->column_width(column_index) + horizontal_padding, item_height());
auto column_metadata = m_model->column_metadata(column_index);
int column_width = column_metadata.preferred_width;
Rect cell_rect(x_offset, 0, column_width + horizontal_padding, item_height());
painter.draw_text(cell_rect.translated(horizontal_padding, 0), m_model->column_name(column_index), TextAlignment::CenterLeft, Color::Black);
x_offset += m_model->column_width(column_index) + horizontal_padding;
x_offset += column_width + horizontal_padding;
painter.draw_line(cell_rect.top_left(), cell_rect.bottom_left(), Color::White);
painter.draw_line(cell_rect.top_right(), cell_rect.bottom_right(), Color::DarkGray);
}

View file

@ -4,6 +4,7 @@
#include "Point.h"
#include "Rect.h"
#include "Size.h"
#include <SharedGraphics/TextAlignment.h>
#include <AK/AKString.h>
class CharacterBitmap;
@ -16,8 +17,6 @@ class GWidget;
class GWindow;
#endif
enum class TextAlignment { TopLeft, CenterLeft, Center, CenterRight };
class Painter {
public:
#ifdef USERLAND

View file

@ -0,0 +1,3 @@
#pragma once
enum class TextAlignment { TopLeft, CenterLeft, Center, CenterRight };