最終更新:
moonlight_aska 2013年09月29日(日) 15:50:34履歴
Googleマップ上のマーカーをタップすると, インフォウィンドウ(Info Window)が表示される. このインフォウィンドウをタッチしたイベントを取得するには, GoogleMap.OnInfoWindowClickListenerインタフェースを利用する.
「Googleマップを表示する」を参照し, Googleマップが表示できるようにする.
- MainActivity.java
- Googleマップのインスタンスを取得する.
- GoogleMap#setOnInfoWindowClickListenerメソッドで, クリック時のイベントハンドラを登録する.
- onInfoWindowClickメソッドに, クリック時の処理を実装する.
package com.moonlight_aska.android.googlemapv2;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.GoogleMap.OnInfoWindowClickListener;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.CameraPosition;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.Marker;
import com.google.android.gms.maps.model.MarkerOptions;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.widget.Toast;
public class MainActivity extends FragmentActivity {
// 六甲山:北緯34度46分41秒, 東経135度15分49秒
private double mLatitude = 34.0d + 46.0d/60 + 41.0d/(60*60);
private double mLongitude = 135.0d + 15.0d/60 + 49.0d/(60*60);
private GoogleMap mMap = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mMap = ( (SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map) ).getMap();
if (mMap != null) {
LatLng location = new LatLng(mLatitude, mLongitude);
CameraPosition cameraPos = new CameraPosition.Builder()
.target(location).zoom(12.0f)
.build();
mMap.animateCamera(CameraUpdateFactory.newCameraPosition(cameraPos));
// マーカー表示
MarkerOptions options = new MarkerOptions();
options.position(location);
options.title("六甲山");
mMap.addMarker(options);
mMap.setOnInfoWindowClickListener(new OnInfoWindowClickListener() {
@Override
public void onInfoWindowClick(Marker marker) {
// TODO Auto-generated method stub
Toast.makeText(getApplicationContext(), "インフォウィンドウクリック", Toast.LENGTH_LONG).show();
}
});
}
}
}
- 動作例

コメントをかく