2017-05-09 3 views
1

몇 달 전에 Android N에서이 앱을 테스트했는데 모두 정상적으로 작동했지만 오류가 발생했습니다. 이제 i'am으로 MapFragment를 사용하여이 오류가 있습니다Google지도를 추가 할 때 오류가 발생했습니다.

05-09 23:22:35.816 11112-11112/pc.dd.sex_startup E/AndroidRuntime: FATAL EXCEPTION: main 
                   Process: pc.dd.sex_startup, PID: 11112 
                   java.lang.RuntimeException: Unable to start activity ComponentInfo{pc.dd.sex_startup/pc.dd.sex_startup.LogIn.Maps.Map}: android.view.InflateException: Binary XML file line #9: Binary XML file line #9: Error inflating class fragment 
                    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2423) 
                    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2483) 
                    at android.app.ActivityThread.access$900(ActivityThread.java:153) 
                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1349) 
                    at android.os.Handler.dispatchMessage(Handler.java:102) 
                    at android.os.Looper.loop(Looper.java:148) 
                    at android.app.ActivityThread.main(ActivityThread.java:5441) 
                    at java.lang.reflect.Method.invoke(Native Method) 
                    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:738) 
                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:628) 
                   Caused by: android.view.InflateException: Binary XML file line #9: Binary XML file line #9: Error inflating class fragment 
                    at android.view.LayoutInflater.inflate(LayoutInflater.java:543) 
                    at android.view.LayoutInflater.inflate(LayoutInflater.java:427) 
                    at android.view.LayoutInflater.inflate(LayoutInflater.java:374) 
                    at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:280) 
                    at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140) 
                    at pc.dd.sex_startup.LogIn.Maps.Map.onCreate(Map.java:85) 
                    at android.app.Activity.performCreate(Activity.java:6303) 
                    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1108) 
                    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2376) 
                    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2483)  
                    at android.app.ActivityThread.access$900(ActivityThread.java:153)  
                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1349)  
                    at android.os.Handler.dispatchMessage(Handler.java:102)  
                    at android.os.Looper.loop(Looper.java:148)  
                    at android.app.ActivityThread.main(ActivityThread.java:5441)  
                    at java.lang.reflect.Method.invoke(Native Method)  
                    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:738)  
                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:628)  
                   Caused by: android.view.InflateException: Binary XML file line #9: Error inflating class fragment 
                    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:786) 
                    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:708) 
                    at android.view.LayoutInflater.rInflate(LayoutInflater.java:839) 
                    at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:802) 
                    at android.view.LayoutInflater.inflate(LayoutInflater.java:519) 
                    at android.view.LayoutInflater.inflate(LayoutInflater.java:427)  
                    at android.view.LayoutInflater.inflate(LayoutInflater.java:374)  
                    at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:280)  
                    at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140)  
                    at pc.dd.sex_startup.LogIn.Maps.Map.onCreate(Map.java:85)  
                    at android.app.Activity.performCreate(Activity.java:6303)  
                    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1108)  
                    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2376)  
                    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2483)  
                    at android.app.ActivityThread.access$900(ActivityThread.java:153)  
                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1349)  
                    at android.os.Handler.dispatchMessage(Handler.java:102)  
                    at android.os.Looper.loop(Looper.java:148)  
                    at android.app.ActivityThread.main(ActivityThread.java:5441)  
                    at java.lang.reflect.Method.invoke(Native Method)  
                    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:738)  
                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:628)  
                   Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Configuration android.content.res.Resources.getConfiguration()' on a null object reference 
                    at android.util.ResolutionOverride.<init>(ResolutionOverride.java:56) 
                    at android.view.SurfaceView.init(SurfaceView.java:207) 
                    at android.view.SurfaceView.<init>(SurfaceView.java:187) 
                    at com.google.maps.api.android.lib6.gmm6.vector.an.<init>(:com.google.android.gms.DynamiteModulesB:231) 
                    at com.google.maps.api.android.lib6.gmm6.vector.ai.<init>(:com.google.android.gms.DynamiteModulesB:163) 
                    at com.google.maps.api.android.lib6.gmm6.api.ao.<init>(:com.google.android.gms.DynamiteModulesB:389) 
                    at com.google.maps.api.android.lib6.gmm6.api.ao.a(:com.google.android.gms.DynamiteModulesB:349) 
                    at com.google.android.gms.maps.internal.eb.a(:com.google.android.gms.DynamiteModulesB:4048) 
                    at com.google.maps.api.android.lib6.impl.az.a(:com.google.android.gms.DynamiteModulesB:403) 
                    at com.google.maps.api.android.lib6.impl.az.a(:com.google.android.gms.DynamiteModulesB:320) 
                    at com.google.maps.api.android.lib6.impl.cp.a(:com.google.android.gms.DynamiteModulesB:82) 
                    at com.google.maps.api.android.lib6.impl.co.a(:com.google.android.gms.DynamiteModulesB:139) 
                    at com.google.android.gms.maps.internal.w.onTransact(:com.google.android.gms.DynamiteModulesB:107) 
                    at android.os.Binder.transact(Binder.java:387) 
                    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) 

및 자바 :

public class Map extends AppCompatActivity implements OnMapReadyCallback { 
private MapView mapView; 
private GoogleMap map; 
private android.app.FragmentManager fragmentManager; 
private android.app.FragmentTransaction fragmentTransaction; 
private FragmentImage fragment; 
public ClusterManager<MyItem> mClusterManager; 
/** 
* ATTENTION: This was auto-generated to implement the App Indexing API. 
* See https://g.co/AppIndexing/AndroidStudio for more information. 
*/ 
private GoogleApiClient client; 


@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.map_main); 

    //add status bar 
    statusBarFragment status_bar = new statusBarFragment(); 
    fragmentManager = getFragmentManager(); 
    fragmentManager.beginTransaction() 
      .add(R.id.statbar_container_map, status_bar) 
      .commit(); 

    // Get the map and register for the ready callback. 
    MapFragment mapFragment = ((MapFragment) getFragmentManager().findFragmentById(R.id.map)); 
    mapFragment.getMapAsync(this); 

및 XML을 :

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:orientation="vertical" android:layout_width="match_parent" 
    android:layout_height="match_parent"> 


    <fragment xmlns:android="http://schemas.android.com/apk/res/android" 
     android:id="@+id/map" 
     class="com.google.android.gms.maps.SupportMapFragment" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     /> 

    <RelativeLayout 
     android:layout_width="fill_parent" 
     android:layout_height="320dp" 
     android:id="@+id/container" 
     android:layout_alignParentBottom="true" 
     android:layout_alignParentStart="true"></RelativeLayout> 

    <FrameLayout 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentTop="true" 
     android:layout_alignParentStart="true" 
     android:id="@+id/statbar_container_map"> 

    </FrameLayout> 

</RelativeLayout> 

을 또한 FragmentActivityAppCompatActivity을 변경하려고합니다. 그 전에 나는 SupportMapFragment을 사용하고 있으며 같은 오류가 있습니다. 뭐가 잘못 됐니?

답변

4

나는 또한 이전에 아무런 문제가 없었습니다. 해결 방법은 당신의 AndroidManifest.xml 파일 MapActivity

android:hardwareAccelerated="true"

+0

들으 많은에 다음 플래그를 추가하는 것입니다. 그것은 작동합니다! –

+0

잘 듣는 것이 좋습니다. 활동이 너무 많으면 태그에 추가 할 수 있습니다. – Vincent

+0

좋아요, 그것에 대해, thx) –

관련 문제