bring back TestTileSource
This commit is contained in:
parent
eb05c29495
commit
dea77fbd5b
@ -22,173 +22,177 @@ import org.oscim.layers.tile.MapTile;
|
||||
import org.oscim.tilesource.ITileDataSink;
|
||||
import org.oscim.tilesource.ITileDataSource;
|
||||
import org.oscim.tilesource.MapInfo;
|
||||
import org.oscim.tilesource.TileSource;
|
||||
|
||||
/**
|
||||
*
|
||||
*
|
||||
*/
|
||||
public class TestTileSource implements ITileDataSource {
|
||||
|
||||
private final Tag[] mTags = {
|
||||
new Tag("natural", "water")
|
||||
};
|
||||
private final Tag[] mTagsWay = {
|
||||
new Tag("highway", "primary"),
|
||||
new Tag("name", "Highway Rd")
|
||||
};
|
||||
private final Tag[] mTagsBoundary = {
|
||||
new Tag("boundary", "administrative"),
|
||||
new Tag("admin_level", "2")
|
||||
};
|
||||
private final Tag[] mTagsPlace = {
|
||||
new Tag("place", "city"),
|
||||
null
|
||||
};
|
||||
public class TestTileSource extends TileSource {
|
||||
|
||||
private final MapInfo mMapInfo =
|
||||
new MapInfo(new BoundingBox(-180, -90, 180, 90),
|
||||
new Byte((byte) 5), null, null, 0, 0, 0,
|
||||
"", "", "", null);
|
||||
new MapInfo(new BoundingBox(-180, -90, 180, 90),
|
||||
new Byte((byte) 5), null, null, 0, 0, 0,
|
||||
"", "", "", null);
|
||||
|
||||
private final boolean mOpenFile = false;
|
||||
|
||||
private final MapElement mElem;
|
||||
|
||||
public TestTileSource() {
|
||||
mElem = new MapElement();
|
||||
}
|
||||
|
||||
private final boolean renderWays = false;
|
||||
private final boolean renderBoundary = false;
|
||||
private final boolean renderPlace = false;
|
||||
// private boolean mOpenFile = false;
|
||||
|
||||
@Override
|
||||
public QueryResult executeQuery(MapTile tile,
|
||||
ITileDataSink mapDataSink) {
|
||||
public ITileDataSource getDataSource() {
|
||||
return new TileDataSource();
|
||||
}
|
||||
|
||||
int size = Tile.SIZE;
|
||||
MapElement e = mElem;
|
||||
@Override
|
||||
public OpenResult open() {
|
||||
// mOpenFile =true;
|
||||
return OpenResult.SUCCESS;
|
||||
}
|
||||
|
||||
float x1 = -1;
|
||||
float y1 = -1;
|
||||
float x2 = size + 1;
|
||||
float y2 = size + 1;
|
||||
@Override
|
||||
public void close() {
|
||||
// mOpenFile = false;
|
||||
}
|
||||
|
||||
// always clear geometry before starting
|
||||
// a different type.
|
||||
e.clear();
|
||||
e.startPolygon();
|
||||
e.addPoint(x1, y1);
|
||||
e.addPoint(x2, y1);
|
||||
e.addPoint(x2, y2);
|
||||
e.addPoint(x1, y2);
|
||||
@Override
|
||||
public MapInfo getMapInfo() {
|
||||
return mMapInfo;
|
||||
}
|
||||
|
||||
y1 = 5;
|
||||
y2 = size - 5;
|
||||
x1 = 5;
|
||||
x2 = size - 5;
|
||||
static class TileDataSource implements ITileDataSource {
|
||||
|
||||
e.startHole();
|
||||
e.addPoint(x1, y1);
|
||||
e.addPoint(x2, y1);
|
||||
e.addPoint(x2, y2);
|
||||
e.addPoint(x1, y2);
|
||||
private static final Tag[] mTags = {
|
||||
new Tag("natural", "water")
|
||||
};
|
||||
private static final Tag[] mTagsWay = {
|
||||
new Tag("highway", "primary"),
|
||||
new Tag("name", "Highway Rd")
|
||||
};
|
||||
private static final Tag[] mTagsBoundary = {
|
||||
new Tag("boundary", "administrative"),
|
||||
new Tag("admin_level", "2")
|
||||
};
|
||||
|
||||
//// FIXME e.setLayer(mTags, 0);
|
||||
mapDataSink.process(e);
|
||||
private static final Tag[] mTagsPlace = {
|
||||
new Tag("place", "city"),
|
||||
null
|
||||
};
|
||||
|
||||
if (renderWays) {
|
||||
e.clear();
|
||||
private final MapElement mElem;
|
||||
|
||||
// middle horizontal
|
||||
e.startLine();
|
||||
e.addPoint(0, size / 2);
|
||||
e.addPoint(size, size / 2);
|
||||
|
||||
// center up
|
||||
e.startLine();
|
||||
e.addPoint(size / 2, -size / 2);
|
||||
e.addPoint(size / 2, size / 2);
|
||||
|
||||
// center down
|
||||
e.startLine();
|
||||
e.addPoint(size / 2, size / 2);
|
||||
e.addPoint(size / 2, size / 2 + size);
|
||||
|
||||
////e.setLayer(mTagsWay, 0);
|
||||
mapDataSink.process(e);
|
||||
|
||||
e.clear();
|
||||
// left-top to center
|
||||
e.startLine();
|
||||
e.addPoint(size / 2, size / 2);
|
||||
e.addPoint(10, 10);
|
||||
|
||||
e.startLine();
|
||||
e.addPoint(0, 10);
|
||||
e.addPoint(size, 10);
|
||||
|
||||
e.startLine();
|
||||
e.addPoint(10, 0);
|
||||
e.addPoint(10, size);
|
||||
|
||||
//// --e.setLayer(mTagsWay, 1);
|
||||
mapDataSink.process(e);
|
||||
public TileDataSource() {
|
||||
mElem = new MapElement();
|
||||
}
|
||||
|
||||
if (renderBoundary) {
|
||||
private final boolean renderWays = true;
|
||||
private final boolean renderBoundary = false;
|
||||
private final boolean renderPlace = false;
|
||||
|
||||
@Override
|
||||
public QueryResult executeQuery(MapTile tile,
|
||||
ITileDataSink mapDataSink) {
|
||||
|
||||
int size = Tile.SIZE;
|
||||
MapElement e = mElem;
|
||||
|
||||
float x1 = -1;
|
||||
float y1 = -1;
|
||||
float x2 = size + 1;
|
||||
float y2 = size + 1;
|
||||
|
||||
// always clear geometry before starting
|
||||
// a different type.
|
||||
e.clear();
|
||||
e.startPolygon();
|
||||
float r = size / 2;
|
||||
e.addPoint(x1, y1);
|
||||
e.addPoint(x2, y1);
|
||||
e.addPoint(x2, y2);
|
||||
e.addPoint(x1, y2);
|
||||
|
||||
for (int i = 0; i < 360; i += 4) {
|
||||
double d = Math.toRadians(i);
|
||||
e.addPoint(r + (float) Math.cos(d) * (r - 40),
|
||||
r + (float) Math.sin(d) * (r - 40));
|
||||
y1 = 5;
|
||||
y2 = size - 5;
|
||||
x1 = 5;
|
||||
x2 = size - 5;
|
||||
|
||||
e.startHole();
|
||||
e.addPoint(x1, y1);
|
||||
e.addPoint(x2, y1);
|
||||
e.addPoint(x2, y2);
|
||||
e.addPoint(x1, y2);
|
||||
|
||||
e.setLayer(0);
|
||||
e.tags.set(mTags);
|
||||
mapDataSink.process(e);
|
||||
|
||||
if (renderWays) {
|
||||
e.clear();
|
||||
|
||||
// middle horizontal
|
||||
e.startLine();
|
||||
e.addPoint(0, size / 2);
|
||||
e.addPoint(size, size / 2);
|
||||
|
||||
// center up
|
||||
e.startLine();
|
||||
e.addPoint(size / 2, -size / 2);
|
||||
e.addPoint(size / 2, size / 2);
|
||||
|
||||
// center down
|
||||
e.startLine();
|
||||
e.addPoint(size / 2, size / 2);
|
||||
e.addPoint(size / 2, size / 2 + size);
|
||||
|
||||
// //e.setLayer(mTagsWay, 0);
|
||||
mapDataSink.process(e);
|
||||
|
||||
e.clear();
|
||||
// left-top to center
|
||||
e.startLine();
|
||||
e.addPoint(size / 2, size / 2);
|
||||
e.addPoint(10, 10);
|
||||
|
||||
e.startLine();
|
||||
e.addPoint(0, 10);
|
||||
e.addPoint(size, 10);
|
||||
|
||||
e.startLine();
|
||||
e.addPoint(10, 0);
|
||||
e.addPoint(10, size);
|
||||
|
||||
e.setLayer(1);
|
||||
e.tags.set(mTagsWay);
|
||||
mapDataSink.process(e);
|
||||
}
|
||||
|
||||
//// e.setLayer(mTagsBoundary, 1);
|
||||
mapDataSink.process(e);
|
||||
if (renderBoundary) {
|
||||
e.clear();
|
||||
e.startPolygon();
|
||||
float r = size / 2;
|
||||
|
||||
for (int i = 0; i < 360; i += 4) {
|
||||
double d = Math.toRadians(i);
|
||||
e.addPoint(r + (float) Math.cos(d) * (r - 40),
|
||||
r + (float) Math.sin(d) * (r - 40));
|
||||
}
|
||||
|
||||
e.setLayer(1);
|
||||
e.tags.set(mTagsWay);
|
||||
mapDataSink.process(e);
|
||||
}
|
||||
|
||||
if (renderPlace) {
|
||||
e.clear();
|
||||
e.startPoints();
|
||||
e.addPoint(size / 2, size / 2);
|
||||
|
||||
mTagsPlace[1] = new Tag("name", tile.toString());
|
||||
e.tags.set(mTagsPlace);
|
||||
mapDataSink.process(e);
|
||||
}
|
||||
|
||||
mapDataSink.completed(true);
|
||||
|
||||
return QueryResult.SUCCESS;
|
||||
}
|
||||
|
||||
if (renderPlace) {
|
||||
e.clear();
|
||||
e.startPoints();
|
||||
e.addPoint(size / 2, size / 2);
|
||||
|
||||
mTagsPlace[1] = new Tag("name", tile.toString());
|
||||
//// e.setLayer(mTagsPlace, 0);
|
||||
mapDataSink.process(e);
|
||||
@Override
|
||||
public void destroy() {
|
||||
}
|
||||
return QueryResult.SUCCESS;
|
||||
}
|
||||
|
||||
|
||||
// @Override
|
||||
// public boolean isOpen() {
|
||||
// return mOpenFile;
|
||||
// }
|
||||
//
|
||||
// @Override
|
||||
// public OpenResult open(MapOptions options) {
|
||||
// mOpenFile = true;
|
||||
// return OpenResult.SUCCESS;
|
||||
// }
|
||||
//
|
||||
// @Override
|
||||
// public void close() {
|
||||
// mOpenFile = false;
|
||||
// }
|
||||
//
|
||||
// @Override
|
||||
// public void cancel() {
|
||||
// }
|
||||
|
||||
|
||||
@Override
|
||||
public void destroy() {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user