diff options
| author | rsudev <rasch@munin-soft.de> | 2011-09-20 07:40:41 +0200 |
|---|---|---|
| committer | rsudev <rasch@munin-soft.de> | 2011-09-20 07:56:41 +0200 |
| commit | a2f2c5db407dd27d9c24cccb42dd45450f8c20af (patch) | |
| tree | e18186c3f2a48708b58abddc8894a63c9735bb6f /main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java | |
| parent | 617d43896cc074a8233e6fdb7f96568afd4f331a (diff) | |
| download | cgeo-a2f2c5db407dd27d9c24cccb42dd45450f8c20af.zip cgeo-a2f2c5db407dd27d9c24cccb42dd45450f8c20af.tar.gz cgeo-a2f2c5db407dd27d9c24cccb42dd45450f8c20af.tar.bz2 | |
Renamed map classes to uppercase
Diffstat (limited to 'main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java')
| -rw-r--r-- | main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java b/main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java new file mode 100644 index 0000000..8bd70e4 --- /dev/null +++ b/main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java @@ -0,0 +1,112 @@ +package cgeo.geocaching.maps.mapsforge; + +import cgeo.geocaching.maps.OtherCachersOverlay; +import cgeo.geocaching.maps.interfaces.ItemizedOverlayImpl; +import cgeo.geocaching.maps.interfaces.MapProjectionImpl; +import cgeo.geocaching.maps.interfaces.MapViewImpl; + +import org.mapsforge.android.maps.ItemizedOverlay; +import org.mapsforge.android.maps.Projection; + +import android.content.Context; +import android.graphics.Canvas; +import android.graphics.Point; +import android.graphics.drawable.Drawable; + +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + +public class MapsforgeOtherCachersOverlay extends ItemizedOverlay<MapsforgeOtherCachersOverlayItem> implements ItemizedOverlayImpl { + + private OtherCachersOverlay base; + private Lock lock = new ReentrantLock(); + + public MapsforgeOtherCachersOverlay(Context contextIn, Drawable markerIn) { + super(boundCenter(markerIn)); + base = new OtherCachersOverlay(this, contextIn); + } + + @Override + public OtherCachersOverlay getBase() { + return base; + } + + @Override + protected MapsforgeOtherCachersOverlayItem createItem(int i) { + if (base == null) + return null; + + return (MapsforgeOtherCachersOverlayItem) base.createItem(i); + } + + @Override + public int size() { + if (base == null) + return 0; + + return base.size(); + } + + @Override + protected boolean onTap(int arg0) { + if (base == null) + return false; + + return base.onTap(arg0); + } + + @Override + protected void drawOverlayBitmap(Canvas canvas, Point drawPosition, + Projection projection, byte drawZoomLevel) { + + base.drawOverlayBitmap(canvas, drawPosition, new MapsforgeMapProjection(projection), drawZoomLevel); + } + + @Override + public void superPopulate() { + populate(); + } + + @Override + public Drawable superBoundCenter(Drawable markerIn) { + return super.boundCenter(markerIn); + } + + @Override + public Drawable superBoundCenterBottom(Drawable marker) { + return super.boundCenterBottom(marker); + } + + @Override + public void superSetLastFocusedItemIndex(int i) { + // Nothing to do here + } + + @Override + public boolean superOnTap(int index) { + return super.onTap(index); + } + + @Override + public void superDraw(Canvas canvas, MapViewImpl mapView, boolean shadow) { + // Nothing to do here + } + + @Override + public void superDrawOverlayBitmap(Canvas canvas, Point drawPosition, + MapProjectionImpl projection, byte drawZoomLevel) { + + super.drawOverlayBitmap(canvas, drawPosition, (Projection) projection.getImpl(), drawZoomLevel); + } + + @Override + public void lock() { + lock.lock(); + } + + @Override + public void unlock() { + lock.unlock(); + } + +}
\ No newline at end of file |
