gpt4 book ai didi

android - 如何使多个图标叠加仅在 Google Maps MapView 上的某个缩放级别后出现?

转载 作者:行者123 更新时间:2023-11-30 04:07:57 29 4
gpt4 key购买 nike

在使用 Maps API 方面,我是初学者,所以请多多包涵,我知道还有许多其他帖子处理相同的问题,但我仍然卡住了。

  • 我已经能够将一些叠加图像放置到我的 map 上。我现在遇到的唯一问题是,当我缩小足够多的级别时,我不知道如何让它们消失,因为这会导致叠加图像挤在一起并重叠——基本上使它们在该级别上无用。因此,对于如何使它们出现(在缩放级别 18 之后)的任何帮助,我们将不胜感激。

  • 我已经尝试使用缩放监听器和 if 语句,但它没有任何变化 - 很可能是因为我不知道我到底需要在哪里实现它和/或需要哪些其他方法来启用它。此外,我不确定如何实现 draw() 方法,因为许多其他人已经使用它来使其缩放和消失。

编辑:

这是我目前成功执行的两个类(应用答案后):

Map.java 文件:

public class Map extends com.google.android.maps.MapActivity implements
OnOverlayGestureListener {

private boolean mShowOverlays = true;
private MapView mMapView;
MapView mapView;
MapController mapController;

private void setOverlayVisibility() {
boolean showOverlays = mMapView.getZoomLevel() > 18;
if (showOverlays != mShowOverlays) {
mShowOverlays = showOverlays;
for (Overlay overlay : mMapView.getOverlays()) {
if (overlay instanceof ItemOverlay) {
((ItemOverlay) overlay).setVisible(showOverlays);
}
}
}

}

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

mapView = (MapView) findViewById(R.id.mapview);
mapView.setBuiltInZoomControls(true);
mapController = mapView.getController();
mapController.setZoom(17);

boolean showOverlays = mMapView.getZoomLevel() > 18;

List<Overlay> mapOverlays = mapView.getOverlays();
Drawable lot = this.getResources().getDrawable(R.drawable.lot);
ItemOverlay parking_lot = new ItemOverlay(lot, this);
GeoPoint point1 = new GeoPoint(43806622, -79219797);
OverlayItem parking = new OverlayItem(point1, "Shopping Center","Parking Lot");

parking_lot.addOverlayItems(parking);
mapOverlays.add(parking_lot);

Drawable logo = this.getResources().getDrawable(R.drawable.entrance);
ItemOverlay ent = new ItemOverlay(logo, this);
GeoPoint start = new GeoPoint(43805697, -79221031);
mapController.setCenter(start);
OverlayItem welcome = new OverlayItem(start, "Welcome", " ");

ent.addOverlayItems(welcome);
mapOverlays.add(ent);

public <ZoomEvent> boolean onZoom(ZoomEvent ze, ManagedOverlay mo) {
setOverlayVisibility();
return true;
}

}

@Override
protected boolean isRouteDisplayed() {
// TODO Auto-generated method stub
return false;
}

}

ItemOverlay.java 文件:

public class ItemOverlay extends ItemizedOverlay<OverlayItem> {
private ArrayList<OverlayItem> mOverlays = new ArrayList<OverlayItem>();
private Context mContext;
private boolean visible = true;

private boolean mVisible = true;

public void setVisible(boolean value) {
mVisible = value;
}
public boolean isVisible() {
return mVisible ;
}

@Override
public void draw(android.graphics.Canvas canvas, MapView mapView, boolean shadow) {
if (mVisible) {
super.draw(canvas, mapView, shadow);
}
}

public ItemOverlay(Drawable defaultMarker, Context context) {
super(boundCenterBottom(defaultMarker));
// TODO Auto-generated constructor stub
mContext = context;
}

public void addOverlayItems(OverlayItem overlay) {
mOverlays.add(overlay);
populate();
}

@Override
protected OverlayItem createItem(int i) {
// TODO Auto-generated method stub
return mOverlays.get(i);

}

@Override
public int size() {
// TODO Auto-generated method stub
return mOverlays.size();
}

@Override
protected boolean onTap(int index) {
// TODO Auto-generated method stub
OverlayItem item = mOverlays.get(index);
AlertDialog.Builder dialog = new AlertDialog.Builder(mContext);
dialog.setTitle(item.getTitle());
dialog.setMessage(item.getSnippet());
dialog.show();
return true;
}

}

最佳答案

我非常喜欢使用适用于 Android 的 OverlayManager 库。它为 Google map 代码添加了功能,并使一些事情变得容易得多。 Find it here包括 some demo code that uses it

选项#1:如果您使用此选项,则可以为您的 MapActivity 使用 OverlayManager 的手势监听器接口(interface),以接收每个缩放(放大/缩小)事件的回调。

public class Map extends MapActivity implements OnOverlayGestureListener 
{
private boolean mShowOverlays = true;
private MapView mMapView; // assign this in onCreate()

private void setOverlayVisibility() {
boolean showOverlays = mMapView.getZoomLevel() >= 18;
if (showOverlays != mShowOverlays) {
mShowOverlays = showOverlays;
for (Overlay overlay : mMapView.getOverlays()) {
if (overlay instanceof ItemOverlay) {
((ItemOverlay)overlay).setVisible(showOverlays);
}
}
}
}

// this is the onOverlayGestureListener callback:
public boolean onZoom(ZoomEvent ze, ManagedOverlay mo) {
setOverlayVisibility();
return true;
}
}

您还必须使用 ManagedOverlay.setOnOverlayGestureListener() 添加您的 Map 实例作为手势监听器。请参阅示例代码。

最后,在您的 ItemOverlay 类中,您可以覆盖 draw() 方法,并根据叠加层是否已标记为可见有选择地进行绘制。您需要添加自定义 visible 属性:

public class ItemOverlay extends ItemizedOverlay {

private boolean mVisible = true;

public void setVisible(boolean value) {
mVisible = value;
}
public boolean isVisible() {
return mVisible ;
}

@Override
public void draw(android.graphics.Canvas canvas, MapView mapView, boolean shadow) {
if (mVisible) {
super.draw(canvas, mapView, shadow);
}
}
}

选项#2:现在,仅仅为了这个目的使用 Overlay Manager 库可能有点矫枉过正。因此,另一种可能更简单的替代方法是以 described in this stack overflow answer 的方式创建一个缩放监听器 . Kurru 提供的代码将放在您的 Map 类中。您将在答案的代码中替换它:

checkMapIcons();

用我上面展示的方法:

setOverlayVisibility();

因此,现在您有两种方法来“观察”缩放级别,并且重写 ItemOverlay.draw() 允许您随时让标记消失(在此示例中缩放级别 < 18 ).

关于android - 如何使多个图标叠加仅在 Google Maps MapView 上的某个缩放级别后出现?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11321445/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com