static void gimp_view_renderer_imagefile_render (GimpViewRenderer *renderer, GtkWidget *widget) { GdkPixbuf *pixbuf = gimp_view_renderer_get_frame_pixbuf (renderer, widget, renderer->width, renderer->height); if (! pixbuf) { GimpImagefile *imagefile = GIMP_IMAGEFILE (renderer->viewable); pixbuf = gimp_view_renderer_imagefile_get_icon (imagefile, widget, MIN (renderer->width, renderer->height)); } if (pixbuf) { gimp_view_renderer_render_pixbuf (renderer, widget, pixbuf); g_object_unref (pixbuf); } else { const gchar *icon_name = gimp_viewable_get_icon_name (renderer->viewable); gimp_view_renderer_render_icon (renderer, widget, icon_name); } }
static void gimp_view_renderer_layer_render (GimpViewRenderer *renderer, GtkWidget *widget) { const gchar *icon_name = NULL; if (gimp_layer_is_floating_sel (GIMP_LAYER (renderer->viewable))) { icon_name = GIMP_STOCK_FLOATING_SELECTION; } else if (gimp_item_is_text_layer (GIMP_ITEM (renderer->viewable))) { icon_name = gimp_viewable_get_icon_name (renderer->viewable); } else { GimpContainer *children = gimp_viewable_get_children (renderer->viewable); if (children && gimp_container_get_n_children (children) == 0) icon_name = "folder"; } if (icon_name) gimp_view_renderer_render_icon (renderer, widget, icon_name); else GIMP_VIEW_RENDERER_CLASS (parent_class)->render (renderer, widget); }
static void gimp_view_renderer_real_render (GimpViewRenderer *renderer, GtkWidget *widget) { GdkPixbuf *pixbuf; GimpTempBuf *temp_buf; const gchar *icon_name; pixbuf = gimp_viewable_get_pixbuf (renderer->viewable, renderer->context, renderer->width, renderer->height); if (pixbuf) { gimp_view_renderer_render_pixbuf (renderer, widget, pixbuf); return; } temp_buf = gimp_viewable_get_preview (renderer->viewable, renderer->context, renderer->width, renderer->height); if (temp_buf) { gimp_view_renderer_render_temp_buf_simple (renderer, widget, temp_buf); return; } icon_name = gimp_viewable_get_icon_name (renderer->viewable); gimp_view_renderer_render_icon (renderer, widget, icon_name); }
static void gimp_view_renderer_buffer_render (GimpViewRenderer *renderer, GtkWidget *widget) { gint buffer_width; gint buffer_height; gint view_width; gint view_height; gboolean scaling_up; GimpTempBuf *render_buf = NULL; gimp_viewable_get_size (renderer->viewable, &buffer_width, &buffer_height); gimp_viewable_calc_preview_size (buffer_width, buffer_height, renderer->width, renderer->height, TRUE, 1.0, 1.0, &view_width, &view_height, &scaling_up); if (scaling_up) { GimpTempBuf *temp_buf; temp_buf = gimp_viewable_get_new_preview (renderer->viewable, renderer->context, buffer_width, buffer_height); if (temp_buf) { render_buf = gimp_temp_buf_scale (temp_buf, view_width, view_height); gimp_temp_buf_unref (temp_buf); } } else { render_buf = gimp_viewable_get_new_preview (renderer->viewable, renderer->context, view_width, view_height); } if (render_buf) { gimp_view_renderer_render_temp_buf_simple (renderer, render_buf); gimp_temp_buf_unref (render_buf); } else /* no preview available */ { const gchar *icon_name; icon_name = gimp_viewable_get_icon_name (renderer->viewable); gimp_view_renderer_render_icon (renderer, widget, icon_name); } }
static void gimp_view_renderer_image_render (GimpViewRenderer *renderer, GtkWidget *widget) { GimpViewRendererImage *rendererimage = GIMP_VIEW_RENDERER_IMAGE (renderer); GimpImage *image = GIMP_IMAGE (renderer->viewable); const gchar *icon_name; /* The conditions checked here are mostly a hack to hide the fact that * we are creating the channel preview from the image preview and turning * off visibility of a channel has the side-effect of painting the channel * preview all black. See bug #459518 for details. */ if (rendererimage->channel == -1 || (gimp_image_get_component_visible (image, rendererimage->channel) && gimp_image_get_component_visible (image, GIMP_ALPHA_CHANNEL))) { gint view_width; gint view_height; gdouble xres; gdouble yres; gboolean scaling_up; GimpTempBuf *render_buf = NULL; gimp_image_get_resolution (image, &xres, &yres); gimp_viewable_calc_preview_size (gimp_image_get_width (image), gimp_image_get_height (image), renderer->width, renderer->height, renderer->dot_for_dot, xres, yres, &view_width, &view_height, &scaling_up); if (scaling_up) { GimpTempBuf *temp_buf; temp_buf = gimp_viewable_get_new_preview (renderer->viewable, renderer->context, gimp_image_get_width (image), gimp_image_get_height (image)); if (temp_buf) { render_buf = gimp_temp_buf_scale (temp_buf, view_width, view_height); gimp_temp_buf_unref (temp_buf); } } else { render_buf = gimp_viewable_get_new_preview (renderer->viewable, renderer->context, view_width, view_height); } if (render_buf) { gint render_buf_x = 0; gint render_buf_y = 0; gint component_index = -1; /* xresolution != yresolution */ if (view_width > renderer->width || view_height > renderer->height) { GimpTempBuf *temp_buf; temp_buf = gimp_temp_buf_scale (render_buf, renderer->width, renderer->height); gimp_temp_buf_unref (render_buf); render_buf = temp_buf; } if (view_width < renderer->width) render_buf_x = (renderer->width - view_width) / 2; if (view_height < renderer->height) render_buf_y = (renderer->height - view_height) / 2; if (rendererimage->channel != -1) component_index = gimp_image_get_component_index (image, rendererimage->channel); gimp_view_renderer_render_temp_buf (renderer, widget, render_buf, render_buf_x, render_buf_y, component_index, GIMP_VIEW_BG_CHECKS, GIMP_VIEW_BG_WHITE); gimp_temp_buf_unref (render_buf); return; } } switch (rendererimage->channel) { case GIMP_RED_CHANNEL: icon_name = GIMP_STOCK_CHANNEL_RED; break; case GIMP_GREEN_CHANNEL: icon_name = GIMP_STOCK_CHANNEL_GREEN; break; case GIMP_BLUE_CHANNEL: icon_name = GIMP_STOCK_CHANNEL_BLUE; break; case GIMP_GRAY_CHANNEL: icon_name = GIMP_STOCK_CHANNEL_GRAY; break; case GIMP_INDEXED_CHANNEL: icon_name = GIMP_STOCK_CHANNEL_INDEXED; break; case GIMP_ALPHA_CHANNEL: icon_name = GIMP_STOCK_CHANNEL_ALPHA; break; default: icon_name = gimp_viewable_get_icon_name (renderer->viewable); break; } gimp_view_renderer_render_icon (renderer, widget, icon_name); }
void gimp_view_renderer_draw (GimpViewRenderer *renderer, GtkWidget *widget, cairo_t *cr, gint available_width, gint available_height) { g_return_if_fail (GIMP_IS_VIEW_RENDERER (renderer)); g_return_if_fail (GTK_IS_WIDGET (widget)); g_return_if_fail (cr != NULL); if (G_UNLIKELY (renderer->context == NULL)) g_warning ("%s: renderer->context is NULL", G_STRFUNC); if (! gtk_widget_is_drawable (widget)) return; if (renderer->viewable) { cairo_save (cr); GIMP_VIEW_RENDERER_GET_CLASS (renderer)->draw (renderer, widget, cr, available_width, available_height); cairo_restore (cr); } else { GimpViewableClass *viewable_class; viewable_class = g_type_class_ref (renderer->viewable_type); gimp_view_renderer_render_icon (renderer, widget, viewable_class->default_icon_name); g_type_class_unref (viewable_class); gimp_view_renderer_real_draw (renderer, widget, cr, available_width, available_height); } if (renderer->border_width > 0) { gint width = renderer->width + renderer->border_width; gint height = renderer->height + renderer->border_width; gdouble x, y; cairo_set_line_width (cr, renderer->border_width); cairo_set_line_join (cr, CAIRO_LINE_JOIN_ROUND); gimp_cairo_set_source_rgb (cr, &renderer->border_color); x = (available_width - width) / 2.0; y = (available_height - height) / 2.0; cairo_rectangle (cr, x, y, width, height); cairo_stroke (cr); } }