summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 639c074)
raw | patch | inline | side by side (parent: 639c074)
author | joncruz <joncruz@users.sourceforge.net> | |
Sat, 18 Apr 2009 20:48:46 +0000 (20:48 +0000) | ||
committer | joncruz <joncruz@users.sourceforge.net> | |
Sat, 18 Apr 2009 20:48:46 +0000 (20:48 +0000) |
src/widgets/icon.cpp | patch | blob | history |
diff --git a/src/widgets/icon.cpp b/src/widgets/icon.cpp
index ec3af771e4e6ada345c3030eca7162b40243ce6a..60cc40a7440463e4ee610cca6eacef4c4202b43e 100644 (file)
--- a/src/widgets/icon.cpp
+++ b/src/widgets/icon.cpp
GTK_ICON_SIZE_MENU, // for Inkscape::ICON_SIZE_DECORATION
};
+static std::map<Glib::ustring, Glib::ustring> legacyNames;
+
class IconCacheItem
{
public:
return TRUE;
}
+static GdkPixbuf* renderup( gchar const* name, Inkscape::IconSize lsize, unsigned psize );
+
// PUBLIC CALL:
void sp_icon_fetch_pixbuf( SPIcon *icon )
{
+ g_message("sp_icon_fetch_pixbuf(%p) [%s]", icon, icon->name);
if ( icon ) {
if ( !icon->pb ) {
icon->psize = sp_icon_get_phys_size(icon->lsize);
- GtkIconTheme *theme = gtk_icon_theme_get_default();
+ icon->pb = renderup(icon->name, icon->lsize, icon->psize);
+ }
+ }
+}
- GdkPixbuf *pb = 0;
- if (gtk_icon_theme_has_icon(theme, icon->name)) {
- pb = gtk_icon_theme_load_icon(theme, icon->name, icon->psize, (GtkIconLookupFlags) 0, NULL);
- }
- if (!pb) {
- pb = sp_icon_image_load_svg( icon->name, Inkscape::getRegisteredIconSize(icon->lsize), icon->psize );
- // if this was loaded from SVG, add it as a builtin icon
- if (pb) {
- gtk_icon_theme_add_builtin_icon(icon->name, icon->psize, pb);
- }
- }
- if (!pb) {
- pb = sp_icon_image_load_pixmap( icon->name, icon->lsize, icon->psize );
- }
- if ( pb ) {
- icon->pb = pb;
- } else {
- /* TODO: We should do something more useful if we can't load the image. */
- g_warning ("failed to load icon '%s'", icon->name);
- }
+static GdkPixbuf* renderup( gchar const* name, Inkscape::IconSize lsize, unsigned psize ) {
+ GtkIconTheme *theme = gtk_icon_theme_get_default();
+
+ GdkPixbuf *pb = 0;
+ if (gtk_icon_theme_has_icon(theme, name)) {
+ pb = gtk_icon_theme_load_icon(theme, name, psize, (GtkIconLookupFlags) 0, NULL);
+ }
+ if (!pb) {
+ pb = sp_icon_image_load_svg( name, Inkscape::getRegisteredIconSize(lsize), psize );
+ if (!pb && (legacyNames.find(name) != legacyNames.end())) {
+ g_message("Checking fallback [%s]->[%s]", name, legacyNames[name].c_str());
+ pb = sp_icon_image_load_svg( legacyNames[name].c_str(), Inkscape::getRegisteredIconSize(lsize), psize );
+ }
+
+ // if this was loaded from SVG, add it as a builtin icon
+ if (pb) {
+ gtk_icon_theme_add_builtin_icon(name, psize, pb);
}
}
+ if (!pb) {
+ pb = sp_icon_image_load_pixmap( name, lsize, psize );
+ }
+ if ( !pb ) {
+ // TODO: We should do something more useful if we can't load the image.
+ g_warning ("failed to load icon '%s'", name);
+ }
+ return pb;
}
static void sp_icon_screen_changed( GtkWidget *widget, GdkScreen *previous_screen )
static Glib::ustring icon_cache_key(gchar const *name, unsigned lsize, unsigned psize);
static GdkPixbuf *get_cached_pixbuf(Glib::ustring const &key);
-std::map<Glib::ustring, Glib::ustring> legacyNames;
-
static void setupLegacyNaming() {
legacyNames["view-fullscreen"] = "fullscreen";
legacyNames["edit-select-all"] = "selection_select_all";
if ( stockFound ) {
img = gtk_image_new_from_stock( name, mappedSize );
- }
- else if ( legacyNames.find(name) != legacyNames.end() ) {
+ } else {
img = gtk_image_new_from_icon_name( name, mappedSize );
if ( dump ) {
g_message("gtk_image_new_from_icon_name( '%s', %d ) = %p", name, mappedSize, img);
widget = GTK_WIDGET(img);
img = 0;
+ if (!gtk_icon_theme_has_icon(gtk_icon_theme_get_default(), name)) {
+ // TODO temporary work-around. until background rendering is restored.
+ int psize = sp_icon_get_phys_size(lsize);
+ renderup(name, lsize, psize);
+ }
+
// Add a hook to render if set visible before prerender is done.
// TODO restore g_signal_connect( G_OBJECT(widget), "map", G_CALLBACK(imageMapNamedCB), GINT_TO_POINTER(0) );