【问题标题】:Google map v2.0 wont work and app crashes谷歌地图 v2.0 无法工作并且应用程序崩溃
【发布时间】:2013-12-10 06:51:46
【问题描述】:

我正在开发地图应用程序。它在 SDK 16 上对我有用,但问题是我需要在 sdk 8 上扩展它并且我的应用程序崩溃了。这是我的 sdk 16 here的全部代码

我将 support-library-v4 作为外部 JAR 添加到项目中。我还添加了 google-play-service-lib 作为库。但没有任何效果

我将Activity 更改为FragmentActivity 也用过

 googleMap =   ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)).getMap();

而不是

googleMap =   ((MapFragment)getFragmentManager().findFragmentById(R.id.map)).getMap();

我遇到了很多问题,但最终在 sdk 16 上解决了。我需要在 sdk 8 中使用它,但应用程序崩溃并且无法工作。

请帮我解决这个问题。

这是我的清单:

         <permission
        android:name="com.ariagostar.maptest.permission.MAPS_RECEIVE"
        android:protectionLevel="signature" />


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



    <uses-permission android:name="com.ariagostar.maptest.permission.MAPS_RECEIVE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <!-- Required to show current location -->
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

    <!-- Required OpenGL ES 2.0. for Maps V2 -->
    <uses-feature
        android:glEsVersion="0x00020000"
        android:required="true" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/mahdi_theme"
        android:name=".G"
        >
        <activity
            android:name=".MainActivity"
            android:label="@string/title_activity_main" 
            >

        </activity>

        <activity android:name=".SplashActivity">



        </activity>
        <activity android:name=".LocationsActivity"
            android:screenOrientation="portrait"
            >


        </activity>
        <activity android:name=".AIDSActivity"
            android:screenOrientation="portrait"
           ></activity>
        <activity android:name=".AboutActivity"></activity>
        <activity android:name=".CureActivity"
            android:screenOrientation="portrait"
           ></activity>
        <activity android:name=".EllatActivity"
            android:screenOrientation="portrait"
            ></activity>
        <activity android:name=".InfectedActivity"
            android:screenOrientation="portrait"
            ></activity>
        <activity android:name=".QuestionActivity"
            android:screenOrientation="portrait"
            >




        </activity>

        <activity android:name=".SeirActivity"
            android:screenOrientation="portrait"></activity>
        <activity android:name=".PreventionActivity"
            android:screenOrientation="portrait"></activity>
        <activity android:name=".TashdidActivity"
            android:screenOrientation="portrait"></activity>
        <activity android:name=".AboutUsActivity"
            android:screenOrientation="portrait"></activity>
        <activity android:name=".OtherProductActivity"
            android:screenOrientation="portrait"></activity>
        <activity android:name=".MapActivity"
           android:label="@string/title_activity_main">

            <intent-filter>
                <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" />

         <meta-data
            android:name="com.google.android.maps.v2.API_KEY"
            android:value="my actual key" />

         <meta-data
        android:name="com.google.android.gms.version"
        android:value="@integer/google_play_services_version" />

    </application>

这是我的地图活动:

import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;

import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.CameraPosition;
import com.google.android.gms.maps.model.LatLng;


public class MapActivity extends FragmentActivity {



         private GoogleMap googleMap;

        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.map_form);
            try {
                Log.i("LOG", "map test 1");
                // Loading map
                initilizeMap();
                Log.i("LOG", "map test 2");

            } catch (Exception e) {
                 Log.e("LOG", "I got an error", e);
                e.printStackTrace();
            }

            Button b1 = (Button) findViewById(R.id.button1);

            b1.setOnClickListener(new OnClickListener() {

                public void onClick(View v) {
                    double latitude =20.002 ;
                    double longitude = 3.399;

                    // create marker
                    //MarkerOptions marker = new MarkerOptions().position(new LatLng(latitude, longitude)).title("Hello Maps ");

                    // adding marker
                    //googleMap.addMarker(marker);

                    CameraPosition cameraPosition = new CameraPosition.Builder().target(
                            new LatLng(37.385044, 78.486671)).zoom(12).build();

                    googleMap.animateCamera(CameraUpdateFactory.newCameraPosition(cameraPosition));

                }
            });
        }

        @Override
        public boolean onCreateOptionsMenu(Menu menu) {
            getMenuInflater().inflate(R.menu.activity_main, menu);
            return true;
        }

        private void initilizeMap() {
            if (googleMap == null) {

                //googleMap = ((MapFragment) getFragmentManager().findFragmentById(R.id.map)).getMap();

                //googleMap =   ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)).getMap();
                //googleMap =   ((MapFragment)getFragmentManager().findFragmentById(R.id.map)).getMap();
                googleMap =   ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)).getMap();


                // check if map is created successfully or not
                if (googleMap == null) {
                    Toast.makeText(getApplicationContext(),
                            "Sorry! unable to create maps", Toast.LENGTH_SHORT)
                            .show();
                }
            }
        }

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


}

这是我的 map_form

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

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

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:text="Button" />

</RelativeLayout>

日志猫:

12-13 11:09:51.957: E/LOG(4706): I got an error
12-13 11:09:51.957: E/LOG(4706): java.lang.NullPointerException
12-13 11:09:51.957: E/LOG(4706):    at com.ariagostar.hiv.MapActivity.initilizeMap(MapActivity.java:76)
12-13 11:09:51.957: E/LOG(4706):    at com.ariagostar.hiv.MapActivity.onCreate(MapActivity.java:32)
12-13 11:09:51.957: E/LOG(4706):    at android.app.Activity.performCreate(Activity.java:5372)
12-13 11:09:51.957: E/LOG(4706):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104)
12-13 11:09:51.957: E/LOG(4706):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2267)
12-13 11:09:51.957: E/LOG(4706):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2359)
12-13 11:09:51.957: E/LOG(4706):    at android.app.ActivityThread.access$700(ActivityThread.java:165)
12-13 11:09:51.957: E/LOG(4706):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1326)
12-13 11:09:51.957: E/LOG(4706):    at android.os.Handler.dispatchMessage(Handler.java:99)
12-13 11:09:51.957: E/LOG(4706):    at android.os.Looper.loop(Looper.java:137)
12-13 11:09:51.957: E/LOG(4706):    at android.app.ActivityThread.main(ActivityThread.java:5455)
12-13 11:09:51.957: E/LOG(4706):    at java.lang.reflect.Method.invokeNative(Native Method)
12-13 11:09:51.957: E/LOG(4706):    at java.lang.reflect.Method.invoke(Method.java:525)
12-13 11:09:51.957: E/LOG(4706):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1187)
12-13 11:09:51.957: E/LOG(4706):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003)
12-13 11:09:51.957: E/LOG(4706):    at dalvik.system.NativeStart.main(Native Method)
12-13 11:09:51.957: E/AndroidRuntime(4706): FATAL EXCEPTION: main
12-13 11:09:51.957: E/AndroidRuntime(4706): java.lang.RuntimeException: Unable to resume activity {com.ariagostar.hiv/com.ariagostar.hiv.MapActivity}: java.lang.NullPointerException
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2929)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2958)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2364)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.ActivityThread.access$700(ActivityThread.java:165)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1326)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.os.Handler.dispatchMessage(Handler.java:99)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.os.Looper.loop(Looper.java:137)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.ActivityThread.main(ActivityThread.java:5455)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at java.lang.reflect.Method.invokeNative(Native Method)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at java.lang.reflect.Method.invoke(Method.java:525)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1187)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at dalvik.system.NativeStart.main(Native Method)
12-13 11:09:51.957: E/AndroidRuntime(4706): Caused by: java.lang.NullPointerException
12-13 11:09:51.957: E/AndroidRuntime(4706):     at com.ariagostar.hiv.MapActivity.initilizeMap(MapActivity.java:76)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at com.ariagostar.hiv.MapActivity.onResume(MapActivity.java:90)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1209)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.Activity.performResume(Activity.java:5450)
12-13 11:09:51.957: E/AndroidRuntime(4706):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2919)
12-13 11:09:51.957: E/AndroidRuntime(4706):     ... 12 more

【问题讨论】:

  • 你的错误在哪里?
  • @GrIsHu:在模拟器中它说:INSTALL_FAILED_MISSING_SHARED_LIBRARY 并取消安装。在我的真实设备中“不幸的是......已经停止”
  • @Kenji Google Maps API V2 根本无法在模拟器上运行。
  • 那我该怎么办?此代码适用于 SDK 16,它仍安装在我的开发人员中。但在 SDK 8 上发生崩溃 :(
  • 在 Google 地图 [Google 地图][1] [1] 中查看以下链接以获得帮助:stackoverflow.com/questions/20464136/…

标签: android google-maps crash


【解决方案1】:

API Level 12 之后才支持 MapFragment 或 SupportMapFragment。建议改用 SupportMapFragment。

Fragment 类在 API 级别 11 之前不可用。并且您的目标是不支持 Fragment 的 API 级别 8。这就是为什么我认为您会收到如下错误:

Caused by: java.lang.ClassNotFoundException: android.view.fragment in loader dalvik.system.PathClassLoader

【讨论】:

  • 我没有使用 MapFragment 。我刚刚使用了 SupportMapFragment 并且应用程序无法工作,我将用整个代码升级我的问题。
  • 我在下面提到片段类不可用。
【解决方案2】:

您需要在项目中导入Google Play Services

检查你是否已经在Android SDK Manager下载了Google Play Services

更多信息Check this example

【讨论】:

  • 我将 support-library-v4 作为外部 JAR 添加到项目中。我还添加了 google-play-service-lib 作为库。但没有任何效果
【解决方案3】:

由于您的错误指示INSTALL_FAILED_MISSING_SHARED_LIBRARY and cancels the istalation. in my real device "unfortunately ... has stoped",并且您正在使用SupportMapFragment 及其在supportv4 库中可用,因此应该在您的项目中添加support-library-v4 以支持API12 下方的地图片段。

如下更改您的onResume()

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

【讨论】:

  • 我将 support-library-v4 作为外部 JAR 添加到项目中。我还添加了 google-play-service-lib 作为库。但没有任何效果
  • 谢谢。但我终于解决了这个问题。这是因为 map_form
【解决方案4】:

我终于解决了这个问题。只是因为使用了

android:name="com.google.android.gms.maps.MapFragment"

并且应该使用这个:

android:name="com.google.android.gms.maps.SupportMapFragment"

应用程序正常运行

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-11-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-02-12
    相关资源
    最近更新 更多