Group layer implementation, closes #99

This commit is contained in:
Emux 2016-07-22 19:27:54 +03:00
parent 6801102631
commit 42fd941d64
4 changed files with 135 additions and 10 deletions

View File

@ -27,9 +27,9 @@ import org.oscim.android.scalebar.MetricUnitAdapter;
import org.oscim.backend.CanvasAdapter; import org.oscim.backend.CanvasAdapter;
import org.oscim.core.MapPosition; import org.oscim.core.MapPosition;
import org.oscim.core.MercatorProjection; import org.oscim.core.MercatorProjection;
import org.oscim.layers.GroupLayer;
import org.oscim.layers.tile.buildings.BuildingLayer; import org.oscim.layers.tile.buildings.BuildingLayer;
import org.oscim.layers.tile.vector.labeling.LabelLayer; import org.oscim.layers.tile.vector.labeling.LabelLayer;
import org.oscim.map.Layers;
import org.oscim.renderer.BitmapRenderer; import org.oscim.renderer.BitmapRenderer;
import org.oscim.renderer.GLViewport; import org.oscim.renderer.GLViewport;
import org.oscim.theme.IRenderTheme; import org.oscim.theme.IRenderTheme;
@ -43,9 +43,10 @@ public class SimpleMapActivity extends BaseMapActivity {
public void onCreate(Bundle savedInstanceState) { public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
Layers layers = mMap.layers(); GroupLayer groupLayer = new GroupLayer(mMap);
layers.add(new BuildingLayer(mMap, mBaseLayer)); groupLayer.layers.add(new BuildingLayer(mMap, mBaseLayer));
layers.add(new LabelLayer(mMap, mBaseLayer)); groupLayer.layers.add(new LabelLayer(mMap, mBaseLayer));
mMap.layers().add(groupLayer);
mapScaleBar = new DefaultMapScaleBar(mMap); mapScaleBar = new DefaultMapScaleBar(mMap);
mapScaleBar.setScaleBarMode(DefaultMapScaleBar.ScaleBarMode.BOTH); mapScaleBar.setScaleBarMode(DefaultMapScaleBar.ScaleBarMode.BOTH);
@ -57,7 +58,7 @@ public class SimpleMapActivity extends BaseMapActivity {
BitmapRenderer renderer = (BitmapRenderer) mapScaleBarLayer.getRenderer(); BitmapRenderer renderer = (BitmapRenderer) mapScaleBarLayer.getRenderer();
renderer.setPosition(GLViewport.Position.BOTTOM_LEFT); renderer.setPosition(GLViewport.Position.BOTTOM_LEFT);
renderer.setOffset(5 * CanvasAdapter.dpi / 160, 0); renderer.setOffset(5 * CanvasAdapter.dpi / 160, 0);
layers.add(mapScaleBarLayer); mMap.layers().add(mapScaleBarLayer);
mMap.setTheme(VtmThemes.DEFAULT); mMap.setTheme(VtmThemes.DEFAULT);
} }

View File

@ -1,6 +1,23 @@
/*
* Copyright 2016 devemux86
*
* This file is part of the OpenScienceMap project (http://www.opensciencemap.org).
*
* This program is free software: you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.oscim.test; package org.oscim.test;
import org.oscim.gdx.GdxMapApp; import org.oscim.gdx.GdxMapApp;
import org.oscim.layers.GroupLayer;
import org.oscim.layers.tile.buildings.BuildingLayer; import org.oscim.layers.tile.buildings.BuildingLayer;
import org.oscim.layers.tile.vector.VectorTileLayer; import org.oscim.layers.tile.vector.VectorTileLayer;
import org.oscim.layers.tile.vector.labeling.LabelLayer; import org.oscim.layers.tile.vector.labeling.LabelLayer;
@ -16,8 +33,10 @@ public class MapTest extends GdxMapApp {
VectorTileLayer l = map.setBaseMap(new OSciMap4TileSource()); VectorTileLayer l = map.setBaseMap(new OSciMap4TileSource());
map.layers().add(new BuildingLayer(map, l)); GroupLayer groupLayer = new GroupLayer(mMap);
map.layers().add(new LabelLayer(map, l)); groupLayer.layers.add(new BuildingLayer(map, l));
groupLayer.layers.add(new LabelLayer(map, l));
map.layers().add(groupLayer);
map.setTheme(VtmThemes.DEFAULT); map.setTheme(VtmThemes.DEFAULT);
map.setMapPosition(53.075, 8.808, 1 << 17); map.setMapPosition(53.075, 8.808, 1 << 17);

View File

@ -0,0 +1,42 @@
/*
* Copyright 2016 devemux86
*
* This program is free software: you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.oscim.layers;
import org.oscim.map.Map;
import java.util.ArrayList;
import java.util.List;
/**
* A layer which is a group of other layers.
*/
public class GroupLayer extends Layer {
/**
* The group of other layers.
*/
public final List<Layer> layers = new ArrayList<>();
public GroupLayer(Map map) {
super(map);
}
@Override
public void onDetach() {
for (Layer layer : layers) {
layer.onDetach();
}
}
}

View File

@ -1,5 +1,6 @@
/* /*
* Copyright 2013 Hannes Janetzek * Copyright 2013 Hannes Janetzek
* Copyright 2016 devemux86
* *
* This file is part of the OpenScienceMap project (http://www.opensciencemap.org). * This file is part of the OpenScienceMap project (http://www.opensciencemap.org).
* *
@ -19,6 +20,7 @@ package org.oscim.map;
import org.oscim.event.Gesture; import org.oscim.event.Gesture;
import org.oscim.event.GestureListener; import org.oscim.event.GestureListener;
import org.oscim.event.MotionEvent; import org.oscim.event.MotionEvent;
import org.oscim.layers.GroupLayer;
import org.oscim.layers.Layer; import org.oscim.layers.Layer;
import org.oscim.map.Map.InputListener; import org.oscim.map.Map.InputListener;
import org.oscim.map.Map.UpdateListener; import org.oscim.map.Map.UpdateListener;
@ -38,7 +40,7 @@ public final class Layers extends AbstractList<Layer> {
Layers(Map map) { Layers(Map map) {
mMap = map; mMap = map;
mLayerList = new CopyOnWriteArrayList<Layer>(); mLayerList = new CopyOnWriteArrayList<>();
} }
@Override @Override
@ -56,12 +58,23 @@ public final class Layers extends AbstractList<Layer> {
if (mLayerList.contains(layer)) if (mLayerList.contains(layer))
throw new IllegalArgumentException("layer added twice"); throw new IllegalArgumentException("layer added twice");
// bind added layer
if (layer instanceof UpdateListener) if (layer instanceof UpdateListener)
mMap.events.bind((UpdateListener) layer); mMap.events.bind((UpdateListener) layer);
if (layer instanceof InputListener) if (layer instanceof InputListener)
mMap.input.bind((InputListener) layer); mMap.input.bind((InputListener) layer);
// bind added group layer
if (layer instanceof GroupLayer) {
GroupLayer groupLayer = (GroupLayer) layer;
for (Layer gl : groupLayer.layers) {
if (gl instanceof UpdateListener)
mMap.events.bind((UpdateListener) gl);
if (gl instanceof InputListener)
mMap.input.bind((InputListener) gl);
}
}
mLayerList.add(index, layer); mLayerList.add(index, layer);
mDirtyLayers = true; mDirtyLayers = true;
} }
@ -72,11 +85,23 @@ public final class Layers extends AbstractList<Layer> {
Layer remove = mLayerList.remove(index); Layer remove = mLayerList.remove(index);
// unbind removed layer
if (remove instanceof UpdateListener) if (remove instanceof UpdateListener)
mMap.events.unbind((UpdateListener) remove); mMap.events.unbind((UpdateListener) remove);
if (remove instanceof InputListener) if (remove instanceof InputListener)
mMap.input.unbind((InputListener) remove); mMap.input.unbind((InputListener) remove);
// unbind removed group layer
if (remove instanceof GroupLayer) {
GroupLayer groupLayer = (GroupLayer) remove;
for (Layer gl : groupLayer.layers) {
if (gl instanceof UpdateListener)
mMap.events.unbind((UpdateListener) gl);
if (gl instanceof InputListener)
mMap.input.unbind((InputListener) gl);
}
}
return remove; return remove;
} }
@ -94,6 +119,17 @@ public final class Layers extends AbstractList<Layer> {
if (remove instanceof InputListener) if (remove instanceof InputListener)
mMap.input.unbind((InputListener) remove); mMap.input.unbind((InputListener) remove);
// unbind replaced group layer
if (remove instanceof GroupLayer) {
GroupLayer groupLayer = (GroupLayer) remove;
for (Layer gl : groupLayer.layers) {
if (gl instanceof UpdateListener)
mMap.events.unbind((UpdateListener) gl);
if (gl instanceof InputListener)
mMap.input.unbind((InputListener) gl);
}
}
return remove; return remove;
} }
@ -121,11 +157,21 @@ public final class Layers extends AbstractList<Layer> {
if (mDirtyLayers) if (mDirtyLayers)
updateLayers(); updateLayers();
for (Layer o : mLayers) for (Layer o : mLayers) {
if (o instanceof GestureListener) if (o instanceof GestureListener)
if (((GestureListener) o).onGesture(g, e)) if (((GestureListener) o).onGesture(g, e))
return true; return true;
if (o instanceof GroupLayer) {
GroupLayer groupLayer = (GroupLayer) o;
for (Layer gl : groupLayer.layers) {
if (gl instanceof GestureListener)
if (((GestureListener) gl).onGesture(g, e))
return true;
}
}
}
return false; return false;
} }
@ -139,6 +185,14 @@ public final class Layers extends AbstractList<Layer> {
if (o.getRenderer() != null) if (o.getRenderer() != null)
numRenderLayers++; numRenderLayers++;
if (o instanceof GroupLayer) {
GroupLayer groupLayer = (GroupLayer) o;
for (Layer gl : groupLayer.layers) {
if (gl.getRenderer() != null)
numRenderLayers++;
}
}
mLayers[n - i - 1] = o; mLayers[n - i - 1] = o;
} }
@ -149,6 +203,15 @@ public final class Layers extends AbstractList<Layer> {
LayerRenderer l = o.getRenderer(); LayerRenderer l = o.getRenderer();
if (l != null) if (l != null)
mLayerRenderer[cnt++] = l; mLayerRenderer[cnt++] = l;
if (o instanceof GroupLayer) {
GroupLayer groupLayer = (GroupLayer) o;
for (Layer gl : groupLayer.layers) {
l = gl.getRenderer();
if (l != null)
mLayerRenderer[cnt++] = l;
}
}
} }
mDirtyLayers = false; mDirtyLayers = false;