1

我正在尝试使 Android 'Google Maps Android API v2' 的示例代码正常工作。我得到的项目没有错误。但是,当我尝试运行应用程序时,应用程序立即崩溃。

Java 代码:

package com.example.Bardo;

import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import com.google.android.gms.maps.SupportMapFragment;


public class GPS extends FragmentActivity{

   @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.gps);
       SupportMapFragment fragment = new SupportMapFragment();
       fragment.getFragmentManager().beginTransaction().add(android.R.id.content, fragment).commit();

    }


}

XML:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
                xmlns:tools="http://schemas.android.com/tools"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                tools:context=".GPS" >

    <fragment
            android:id="@+id/map"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            class="com.google.android.gms.maps.MapFragment" />

</RelativeLayout>

日志输出:

08-29 09:31:37.286: E/SurfaceFlinger(36): ro.sf.lcd_density must be defined as a build property
08-29 09:31:44.396: E/Trace(1494): error opening trace file: No such file or directory (2)
08-29 09:31:44.466: E/SurfaceFlinger(36): ro.sf.lcd_density must be defined as a build property
08-29 09:31:46.397: E/dalvikvm(1494): Could not find class 'com.example.Bardo.GPS', referenced from method com.example.Bardo.Acceuil$5.onClick
08-29 09:31:46.536: E/SurfaceFlinger(36): ro.sf.lcd_density must be defined as a build property
08-29 09:35:13.466: E/ThrottleService(345): problem during onPollAlarm: java.lang.IllegalStateException: problem parsing stats: java.io.FileNotFoundException: /proc/net/xt_qtaguid/iface_stat_all: open failed: ENOENT (No such file or directory)

清单:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.Bardo"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk

        android:minSdkVersion="8"
        android:targetSdkVersion="17" />


    <permission
        android:name="com.example.Bardo.permission.MAPS_RECEIVE"
        android:protectionLevel="signature" />
     <uses-permission android:name="com.example.Bardo.permission.MAPS_RECEIVE" />
    <uses-permission android:name="android.permission.INTERNET" />
   <uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION"/>
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />



    <uses-feature
            android:glEsVersion="0x00020000"
            android:required="true"/>


    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_bardo"
        android:label="Bardo Museum"
        android:theme="@style/AppTheme" >



        <activity
            android:name=".Acceuil"
            android:label="Musée de la Bardo" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>

        </activity>
        <activity android:name=".Objets" android:label="Objets">  </activity>
        <activity android:name=".GPS" android:label="GPS"> </activity>
        <activity android:name=".Detail" android:label="Detail"></activity>
        <activity
                android:name=".Galeries"
                android:label="Galeries"
               />
        <activity
                android:name=".Evennements"
                android:label="Evennements"/>
        <activity
                android:name=".Infos"
                android:label="Infos"/>

    </application>

</manifest> 

我用谷歌搜索并没有发现有关此异常的信息。我真的很困惑这个问题,不知道如何解决它。有谁知道如何解决它?谢谢。

4

3 回答 3

3

如果你有这个错误error opening trace file: No such file or directory

发生这种情况是因为您尚未在计算机中安装 minSdkVersion 或 targetSdkVersion。我现在已经测试过了。

例如,如果您的 Manifest.xml 中有这些行:

<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="17" />

而你的电脑只安装了API17,它会报错。如果您想对其进行测试,请尝试安装其他 API 版本(在本例中为 API 8)。

对于这个错误ro.sf.lcd_density must be defined as a build property

我认为您正在主线程上使用网络代码。在后台线程中进行联网。AsyncTask 是一个不错的选择。

这两个都应该解决你的问题。

于 2013-08-29T09:52:40.610 回答
2

您没有 Maps API 密钥。按照此文档正确设置:https ://developers.google.com/maps/documentation/android/start

于 2013-08-29T09:51:50.370 回答
0

在课程开始时检查您的包名称。它们应该与您的应用程序的名称相匹配。这可能是某种复制粘贴错误

于 2013-08-29T09:52:19.963 回答