我创建了一个带有 3 个子项、一个标签和 2 个按钮的 action_bar 小部件。我在 gtk_widget_set_size_request() 方法中尝试了多种宽度和高度尺寸。无论我设置的尺寸是多少...
我创建了一个带有 3 个子项、一个标签和 2 个按钮的 action_bar 小部件。我在该方法中尝试了多种宽度和高度尺寸 gtk_widget_set_size_request()
。无论我将操作栏的尺寸设置为多少,无论窗口本身的大小如何,操作栏的高度始终相同。
这是我为整个项目编写的代码。很抱歉,所有代码都挤在一起了。我遇到了一些复制和粘贴问题...
#include <gtk/gtk.h>
#include <pango/pango.h>
#include <stdio.h>
//READERS! This code is meant to be easily read for people who want to learn!
//Handles initializing the window
static void activateWindow(GtkApplication *app) {
GtkWidget *window = gtk_application_window_new(app);
//TopActionBar | Creation
GtkWidget *topActionBar = gtk_action_bar_new();
//This line is the issue.
gtk_widget_set_size_request(GTK_WIDGET(topActionBar), -1, 17);
//TopActionBar | TITLE
GtkWidget *bideLabel = gtk_label_new(NULL);
gchar *bideLabelText = g_markup_printf_escaped("<b>BIDE</b>");
gtk_label_set_markup(GTK_LABEL(bideLabel), bideLabelText);
gtk_action_bar_pack_start(GTK_ACTION_BAR(topActionBar), GTK_WIDGET(bideLabel));
//TopActionBar | Open Folder Button
GtkWidget *openFolder = gtk_button_new();
gtk_button_set_label(GTK_BUTTON(openFolder), "Open Folder");
gtk_action_bar_pack_start(GTK_ACTION_BAR(topActionBar), GTK_WIDGET(openFolder));
//TopActionBar | Help Menu Button
gchar *helpButtonText = g_markup_printf_escaped("<u>HELP</u>");
GtkWidget *helpButton = gtk_button_new();
GtkWidget *helpLabel = gtk_label_new("Help");
gtk_label_set_markup(GTK_LABEL(helpLabel), helpButtonText);
gtk_button_set_child(GTK_BUTTON(helpButton), GTK_WIDGET(helpLabel));
gtk_action_bar_pack_start(GTK_ACTION_BAR(topActionBar), GTK_WIDGET(helpButton));
gtk_window_set_child(GTK_WINDOW(window), GTK_WIDGET(topActionBar));
gtk_window_present(GTK_WINDOW(window));
}
int main(int argc, char *argv[]){
GtkApplication *app = gtk_application_new("me.lufthor.bide", G_APPLICATION_DEFAULT_FLAGS);
g_signal_connect(app, "activate", G_CALLBACK(activateWindow), NULL);
return g_application_run(G_APPLICATION(app), argc, argv);
}
我尝试调整高度和宽度值,但没有任何变化。
printf()
在 C 中,它被缓冲,并且只有当遇到新行时才会打印
不完全的。
流通常有以下三种模式: 无缓冲 , 全缓冲 , 行缓冲 。通常 stdout
是 行缓冲的 ,当打印 时刷新数据 '\n'
,其内部缓冲区已满或由于显式命令,例如 fflush(stdout)
.
然而 C 对这 3 种模式有具体说明: 对这些特性的支持是由实现定义的 。C17dr § 7.21.3 3.
因此,看到输出和看不到输出都符合 OP 的代码。
为了确保输出可见,请刷新。否则,请遵循实现定义的行为。
printf("Hello world");
fflush(stdout); // add
while(1);