forked from AuroraMiddleware/gtk
d9c9259861
It doesn't make sense to keep them separate as GtkSizeRequest requires a GtkWidget and GtkWidget implements GtkSizeRequest, so you can never have one without the other. It also makes the code a lot easier because no casts are required when calling functions. Also, the names would translate to gtk_widget_get_width() and people agreed that this would be a too generic name, so a "preferred" was added to the names. So this patch moves the functions: gtk_size_request_get_request_mode() => gtk_widget_get_request_mode() gtk_size_request_get_width() => gtk_widget_get_preferred_width() gtk_size_request_get_height() => gtk_widget_get_preferred_height() gtk_size_request_get_size() => gtk_widget_get_preferred_size() gtk_size_request_get_width_for_height() => gtk_widget_get_preferred_width_for_height() gtk_size_request_get_height_for_width() => gtk_widget_get_preferred_height_for_width() ... and moves the corresponding vfuncs to the GtkWidgetClass. The patch also renames the implementations of the vfuncs in widgets to include the word "preferrred".
157 lines
4.3 KiB
C
157 lines
4.3 KiB
C
#include "config.h"
|
|
#include <gtk/gtk.h>
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
GdkInterpType interp_type = GDK_INTERP_BILINEAR;
|
|
int overall_alpha = 255;
|
|
GdkPixbuf *pixbuf;
|
|
GtkWidget *darea;
|
|
|
|
void
|
|
set_interp_type (GtkWidget *widget, gpointer data)
|
|
{
|
|
guint types[] = { GDK_INTERP_NEAREST,
|
|
GDK_INTERP_BILINEAR,
|
|
GDK_INTERP_TILES,
|
|
GDK_INTERP_HYPER };
|
|
|
|
interp_type = types[gtk_combo_box_get_active (GTK_COMBO_BOX (widget))];
|
|
gtk_widget_queue_draw (darea);
|
|
}
|
|
|
|
void
|
|
overall_changed_cb (GtkAdjustment *adjustment, gpointer data)
|
|
{
|
|
if (adjustment->value != overall_alpha)
|
|
{
|
|
overall_alpha = adjustment->value;
|
|
gtk_widget_queue_draw (darea);
|
|
}
|
|
}
|
|
|
|
gboolean
|
|
draw_cb (GtkWidget *widget, cairo_t *cr, gpointer data)
|
|
{
|
|
GdkPixbuf *dest;
|
|
int width, height;
|
|
|
|
width = gtk_widget_get_allocated_width (widget);
|
|
height = gtk_widget_get_allocated_height (widget);
|
|
|
|
dest = gdk_pixbuf_new (GDK_COLORSPACE_RGB, FALSE, 8, width, height);
|
|
|
|
gdk_pixbuf_composite_color (pixbuf, dest,
|
|
0, 0, width, height,
|
|
0, 0,
|
|
(double) width / gdk_pixbuf_get_width (pixbuf),
|
|
(double) height / gdk_pixbuf_get_height (pixbuf),
|
|
interp_type, overall_alpha,
|
|
0, 0, 16, 0xaaaaaa, 0x555555);
|
|
|
|
gdk_cairo_set_source_pixbuf (cr, dest, 0, 0);
|
|
cairo_paint (cr);
|
|
|
|
g_object_unref (dest);
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
extern void pixbuf_init();
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
GtkWidget *window, *vbox;
|
|
GtkWidget *combo_box;
|
|
GtkWidget *alignment;
|
|
GtkWidget *hbox, *label, *hscale;
|
|
GtkAdjustment *adjustment;
|
|
GtkRequisition scratch_requisition;
|
|
const gchar *creator;
|
|
GError *error;
|
|
|
|
pixbuf_init ();
|
|
|
|
gtk_init (&argc, &argv);
|
|
|
|
if (argc != 2) {
|
|
fprintf (stderr, "Usage: testpixbuf-scale FILE\n");
|
|
exit (1);
|
|
}
|
|
|
|
error = NULL;
|
|
pixbuf = gdk_pixbuf_new_from_file (argv[1], &error);
|
|
if (!pixbuf) {
|
|
fprintf (stderr, "Cannot load image: %s\n",
|
|
error->message);
|
|
g_error_free (error);
|
|
exit(1);
|
|
}
|
|
|
|
creator = gdk_pixbuf_get_option (pixbuf, "tEXt::Software");
|
|
if (creator)
|
|
g_print ("%s was created by '%s'\n", argv[1], creator);
|
|
|
|
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
|
g_signal_connect (window, "destroy",
|
|
G_CALLBACK (gtk_main_quit), NULL);
|
|
|
|
vbox = gtk_vbox_new (FALSE, 0);
|
|
gtk_container_add (GTK_CONTAINER (window), vbox);
|
|
|
|
combo_box = gtk_combo_box_new_text ();
|
|
|
|
gtk_combo_box_append_text (GTK_COMBO_BOX (combo_box), "NEAREST");
|
|
gtk_combo_box_append_text (GTK_COMBO_BOX (combo_box), "BILINEAR");
|
|
gtk_combo_box_append_text (GTK_COMBO_BOX (combo_box), "TILES");
|
|
gtk_combo_box_append_text (GTK_COMBO_BOX (combo_box), "HYPER");
|
|
|
|
gtk_combo_box_set_active (GTK_COMBO_BOX (combo_box), 1);
|
|
|
|
g_signal_connect (combo_box, "changed",
|
|
G_CALLBACK (set_interp_type),
|
|
NULL);
|
|
|
|
alignment = gtk_alignment_new (0.0, 0.0, 0.0, 0.5);
|
|
gtk_box_pack_start (GTK_BOX (vbox), alignment, FALSE, FALSE, 0);
|
|
|
|
hbox = gtk_hbox_new (FALSE, 4);
|
|
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
|
|
|
|
label = gtk_label_new ("Overall Alpha:");
|
|
gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
|
|
|
adjustment = GTK_ADJUSTMENT (gtk_adjustment_new (overall_alpha, 0, 255, 1, 10, 0));
|
|
g_signal_connect (adjustment, "value_changed",
|
|
G_CALLBACK (overall_changed_cb), NULL);
|
|
|
|
hscale = gtk_hscale_new (adjustment);
|
|
gtk_scale_set_digits (GTK_SCALE (hscale), 0);
|
|
gtk_box_pack_start (GTK_BOX (hbox), hscale, TRUE, TRUE, 0);
|
|
|
|
gtk_container_add (GTK_CONTAINER (alignment), combo_box);
|
|
gtk_widget_show_all (vbox);
|
|
|
|
/* Compute the size without the drawing area, so we know how big to make the default size */
|
|
gtk_widget_get_preferred_size ( (vbox),
|
|
&scratch_requisition, NULL);
|
|
|
|
darea = gtk_drawing_area_new ();
|
|
gtk_box_pack_start (GTK_BOX (vbox), darea, TRUE, TRUE, 0);
|
|
|
|
g_signal_connect (darea, "draw",
|
|
G_CALLBACK (draw_cb), NULL);
|
|
|
|
gtk_window_set_default_size (GTK_WINDOW (window),
|
|
gdk_pixbuf_get_width (pixbuf),
|
|
scratch_requisition.height + gdk_pixbuf_get_height (pixbuf));
|
|
|
|
gtk_widget_show_all (window);
|
|
|
|
gtk_main ();
|
|
|
|
return 0;
|
|
}
|