Błąd przy uruchamianiu mapy

0

Przy próbie uruchomienia mapy wyskakuje:

28158-28158/pl.froger.sqlitetodomanager E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: pl.froger.sqlitetodomanager, PID: 28158
    java.lang.RuntimeException: Unable to start activity ComponentInfo{pl.froger.sqlitetodomanager/pl.froger.sqlitetodomanager.model.MapActivity}: android.view.InflateException: Binary XML file line #8: Error inflating class fragment
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2202)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2252)
            at android.app.ActivityThread.access$800(ActivityThread.java:139)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1200)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5103)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:606)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: android.view.InflateException: Binary XML file line #8: Error inflating class fragment
            at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
            at android.view.LayoutInflater.rInflate(LayoutInflater.java:755)
            at android.view.LayoutInflater.inflate(LayoutInflater.java:492)
            at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
            at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
            at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:315)
            at android.app.Activity.setContentView(Activity.java:1973)
            at pl.froger.sqlitetodomanager.model.MapActivity.onCreate(MapActivity.java:29)
            at android.app.Activity.performCreate(Activity.java:5275)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2166)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2252)
            at android.app.ActivityThread.access$800(ActivityThread.java:139)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1200)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5103)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:606)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.SecurityException: The Maps API requires the additional following permissions to be set in the AndroidManifest.xml to ensure a correct behavior:
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
            at com.google.maps.api.android.lib6.d.t.a(Unknown Source)
            at com.google.maps.api.android.lib6.d.ft.a(Unknown Source)
            at com.google.maps.api.android.lib6.d.aj.a(Unknown Source)
            at com.google.maps.api.android.lib6.d.ai.a(Unknown Source)
            at com.google.android.gms.maps.internal.x.onTransact(SourceFile:107)
            at android.os.Binder.transact(Binder.java:364)
            at com.google.android.gms.maps.internal.IMapFragmentDelegate$zza$zza.onCreateView(Unknown Source)
            at com.google.android.gms.maps.SupportMapFragment$zza.onCreateView(Unknown Source)
            at com.google.android.gms.dynamic.zza$4.zzb(Unknown Source)
            at com.google.android.gms.dynamic.zza.zza(Unknown Source)
            at com.google.android.gms.dynamic.zza.onCreateView(Unknown Source)
            at com.google.android.gms.maps.SupportMapFragment.onCreateView(Unknown Source)
            at android.support.v4.app.Fragment.performCreateView(Fragment.java:1786)
            at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:922)
            at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1114)
            at android.support.v4.app.FragmentManagerImpl.addFragment(FragmentManager.java:1216)
            at android.support.v4.app.FragmentManagerImpl.onCreateView(FragmentManager.java:2169)
            at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:297)
            at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685)
            ... 21 more

Czym może być to spowodowane?

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

mam ustawione w manifescie.

AndroidManifest.XML:

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

    <uses-sdk android:minSdkVersion="9" />

    <android:uses-permission
        android:name="android.permission.WRITE_EXTERNAL_STORAGE"
        android:maxSdkVersion="18" />
    <android:uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <android:uses-permission
        android:name="android.permission.READ_EXTERNAL_STORAGE"
        android:maxSdkVersion="18" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />


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

    <application
        android:icon="@drawable/icon"
        android:label="@string/app_name" >

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

        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".EditActivity"
            android:label="@string/title_activity_edit" >
        </activity>
        <activity
            android:name=".model.MapActivity"
            android:label="@string/title_activity_map" >
        </activity>
    </application>

</manifest>

Mapactivity.java:

package pl.froger.sqlitetodomanager.model;

import android.app.Activity;
import android.content.Intent;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;

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.Marker;
import com.google.android.gms.maps.model.MarkerOptions;

import pl.froger.sqlitetodomanager.R;

public class MapActivity extends FragmentActivity {
    private Marker marker = null;

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

        SupportMapFragment supportMapFragment = (SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map);

        final GoogleMap googleMap = supportMapFragment.getMap();
        googleMap.setMyLocationEnabled(true);

        if(getIntent().hasExtra("lat")) {
            if(getIntent().getExtras().getDouble("lat") != 0.0 && getIntent().getExtras().getDouble("lng") != 0.0) {
                marker = googleMap.addMarker(new MarkerOptions()
                        .position(new LatLng(getIntent().getExtras().getDouble("lat"), getIntent().getExtras().getDouble("lng")))
                        .draggable(true));
                Log.i(">>>>>>>>>>>>>>>>", marker.getPosition().toString());
            }
        }

        //googleMap.addMarker(new MarkerOptions()
        //        .position(new LatLng(location.getLatitude(), location.getLongitude()))
        //        .draggable(true));

        googleMap.setOnMapClickListener(new GoogleMap.OnMapClickListener() {
            @Override
            public void onMapClick(LatLng latLng) {
                googleMap.clear();

                marker = googleMap.addMarker(new MarkerOptions()
                        .position(latLng)
                        .draggable(true));
            }
        });

        Button btn_location = (Button)findViewById(R.id.btn_location);
        btn_location.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if(marker != null) {
                    Intent intent = new Intent();
                    intent.putExtra("lat", marker.getPosition().latitude);
                    intent.putExtra("lng", marker.getPosition().longitude);
                    setResult(Activity.RESULT_OK, intent);
                }

                finish();
                //startActivity(intent);
            }
        });

    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_map, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }
}
0

Jaką wersje Androida ma urządzenie/emulator na którym uruchamiasz aplikację? Jeśli powyżej API 18 to nie dziwne, że leci błąd, masz w manifeście:

<android:uses-permission
        android:name="android.permission.WRITE_EXTERNAL_STORAGE"
        android:maxSdkVersion="18" />

Przy takim zapisie uprawnienia są przyznane tylko dla urządzeń z API < 19.

1 użytkowników online, w tym zalogowanych: 0, gości: 1