[英]OSMDroid/OSMBonusPack adding marker with info bubble on marker click
[英]How to change the marker bubble using OSMDROID/OSMBonusPack
我正在嘗試用 OSM 地圖替換我的應用程序中的谷歌地圖。 我一直在嘗試使用這種按照自己如何安裝和使用進口的Jitpack項目。 它工作正常。 點擊標記默認信息氣泡(一些淺灰色的)顯示。 如果我想修改標記氣泡的背景,我該怎么做? 我的代碼中沒有使用任何類型的 onClick 方法
import android.app.Fragment;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import org.osmdroid.api.IMapController;
import org.osmdroid.tileprovider.tilesource.TileSourceFactory;
import org.osmdroid.util.GeoPoint;
import org.osmdroid.views.MapView;
import org.osmdroid.views.overlay.Marker;
import org.osmdroid.views.overlay.ScaleBarOverlay;
import java.util.ArrayList;
import java.util.List;
import demo.exe.exe.R;
import demo.exe.exe.model.Education.EducationServiceProviderItem;
import demo.exe.exe.utils.AppConstants;
public class MapFragmentOSM extends Fragment implements View.OnClickListener {
private ArrayList<EducationServiceProviderItem> educationServiceProvider=null;
MapView mapView;
int subcategotyId;
View rootView;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
double latDouble,longDouble;
int i=0;
super.onCreate(savedInstanceState);
rootView = inflater.inflate(R.layout.fragment_map, container,
false);
mapView = (MapView) rootView.findViewById(R.id.mapview);
mapView.setClickable(true);
mapView.setBuiltInZoomControls(true);
mapView.setMultiTouchControls(true);
mapView.setUseDataConnection(true);
;
mapView.setTileSource(TileSourceFactory.MAPQUESTOSM);
IMapController mapViewController = mapView.getController();
if(locationNameId==1) {
mapViewController.setZoom(18);
mapViewController.setCenter(AppConstants.BAUNIA1);
}
else if(locationNameId==2)
{
mapViewController.setZoom(17);
mapViewController.setCenter(AppConstants.PARIS1);
}
switch (categoryId)
{
case AppConstants.EDUCATION:
if(educationServiceProvider!=null) {
for (EducationServiceProviderItem et : educationServiceProvider) {
// LatLng location = new LatLng(Double.parseDouble(et.getLatitude()), Double.parseDouble(et.getLongitude()));
subcategotyId = et.getEduSubCategoryId();
latDouble=Double.parseDouble(et.getLatitude());
longDouble=Double.parseDouble(et.getLongitude());
GeoPoint point= new GeoPoint(latDouble,longDouble);
drawMarkerEdu(point, et.getEduNameEng(),et.getAddress(), et.getEduSubCategoryId());
}
}
break;
default:
break;
}
//Add Scale Bar
ScaleBarOverlay myScaleBarOverlay = new ScaleBarOverlay(mapView);
mapView.getOverlays().add(myScaleBarOverlay);
return rootView;
}
private void drawMarkerEdu(GeoPoint point,String title,String address,int subcategotyId) {
Marker marker = new Marker(mapView);
marker.setPosition(point);
marker.setAnchor(Marker.ANCHOR_CENTER, Marker.ANCHOR_BOTTOM);
if (subcategotyId >= 1 && subcategotyId <= 12)
marker.setIcon(this.getResources().getDrawable(R.drawable.pin_feroza));
else if (subcategotyId >= 13 && subcategotyId <= 17)
marker.setIcon(this.getResources().getDrawable(R.drawable.pin_blue));
else if (subcategotyId >= 18 && subcategotyId <= 19)
marker.setIcon(this.getResources().getDrawable(R.drawable.pin_pink));
else if (subcategotyId >= 20 && subcategotyId <= 21)
marker.setIcon(this.getResources().getDrawable(R.drawable.pin_green));
else if (subcategotyId >= 22 && subcategotyId <= 26)
marker.setIcon(this.getResources().getDrawable(R.drawable.pin_yellow));
marker.setSnippet(title);
marker.setSubDescription(address);
mapView.getOverlays().add(marker);
}
@Override
public void onClick(View v) {
}
}
任何建議將不勝感激!
本教程准確顯示了您想要的內容。 基本上,您可以覆蓋 InfoWindow 類並為其提供您自己的布局。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.