GTK: Fix auto-completion popup height to better fit contents

This commit is contained in:
Colomban Wendling 2014-09-11 14:37:12 +02:00
parent 7d38ff67ec
commit 61eaf23a26

View File

@ -1226,12 +1226,11 @@ Window::~Window() {}
void Window::Destroy() { void Window::Destroy() {
if (wid) { if (wid) {
if (dynamic_cast<ListBox*>(this)) { ListBox *listbox = dynamic_cast<ListBox*>(this);
if (listbox) {
gtk_widget_hide(GTK_WIDGET(wid)); gtk_widget_hide(GTK_WIDGET(wid));
// clear up window content // clear up window content
GtkWidget *child = gtk_bin_get_child(GTK_BIN(wid)); listbox->Clear();
if (child)
gtk_widget_destroy(child);
// resize the window to the smallest possible size for it to adapt // resize the window to the smallest possible size for it to adapt
// to future content // to future content
gtk_window_resize(GTK_WINDOW(wid), 1, 1); gtk_window_resize(GTK_WINDOW(wid), 1, 1);
@ -1455,6 +1454,7 @@ public:
virtual void SetAverageCharWidth(int width); virtual void SetAverageCharWidth(int width);
virtual void SetVisibleRows(int rows); virtual void SetVisibleRows(int rows);
virtual int GetVisibleRows() const; virtual int GetVisibleRows() const;
int GetRowHeight();
virtual PRectangle GetDesiredRect(); virtual PRectangle GetDesiredRect();
virtual int CaretFromEdge(); virtual int CaretFromEdge();
virtual void Clear(); virtual void Clear();
@ -1541,10 +1541,12 @@ static void StyleSet(GtkWidget *w, GtkStyle*, void*) {
} }
void ListBoxX::Create(Window &, int, Point, int, bool, int) { void ListBoxX::Create(Window &, int, Point, int, bool, int) {
if (widCached == 0) if (widCached != 0) {
widCached = gtk_window_new(GTK_WINDOW_POPUP); wid = widCached;
return;
}
wid = widCached; wid = widCached = gtk_window_new(GTK_WINDOW_POPUP);
GtkWidget *frame = gtk_frame_new(NULL); GtkWidget *frame = gtk_frame_new(NULL);
gtk_widget_show(frame); gtk_widget_show(frame);
@ -1598,7 +1600,6 @@ void ListBoxX::Create(Window &, int, Point, int, bool, int) {
gtk_widget_show(wid); gtk_widget_show(wid);
g_signal_connect(G_OBJECT(wid), "button_press_event", g_signal_connect(G_OBJECT(wid), "button_press_event",
G_CALLBACK(ButtonPress), this); G_CALLBACK(ButtonPress), this);
gtk_widget_realize(PWidget(wid));
} }
void ListBoxX::SetFont(Font &scint_font) { void ListBoxX::SetFont(Font &scint_font) {
@ -1625,6 +1626,21 @@ int ListBoxX::GetVisibleRows() const {
return desiredVisibleRows; return desiredVisibleRows;
} }
int ListBoxX::GetRowHeight()
{
int row_height=0;
int vertical_separator=0;
int expander_size=0;
GtkTreeViewColumn *column = gtk_tree_view_get_column(GTK_TREE_VIEW(list), 0);
gtk_tree_view_column_cell_get_size(column, NULL, NULL, NULL, NULL, &row_height);
gtk_widget_style_get(PWidget(list),
"vertical-separator", &vertical_separator,
"expander-size", &expander_size, NULL);
row_height += vertical_separator;
row_height = Platform::Maximum(row_height, expander_size);
return row_height;
}
PRectangle ListBoxX::GetDesiredRect() { PRectangle ListBoxX::GetDesiredRect() {
// Before any size allocated pretend its 100 wide so not scrolled // Before any size allocated pretend its 100 wide so not scrolled
PRectangle rc(0, 0, 100, 100); PRectangle rc(0, 0, 100, 100);
@ -1634,22 +1650,19 @@ PRectangle ListBoxX::GetDesiredRect() {
rows = desiredVisibleRows; rows = desiredVisibleRows;
GtkRequisition req; GtkRequisition req;
#if GTK_CHECK_VERSION(3,0,0)
// This, apparently unnecessary call, ensures gtk_tree_view_column_cell_get_size // This, apparently unnecessary call, ensures gtk_tree_view_column_cell_get_size
// returns reasonable values. // returns reasonable values.
#if GTK_CHECK_VERSION(3,0,0)
gtk_widget_get_preferred_size(GTK_WIDGET(scroller), NULL, &req); gtk_widget_get_preferred_size(GTK_WIDGET(scroller), NULL, &req);
#else
gtk_widget_size_request(GTK_WIDGET(scroller), &req);
#endif #endif
int height; int height;
// First calculate height of the clist for our desired visible // First calculate height of the clist for our desired visible
// row count otherwise it tries to expand to the total # of rows // row count otherwise it tries to expand to the total # of rows
// Get cell height // Get cell height
int row_width=0; int row_height = GetRowHeight();
int row_height=0;
GtkTreeViewColumn * column =
gtk_tree_view_get_column(GTK_TREE_VIEW(list), 0);
gtk_tree_view_column_cell_get_size(column, NULL,
NULL, NULL, &row_width, &row_height);
#if GTK_CHECK_VERSION(3,0,0) #if GTK_CHECK_VERSION(3,0,0)
GtkStyleContext *styleContextList = gtk_widget_get_style_context(PWidget(list)); GtkStyleContext *styleContextList = gtk_widget_get_style_context(PWidget(list));
GtkBorder padding; GtkBorder padding;
@ -1661,7 +1674,7 @@ PRectangle ListBoxX::GetDesiredRect() {
int ythickness = PWidget(list)->style->ythickness; int ythickness = PWidget(list)->style->ythickness;
height = (rows * row_height height = (rows * row_height
+ 2 * (ythickness + 2 * (ythickness
+ GTK_CONTAINER(PWidget(list))->border_width + 1)); + GTK_CONTAINER(PWidget(list))->border_width));
#endif #endif
gtk_widget_set_size_request(GTK_WIDGET(PWidget(list)), -1, height); gtk_widget_set_size_request(GTK_WIDGET(PWidget(list)), -1, height);
@ -1792,12 +1805,7 @@ void ListBoxX::Select(int n) {
+ adj->lower - adj->page_size / 2; + adj->lower - adj->page_size / 2;
#endif #endif
// Get cell height // Get cell height
int row_width; int row_height = GetRowHeight();
int row_height;
GtkTreeViewColumn * column =
gtk_tree_view_get_column(GTK_TREE_VIEW(list), 0);
gtk_tree_view_column_cell_get_size(column, NULL, NULL,
NULL, &row_width, &row_height);
int rows = Length(); int rows = Length();
if ((rows == 0) || (rows > desiredVisibleRows)) if ((rows == 0) || (rows > desiredVisibleRows))