Index: trunk/src/org/openstreetmap/josm/gui/layer/geoimage/GeoImageLayer.java
===================================================================
--- trunk/src/org/openstreetmap/josm/gui/layer/geoimage/GeoImageLayer.java	(revision 7783)
+++ trunk/src/org/openstreetmap/josm/gui/layer/geoimage/GeoImageLayer.java	(revision 7784)
@@ -401,4 +401,5 @@
 
         setName(l.getName());
+        thumbsLoaded &= l.thumbsLoaded;
     }
 
Index: trunk/src/org/openstreetmap/josm/gui/layer/geoimage/ThumbsLoader.java
===================================================================
--- trunk/src/org/openstreetmap/josm/gui/layer/geoimage/ThumbsLoader.java	(revision 7783)
+++ trunk/src/org/openstreetmap/josm/gui/layer/geoimage/ThumbsLoader.java	(revision 7784)
@@ -41,9 +41,12 @@
             if (stop) return;
 
-            data.get(i).thumbnail = loadThumb(data.get(i));
+            // Do not load thumbnails that were loaded before.
+            if (data.get(i).thumbnail == null) {
+                data.get(i).thumbnail = loadThumb(data.get(i));
 
-            if (Main.isDisplayingMapView()) {
-                layer.updateOffscreenBuffer = true;
-                Main.map.mapView.repaint();
+                if (Main.isDisplayingMapView()) {
+                    layer.updateOffscreenBuffer = true;
+                    Main.map.mapView.repaint();
+                }
             }
         }
