如何在Android上通过新的Google Maps API v2显示Google地图?

BBo*_*Doo 2 android google-maps google-maps-api-2 android-mapview

新版Google Maps API v2刚刚发布,与之前的Google Maps API v1不同.

如何使用新API显示Google地图?

BBo*_*Doo 10

如您所知,2012年12月发布的新版Google Maps API v2.

因此,在Android上显示谷歌地图的方法与过去(Google Maps API v1)的方法有很大不同.但是很多人不太可能从现在开始意识到这种差异.

首先,需要提前设置Google服务库,支持库和有效的API密钥.如果您不知道如何操作,请仔细阅读这两个文件:一个两个.

其次,显示普通Google Map的代码也不同于过去已知的MapView(Google Maps API v1).

我将以自我回答的形式向新Android开发人员介绍第二个问题,如下所示;

1.在(支持)片段中显示普通的Google Map.

main.xml ...

请注意"class ="com.google.android.gms.maps .SupportMapFragment""是正确的.

旧版本使用"class ="com.google.android.maps .SupportMapFragment""

<?xml version="1.0" encoding="utf-8"?>
<!-- This can go anywhere in your layout (see other demos for some examples). -->
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/map"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  class="com.google.android.gms.maps.SupportMapFragment"/>
Run Code Online (Sandbox Code Playgroud)

MainActivity.java ....请注意,要在MainActivity中导入的所有类必须如下所示; 请检查导入的类是否包含com.google.android. .maps.xxxxxxx类型.

import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
import android.os.Bundle;

/**
 * This shows how to create a simple activity with a map and a marker on the map.
 * <p>
 * Notice how we deal with the possibility that the Google Play services APK is not
 * installed/enabled/updated on a user's device.
 */
public class BasicMapActivity extends android.support.v4.app.FragmentActivity {
    /**
     * Note that this may be null if the Google Play services APK is not available.
     */
    private GoogleMap mMap;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        setUpMapIfNeeded();
    }

    @Override
    protected void onResume() {
        super.onResume();
        setUpMapIfNeeded();
    }

    /**
     * Sets up the map if it is possible to do so (i.e., the Google Play services APK is correctly
     * installed) and the map has not already been instantiated.. This will ensure that we only ever
     * call {@link #setUpMap()} once when {@link #mMap} is not null.
     * <p>
     * If it isn't installed {@link SupportMapFragment} (and
     * {@link com.google.android.gms.maps.MapView
     * MapView}) will show a prompt for the user to install/update the Google Play services APK on
     * their device.
     * <p>
     * A user can return to this Activity after following the prompt and correctly
     * installing/updating/enabling the Google Play services. Since the Activity may not have been
     * completely destroyed during this process (it is likely that it would only be stopped or
     * paused), {@link #onCreate(Bundle)} may not be called again so we should call this method in
     * {@link #onResume()} to guarantee that it will be called.
     */
    private void setUpMapIfNeeded() {
        // Do a null check to confirm that we have not already instantiated the map.
        if (mMap == null) {
            // Try to obtain the map from the SupportMapFragment.
            mMap = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map))
                    .getMap();
            // Check if we were successful in obtaining the map.
            if (mMap != null) {
                setUpMap();
            }
        }
    }

    /**
     * This is where we can add markers or lines, add listeners or move the camera. In this case, we
     * just add a marker near Africa.
     * <p>
     * This should only be called once and when we are sure that {@link #mMap} is not null.
     */
    private void setUpMap() {
        mMap.addMarker(new MarkerOptions().position(new LatLng(0, 0)).title("Marker"));
    }
}
Run Code Online (Sandbox Code Playgroud)

2.在(支持)片段中显示MapView.

main.xml ....

请注意"class ="com.google.android.gms .maps.MapView ""是正确的.

旧版本使用"class ="com.google.android .maps.MapView ".

<?xml version="1.0" encoding="utf-8"?>
<!-- This can go anywhere in your layout. -->
<com.google.android.gms.maps.MapView xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/map"
  android:layout_width="match_parent"
  android:layout_height="match_parent"/>
Run Code Online (Sandbox Code Playgroud)

MainActivity.java ......

请注意,要在MainActivity中导入的所有类必须如下所示; 请检查导入的类是否包含com.google.android. .maps.xxxxxxx类型.

而且你必须添加"mMapView.onCreate(savedInstanceState);" 在OnCreate()下.

import android.os.Bundle;
import com.google.android.gms.maps.MapView;

/**
 * This shows how to create a simple activity with a raw MapView and add a marker to it. This
 * requires forwarding all the important lifecycle methods onto MapView.
 */
public class RawMapViewDemoActivity extends android.support.v4.app.FragmentActivity {
    private MapView mMapView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        mMapView = (MapView) findViewById(R.id.map);
        mMapView.onCreate(savedInstanceState);

    }

    @Override
    protected void onResume() {
        super.onResume();
        mMapView.onResume();

    }

    @Override
    protected void onPause() {
        mMapView.onPause();
        super.onPause();
    }
    @Override
    protected void onDestroy() {
        mMapView.onDestroy();
        super.onDestroy();
    }
    @Override
    public void onLowMemory() {
        super.onLowMemory();
        mMapView.onLowMemory();
    }

    @Override
    public void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        mMapView.onSaveInstanceState(outState);
    }
}
Run Code Online (Sandbox Code Playgroud)

特别是,在MapView的情况下,许多人犯了一个错误,在他们的main.xml中设置" com.google.android.maps .MapView .."后,他们导入了" com.google.android.gms.maps .MapView"在他们的MainActivity中.它导致ANR(错误).在相反的情况下是相同的结果.

因此,请始终检查是否必须在应用程序的main.xml和MainActivity.java中使用或导入相同的类或对象.