android mapview自定义互动程序



我需要在我的地图视图中添加一个自定义的基本层。我的理解是,地图瓷砖与谷歌瓷砖完全相同。它们是以以下格式提供的静态文件:http:///tilecache///.png

例如http:///tilecache/6/16/26.png是佛罗里达州-阿拉巴马州和密西西比州之间的海湾海岸。

如何使用瓷砖创建覆盖?

osmdroid(如上所述)很酷,但相当巨大。不久前我决定使用http://sourceforge.net/projects/libwlocate/相反,它包含显示/滚动/缩放地图的功能,如osmdroid,但您可以选择使用OSM、谷歌地图或谷歌卫星视图。

可以在中找到如何使用它的示例http://libwlocate.git.sourceforge.net/git/gitweb.cgi?p=libwlocate/libwlocate;a=斑点;f=master/android/LocDemo/src/com/vwp/LocDemo/LocDemo.java;h=5e2134fb7d197258f5f4f6f9021d2fa9ad9f2d9a;hb=头

我建议使用osmdroid。您可以扩展OnlineTileSourecBase。

public class YourTileSource extends OnlineTileSourceBase implements IStyledTileSource<Integer> {
public YourTileSource (String aName, string aResourceId,
    int aZoomMinLevel, int aZoomMaxLevel, int aTileSizePixels,
    String aImageFilenameEnding, String aBaseUrl) {
    super(aName, aResourceId, aZoomMinLevel, aZoomMaxLevel, aTileSizePixels,
            aImageFilenameEnding, aBaseUrl);
}
public void setStyle(Integer style) {
    // TODO Auto-generated method stub
}
public void setStyle(String style) {
    // TODO Auto-generated method stub
}
public Integer getStyle() {
    // TODO Auto-generated method stub
    return null;
}
@Override
public String getTileURLString(MapTile aTile) {
    return getBaseUrl() + "/" + aTile.getX() + "/" + aTile.getY() + "/" + aTile.getZoomLevel() + ".png";
}

}

然后将您的互动程序源添加到地图视图中:

TileSourceFactory.addTileSource(new YourTileSource ("YourTileSource", null, 1, 20, 256, ".png", "http:///tilecache/"));
mapView.setTileSource(TileSourceFactory.getTileSource("YourTileSource"));

您的mapView需要是org.osmdroid.views.mapView才能工作。OSMdroid类应该取代所有的谷歌地图类。

首先下载osmdroid-android-3.0.8.jar文件,将其添加到项目中的libs文件夹中,然后右键单击>属性>Java构建路径>库>添加Jars将其添加至项目,然后在libs文件夹中将其找到。如果你有更多的问题,我对osmdroid有很多经验。

对于OSMDroid的较新版本,构造函数的aResourceId参数已被删除,最后一个参数aBaseUrlString[]

public YourTileSource (String aName, 
    int aZoomMinLevel, 
    int aZoomMaxLevel, 
    int aTileSizePixels,
    String aImageFilenameEnding, 
    String[] aBaseUrl) {
    super(aName, 
          aZoomMinLevel, 
          aZoomMaxLevel, 
          aTileSizePixels, 
          aImageFilenameEnding, 
          aBaseUrl);
}

最新更新