Как использовать MOBAC, созданный OSMDroid SQLite исходный файл плитки в автономном режиме?
Я старался изо всех сил пытаться получить собственную автономную карту Mobile Atlas Creator OSMDroid SQLite, работающую с OSMDroid 3.0.8, но безуспешно. Это'Это были долгие 3 дня. Я'Попробую объяснить с помощью клипов из моего приложения. Я'я расширяю ItemizedIconOverlay и OverlayItem, так что я надеюсь, что это не такСлишком запутанно.
Я создал свой собственный файл карты OSMDroid SQLite с 3 различными уровнями масштабирования для небольшого размера, например, 10 квадратных километров. Я скопировал полученноеbase.sqlite» файл в мой проект / res / raw / каталог. Обратите внимание, что GeoPoints в моем приложении должны находиться в пределах карты.с ассортиментом плитки. "base.sqlite» файл должен быть сохранен в каталоге данных конкретного приложения.
Затем я перевернул каталог / osmdroid на своем телефоне, чтобы я мог удалить ранее кэшированные карты. Я думал, что у меня были свои автономные карты, работающие до тех пор, пока я не включил режим полета и заметил, что кэшированные карты все еще были доступны.
Теперь все, что я получаю, это бланки. Я понятия не имею, как это сделать. Я'Я вижу пару примеров, но после тонны экспериментов у меня нетне удалось заставить кого-либо из них работать.
private Hashtable nodes = new Hashtable();
private MapView mapView;
private Context context;
private LocationManager locManager;
private MapController mapController;
private MapTileProviderArray mapProvider;
private String mapTileArchivePath = "base.sqlite";
private ResourceProxy resourceProxy;
@Override
public void onCreate(final Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
try {
this.mapView = new MapView(this, 256);
this.mapView.setBuiltInZoomControls(true);
this.mapView.setMultiTouchControls(true);
this.context = this.getApplicationContext();
this.resourceProxy = new DefaultResourceProxyImpl(context);
XYTileSource TILERENDERER = new XYTileSource("test",
ResourceProxy.string.offline_mode,
1, 20, 256, ".png", "http://127.0.0.1");
SimpleRegisterReceiver simpleReceiver = new SimpleRegisterReceiver(this.context);
IArchiveFile[] archives = { ArchiveFileFactory.getArchiveFile(this.getMapsFile()) };
MapTileModuleProviderBase moduleProvider = new MapTileFileArchiveProvider(
simpleReceiver,
TILERENDERER,
archives);
this.mapProvider = new MapTileProviderArray(TILERENDERER, null, new MapTileModuleProviderBase[] { moduleProvider });
this.mapProvider.setUseDataConnection(false);
this.mapView = new MapView(this, 256, this.resourceProxy, this.mapProvider);
this.mapView.setUseDataConnection(false);
mapController = mapView.getController();
mapController.setZoom(18);
mapController.setCenter(new GeoPoint((int)(45.349622 * 1E6), (int)(-75.880700 *1E6)));
this.setContentView(mapView);
} catch(Exception ex) {
Log.e("test", ex.getMessage());
}
}
public File getMapsFile() throws IOException {
Log.d("test", "Trying to load map tiles to: " + this.mapTileArchivePath);
FileOutputStream fos = this.openFileOutput(this.mapTileArchivePath, Context.MODE_PRIVATE);
InputStream in = getResources().openRawResource(R.raw.osmdroid);
byte[] buff = new byte[1024];
int read = 0;
try {
while ((read = in.read(buff)) > 0) {
fos.write(buff, 0, read);
}
} finally {
in.close();
fos.close();
}
return new File(this.getFilesDir(), this.mapTileArchivePath);
}