android.view.InflateException: строка двоичного файла XML № 0: строка двоичного файла XML № 0: ошибка надувания фрагмента класса - PullRequest
0 голосов
/ 14 мая 2018

Здравствуйте, stackoverflow, я столкнулся с небольшой проблемой целую неделю. Я пытаюсь запустить действие Map из своего основного действия, и после вызова действия Map я получаю эту ошибку:

E/AndroidRuntime: FATAL EXCEPTION: main
              Process: eu.tinysolutions.tinytracker, PID: 12795
              java.lang.RuntimeException: Unable to start activity ComponentInfo{eu.tinysolutions.tinytracker/eu.tinysolutions.tinytracker.MapsActivity}: android.view.InflateException: Binary XML file line #0: Binary XML file line #0: Error inflating class fragment
                  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2572)
                  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2654)
                  at android.app.ActivityThread.-wrap11(ActivityThread.java)
                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1488)
                  at android.os.Handler.dispatchMessage(Handler.java:111)
                  at android.os.Looper.loop(Looper.java:207)
                  at android.app.ActivityThread.main(ActivityThread.java:5728)
                  at java.lang.reflect.Method.invoke(Native Method)
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:679)
               Caused by: android.view.InflateException: Binary XML file line #0: Binary XML file line #0: Error inflating class fragment
                  at android.view.LayoutInflater.inflate(LayoutInflater.java:539)
                  at android.view.LayoutInflater.inflate(LayoutInflater.java:423)
                  at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
                  at com.android.internal.policy.PhoneWindow.setContentView(PhoneWindow.java:412)
                  at android.app.Activity.setContentView(Activity.java:2191)
                  at eu.tinysolutions.tinytracker.MapsActivity.onCreate(MapsActivity.java:20)
                  at android.app.Activity.performCreate(Activity.java:6309)
                  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1113)
                  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2519)
                  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2654) 
                  at android.app.ActivityThread.-wrap11(ActivityThread.java) 
                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1488) 
                  at android.os.Handler.dispatchMessage(Handler.java:111) 
                  at android.os.Looper.loop(Looper.java:207) 
                  at android.app.ActivityThread.main(ActivityThread.java:5728) 
                  at java.lang.reflect.Method.invoke(Native Method) 
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:679) 
               Caused by: android.view.InflateException: Binary XML file line #0: Error inflating class fragment
                  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:782)
                  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)
                  at android.view.LayoutInflater.inflate(LayoutInflater.java:492)
                  at android.view.LayoutInflater.inflate(LayoutInflater.java:423) 
                  at android.view.LayoutInflater.inflate(LayoutInflater.java:374) 
                  at com.android.internal.policy.PhoneWindow.setContentView(PhoneWindow.java:412) 
                  at android.app.Activity.setContentView(Activity.java:2191) 
                  at eu.tinysolutions.tinytracker.MapsActivity.onCreate(MapsActivity.java:20) 
                  at android.app.Activity.performCreate(Activity.java:6309) 
                  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1113) 
                  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2519) 
                  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2654) 
                  at android.app.ActivityThread.-wrap11(ActivityThread.java) 
                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1488) 
                  at android.os.Handler.dispatchMessage(Handler.java:111) 
                  at android.os.Looper.loop(Looper.java:207) 
                  at android.app.ActivityThread.main(ActivityThread.java:5728) 
                  at java.lang.reflect.Method.invoke(Native Method) 
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:679) 
               Caused by: java.lang.RuntimeException: API key not found.  Check that <meta-data android:name="com.google.android.geo.API_KEY" android:value="your API key"/> is in the <application> element of AndroidManifest.xml
                  at com.google.maps.api.android.lib6.drd.q.b(:com.google.android.gms.dynamite_dynamitemodulesb@12673019@12.6.73 (040300-194189626):40)
                  at com.google.maps.api.android.lib6.auth.e.a(:com.google.android.gms.dynamite_dynamitemodulesb@12673019@12.6.73 (040300-194189626):11)
                  at com.google.maps.api.android.lib6.impl.e.a(:com.google.android.gms.dynamite_dynamitemodulesb@12673019@12.6.73 (040300-194189626):4)
                  at com.google.android.gms.maps.internal.b.a(:com.google.android.gms.dynamite_dynamitemodulesb@12673019@12.6.73 (040300-194189626):24)
                  at com.google.android.gms.maps.internal.CreatorImpl.a(:com.google.android.gms.dynamite_dynamitemodulesb@12673019@12.6.73 (040300-194189626):69)
                  at com.google.android.gms.maps.internal.CreatorImpl.newMapFragmentDelegate(:com.google.android.gms.dynamite_dynamitemodulesb@12673019@12.6.73 (040300-194189626):32)
                  at com.google.android.gms.maps.internal.i.onTransact(:com.google.android.gms.dynamite_dynamitemodulesb@12673019@12.6.73 (040300-194189626):31)
                  at android.os.Binder.transact(Binder.java:392)
                  at com.google.android.gms.internal.maps.zza.transactAndReadException(Unknown Source)
                  at com.google.android.gms.maps.internal.zzf.zzc(Unknown Source)
                  at com.google.android.gms.maps.SupportMapFragment$zzb.zzc(Unknown Source)
                  at com.google.android.gms.maps.SupportMapFragment$zzb.createDelegate(Unknown Source)
                  at com.google.android.gms.dynamic.DeferredLifecycleHelper.zza(Unknown Source)
                  at com.google.android.gms.dynamic.DeferredLifecycleHelper.onInflate(Unknown Source)
                  at com.google.android.gms.maps.SupportMapFragment.onInflate(Unknown Source)
                  at android.support.v4.app.Fragment.onInflate(Fragment.java:1306)
                  at android.support.v4.app.FragmentManagerImpl.onCreateView(FragmentManager.java:3672)
                at android.support.v4.app.

MainActivity код:

 protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    mapInit();
}
public void mapInit(){
    startActivity(new Intent(this, MapsActivity.class));

}

MapsAcitivity - это просто действие по умолчанию для Android-студии Google, работающее с картами Google:

public class MapsActivity extends FragmentActivity implements OnMapReadyCallback {

  private GoogleMap mMap;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_maps);
    // Obtain the SupportMapFragment and get notified when the map is ready to be used.
    SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
            .findFragmentById(R.id.map);
    mapFragment.getMapAsync(this);
  }

Я обнаружил, что приложение тормозит на MapsActivity setContentView line

P.S Я добавил ключ API в файл манифеста

UPDATE

извините, я забыл добавить файлы макетов

Вот файл макета Activity_maps:

<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:map="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/map"
android:name="com.google.android.gms.maps.SupportMapFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MapsActivity" />

Ответы [ 2 ]

0 голосов
/ 14 мая 2018

Проблема в том, что вы используете фрагмент без представления контейнера.

Об этом можно прочитать в Создание документации гибкого пользовательского интерфейса :

Важное правило при работе с фрагментами, особенно при добавлении фрагментов во время выполнения, заключается в том, что макет вашей деятельности должен включать контейнерное представление, в которое можно вставить фрагмент.

И из этого Документация по фрагментам :

Когда вы добавляете фрагмент как часть макета своей деятельности, он находится в ViewGroup внутри иерархии представления деятельности, и фрагмент определяет свою собственнуюПосмотреть макет.Вы можете вставить фрагмент в макет своей деятельности, объявив его в файле макета активности, как элемент, или из кода своего приложения, добавив его в существующую ViewGroup

Итак, добавьте корневой макет в ваш XML, изменив макет activity_maps на что-то вроде этого:

<?xml version="1.0" encoding="utf-8"?>
<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=".MapsActivity" >

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

</RelativeLayout>

Не забудьте использовать class вместо атрибута android:name.

0 голосов
/ 14 мая 2018

его там в логах

Caused by: java.lang.RuntimeException: API key not found. Check that <meta-data android:name="com.google.android.geo.API_KEY" android:value="your API key"/> is in the <application> element of AndroidManifest.xml

добавьте ваш ключ API в файл манифеста

, например

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools">
    .
    .
    <application
          .  
          <meta-data
                 android:name="com.google.android.geo.API_KEY"
                 android:value="YOUR API KEY HERE" />
    </application>
</manifest>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...