简单地图视图不起作用

时间:2013-01-16 19:54:01

标签: android

创建简单的Google地图视图时遇到问题。您可以在下面找到我的代码:

清单:

<uses-sdk
    android:minSdkVersion="8"/>
<uses-permission android:name="android.permission.INTERNET"/>

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <meta-data
        android:name="com.google.android.maps.v2.API_KEY"
        android:value="AIzaSyB0zPyFFyQ_sCVmMjj6pgNqvqKg3zHGMSs"/>


    <activity
        android:name="com.example.maptest.MainActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <category android:name="android.intent.category.EMBED"/>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>

    </activity>
           <uses-library android:name="com.google.android.maps"/>
</application>

在Java文件中:

public class MainActivity extends MapActivity {

private MapView mapView; 

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mapView = (MapView)findViewById(R.id.map); 
}

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

}

在XML文件中:

<com.google.android.maps.MapView
    android:id="@+id/map"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_alignParentLeft="true"
    android:apiKey="AIzaSyB0zPyFFyQ_sCVmMjj6pgNqvqKg3zHGMSs"
    android:clickable="true" >
</com.google.android.maps.MapView>

结果是一个启动应用程序,女巫只显示灰色区域而不是地图,但角落里有典型的谷歌图标。

我知道最常见的问题是API密钥错误,但我经常检查它并且密钥是正确的。 也许有人有建议?

1 个答案:

答案 0 :(得分:0)

问题是您正在使用V2 API的密钥(根据清单中的注释判断),但您的实现使用的是V1 API。你基本上把这两个API版本混在了一起。 V1 API需要将适当的V1 API密钥作为XML布局中MapView的属性放置。 V2 API要求将密钥放在清单中,就像您所做的那样。此外,V2 API还需要将各种其他内容添加到清单中。

当您使用V1 API时,您需要获取V1 API密钥(您可以在4月份之前使用该密钥,因为它已被弃用)。或者,切换到使用V2 API,显然你会被鼓励这样做(但要注意它需要以后的某些2.2设备不支持的OpenGL版本。)

我建议您密切关注V2 API教程:V2 Maps API