2017-12-06 18:22:24 +00:00
|
|
|
|
|
|
|
#include<gtk/gtk.h>
|
|
|
|
|
|
|
|
static const char *css =
|
|
|
|
".one {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border-left: 50px solid #0f0;"
|
|
|
|
" border-top: 10px solid red;"
|
|
|
|
" border-bottom: 50px solid teal;"
|
|
|
|
" border-right: 100px solid pink;"
|
|
|
|
" border-radius: 100px;"
|
|
|
|
"}"
|
|
|
|
".two {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border-left: 50px solid #0f0;"
|
|
|
|
" border-top: 10px solid red;"
|
|
|
|
" border-bottom: 50px solid teal;"
|
|
|
|
" border-right: 100px solid pink;"
|
|
|
|
" border-radius: 50%;"
|
|
|
|
"}"
|
|
|
|
".three {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border-left: 50px solid #0f0;"
|
|
|
|
" border-top: 10px solid red;"
|
|
|
|
" border-bottom: 50px solid teal;"
|
|
|
|
" border-right: 100px solid pink;"
|
|
|
|
" border-radius: 0px;"
|
|
|
|
"}"
|
|
|
|
".four {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border: 10px solid black;"
|
|
|
|
" border-radius: 999px;"
|
|
|
|
"}"
|
|
|
|
".five {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border: 30px solid black;"
|
|
|
|
" border-radius: 0px;"
|
|
|
|
"}"
|
|
|
|
".b1 {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border-top: 30px solid black;"
|
|
|
|
" border-radius: 0px;"
|
|
|
|
"}"
|
|
|
|
".b2 {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border-bottom: 30px solid black;"
|
|
|
|
" border-radius: 0px;"
|
|
|
|
"}"
|
|
|
|
".b3 {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border-right: 30px solid blue;"
|
|
|
|
" border-radius: 40px;"
|
|
|
|
"}"
|
|
|
|
".b4 {"
|
|
|
|
" all: unset;"
|
|
|
|
" min-width: 100px;"
|
|
|
|
" min-height:100px;"
|
|
|
|
" border-bottom: 30px solid blue;"
|
|
|
|
" border-radius: 40px;"
|
|
|
|
"}"
|
|
|
|
;
|
|
|
|
|
2020-02-10 03:24:47 +00:00
|
|
|
static void
|
|
|
|
quit_cb (GtkWidget *widget,
|
|
|
|
gpointer data)
|
|
|
|
{
|
|
|
|
gboolean *done = data;
|
|
|
|
|
|
|
|
*done = TRUE;
|
|
|
|
|
|
|
|
g_main_context_wakeup (NULL);
|
|
|
|
}
|
2017-12-06 18:22:24 +00:00
|
|
|
|
|
|
|
int
|
|
|
|
main (int argc, char **argv)
|
|
|
|
{
|
|
|
|
GtkWidget *window;
|
|
|
|
GtkWidget *box;
|
|
|
|
GtkWidget *top;
|
|
|
|
GtkWidget *bottom;
|
|
|
|
GtkWidget *w;
|
|
|
|
GtkCssProvider *provider;
|
2020-02-10 03:24:47 +00:00
|
|
|
gboolean done = FALSE;
|
2017-12-06 18:22:24 +00:00
|
|
|
|
|
|
|
gtk_init ();
|
|
|
|
|
|
|
|
provider = gtk_css_provider_new ();
|
|
|
|
gtk_css_provider_load_from_data (provider, css, -1);
|
|
|
|
gtk_style_context_add_provider_for_display (gdk_display_get_default (),
|
|
|
|
GTK_STYLE_PROVIDER (provider),
|
|
|
|
GTK_STYLE_PROVIDER_PRIORITY_APPLICATION);
|
|
|
|
|
2020-02-14 19:55:36 +00:00
|
|
|
window = gtk_window_new ();
|
2017-12-06 18:22:24 +00:00
|
|
|
box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 40);
|
|
|
|
top = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 40);
|
|
|
|
bottom = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 40);
|
2020-02-26 01:57:20 +00:00
|
|
|
gtk_widget_set_margin_start (box, 40);
|
|
|
|
gtk_widget_set_margin_end (box, 40);
|
|
|
|
gtk_widget_set_margin_top (box, 40);
|
|
|
|
gtk_widget_set_margin_bottom (box, 40);
|
2017-12-06 18:22:24 +00:00
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "one");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (top), w);
|
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "two");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (top), w);
|
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "three");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (top), w);
|
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "four");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (top), w);
|
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "five");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (top), w);
|
|
|
|
|
|
|
|
|
|
|
|
/* Bottom */
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "b1");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (bottom), w);
|
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "b2");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (bottom), w);
|
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "b3");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (bottom), w);
|
|
|
|
|
|
|
|
w = gtk_button_new ();
|
|
|
|
gtk_widget_set_valign (w, GTK_ALIGN_CENTER);
|
2020-04-10 16:08:16 +00:00
|
|
|
gtk_widget_add_css_class (w, "b4");
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_container_add (GTK_CONTAINER (bottom), w);
|
|
|
|
|
|
|
|
gtk_container_add (GTK_CONTAINER (box), top);
|
|
|
|
gtk_container_add (GTK_CONTAINER (box), bottom);
|
2020-05-02 21:26:54 +00:00
|
|
|
gtk_window_set_child (GTK_WINDOW (window), box);
|
2020-02-10 03:24:47 +00:00
|
|
|
g_signal_connect (window, "destroy", G_CALLBACK (quit_cb), &done);
|
2017-12-06 18:22:24 +00:00
|
|
|
gtk_widget_show (window);
|
|
|
|
|
2020-02-10 03:24:47 +00:00
|
|
|
while (!done)
|
|
|
|
g_main_context_iteration (NULL, TRUE);
|
2017-12-06 18:22:24 +00:00
|
|
|
|
|
|
|
gtk_widget_destroy (window);
|
|
|
|
}
|