aboutsummaryrefslogtreecommitdiffstats
path: root/main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java
diff options
context:
space:
mode:
authorrsudev <rasch@munin-soft.de>2011-09-20 07:40:41 +0200
committerrsudev <rasch@munin-soft.de>2011-09-20 07:56:41 +0200
commita2f2c5db407dd27d9c24cccb42dd45450f8c20af (patch)
treee18186c3f2a48708b58abddc8894a63c9735bb6f /main/src/cgeo/geocaching/maps/mapsforge/MapsforgeOtherCachersOverlay.java
parent617d43896cc074a8233e6fdb7f96568afd4f331a (diff)
downloadcgeo-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.java112
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