1

マップビューをズームアウトしたときにアイコンが海の上に表示される理由を理解しようとしていますが、ズームインしたときにポイントが正しいのです。

これが私のコードです:

@Override
public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    setContentView(R.layout.main);

    mapView = (MapView) findViewById(R.id.mapview1);
    mapView.setBuiltInZoomControls(true);
    MapController mapController = mapView.getController();

    //set up test points
    point = new GeoPoint(25982160, -80358564);
    showAnimatedMarker(point, "true");  
    point = new GeoPoint(34023084, -84781697);
    showAnimatedMarker(point, "Test");
    point = new GeoPoint(40759508, -73987061);
    showAnimatedMarker(point, "Yo YO YO");
    point = new GeoPoint(34152852, -118336107);
    showAnimatedMarker(point, "Boom shakalaka");
    point = new GeoPoint(-23564595, -46652759);
    showAnimatedMarker(point, "Testing having a real long name");

    mapController.setZoom(4);
    mapController.animateTo(point);
}

public void showAnimatedMarker(GeoPoint point, String locationName)
{
    //animate the marker
    RelativeLayout v = (RelativeLayout) View.inflate(this, R.layout.markerlayout, null);
    final ImageView marker = (ImageView) v.findViewById(R.id.marker);
    final TextView markerText = (TextView) v.findViewById(R.id.markerText);
    final String locName = locationName;
    marker.post(new Runnable() {
        @Override
        public void run() {
            markerText.setText(locName);
            AnimationDrawable markerImage = (AnimationDrawable)marker.getDrawable();            
            markerImage.start();
        }
    });
    mapView.addView(v, 0, new MapView.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT, point, MapView.LayoutParams.BOTTOM_CENTER));

}

これが私の言いたいことを示す2枚の写真です。1枚はズームアウトされ、1枚はカリフォルニアの場所にズームインされています。

どんな助けでも大歓迎です。

拡大画像

ズームアウトした画像

編集:

これが私の更新されたコードです(Frohnzieが投稿したものとまったく同じであるため、myOverlaysクラスは含めませんでした)

    MapController mapController = mapView.getController();
    MyOverlay testOverlay;

     //set up test points
    point = new GeoPoint(25982160, -80358564);
    //showAnimatedMarker(point, "true");
    testOverlay = new MyOverlay(this,  mapView, point);
    mapOverlays.add(testOverlay);       

    point = new GeoPoint(34023084, -84781697);
    //showAnimatedMarker(point, "Test");
    testOverlay = new MyOverlay(this,  mapView, point);
    mapOverlays.add(testOverlay);   

    point = new GeoPoint(40759508, -73987061);
    //showAnimatedMarker(point, "Yo YO YO");
    testOverlay = new MyOverlay(this,  mapView, point);
    mapOverlays.add(testOverlay);   

    point = new GeoPoint(34152852, -118336107);
    //showAnimatedMarker(point, "Boom shakalaka");
    testOverlay = new MyOverlay(this,  mapView, point);
    mapOverlays.add(testOverlay);   

    point = new GeoPoint(-23564595, -46652759);
    //showAnimatedMarker(point, "Testing having a real long name");
    testOverlay = new MyOverlay(this,  mapView, point);
    mapOverlays.add(testOverlay);   

    mapController.setZoom(4);
    mapController.animateTo(point);
    mapView.invalidate();
}
4

1 に答える 1

2

過度の機能の使用を検討しましたか?次のオーバーレイは、マップ上のマーカーをアニメーション化します。複数のマーカーの場合、extendOverlayItemを使用できます。

public class MyOverlay extends Overlay {
  private Drawable mMarker;
  private MapView mMapView;
  private int level;
  private Timer timer;
  Private GeoPoint mGeoPoint;

  public MyOverlay(Context context, MapView mapView, GeoPoint geoPoint) {
    mMapView = mapView;
    mGeoPoint = geoPoint;
    mMarker = context.getResources().getDrawable(R.drawable.position_anim);
    timer = new Timer();
    timer.schedule(new TimerTask() {
      @Override
      public void run() {
        level = (level + 1) % 2;
        mMapView.postInvalidate();
      }
    }, 1000, 1000);
  }

  @Override
  public void draw(Canvas canvas, MapView mapView, boolean shadow) {
    Projection projection = mapView.getProjection();
    Point center = new Point();
    projection.toPixels(mGeoPoint, center);

    int width = mMarker.getIntrinsicWidth();
    int height = mMarker.getIntrinsicHeight();

    mMarker.setLevel(level);
    mMarker.setBounds(center.x - width / 2, center.y - height / 2, center.x + width / 2, center.y + height / 2);
    mMarker.draw(canvas);
  }
}

マーカーリソースの例(position_anim.xml):

<level-list xmlns:android="http://schemas.android.com/apk/res/android" >
  <item android:maxLevel="0" android:drawable="@drawable/image1" />
  <item android:maxLevel="1" android:drawable="@drawable/image2" />
</level-list>
于 2012-07-31T14:42:15.103 に答える