GoogleTV InflateException - PullRequest
       23

GoogleTV InflateException

0 голосов
/ 17 января 2012

Я пытаюсь перенести свое приложение на Google TV, но как только я начал, у меня возникла исключительная ситуация InflateException для одного из моих XML-файлов.

На любом другом устройстве, на котором я пытался запустить приложение (на вкладках или на телефонах), оно работает без каких-либо проблем, но в GoogleTV оно дает такое исключение.

EDIT строка XML не совсем понятна, если она находится в файлах XML, потому что, как отмечают некоторые в комментариях, инфлятор не очень хорошо отслеживает это. Кажется, он находится во включенном макете (см. Код ниже) вокруг TextView.

Кто-нибудь когда-нибудь получал эту книгу?

Я заметил из трассировки стека, что inflater имеет другую реализацию, от которой я могу догадаться, что он может не поддерживать что-то, что я использую.

Я также заметил, что в нижней части трассировки стека есть:

Caused by: java.lang.reflect.InvocationTargetException

на самом деле для меня это ничего не говорит, но, может быть, кто-то там :).

есть идеи?

XML:

<?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"
android:background="@android:color/transparent" >

<include android:layout_alignParentTop="true"
    layout="@layout/sd_error"/>

<GridView
    android:id="@android:id/list"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_margin="0dip"
    android:cacheColorHint="@android:color/transparent"
    android:listSelector="@drawable/mxm_list_selector"
    android:drawSelectorOnTop="true"
    android:numColumns="2"
    android:padding="0dip"
    android:stretchMode="columnWidth"
    android:nextFocusDown="@+id/music_now_playing_container"/>

<ProgressBar
    android:id="@android:id/empty"
    style="@style/Widget.ProgressBar.Large.Music"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true" />

 </RelativeLayout>

@ макет / sd_error:

<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android">
     <ImageView
        android:id="@+id/sd_icon"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:background="@drawable/ic_mp_sd_card"
        android:visibility="gone" />

    <TextView
        android:id="@+id/sd_message"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:padding="8dip"
        android:text="@string/sdcard_missing_message"
        android:textAppearance="?android:attr/textAppearanceMedium"
        android:visibility="gone" />

</merge>

Вход:

01-17 10:06:05.794: E/AndroidRuntime(26441): FATAL EXCEPTION: main
01-17 10:06:05.794: E/AndroidRuntime(26441): android.view.InflateException: Binary XML file line #18: Error inflating class <unknown>
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.createView(LayoutInflater.java:596)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at com.android.internal.policy.impl.tv.TvLayoutInflater.onCreateView(TvLayoutInflater.java:50)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:644)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:669)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.rInflate(LayoutInflater.java:724)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.parseInclude(LayoutInflater.java:783)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.rInflate(LayoutInflater.java:720)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.inflate(LayoutInflater.java:479)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.inflate(LayoutInflater.java:391)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.LayoutInflater.inflate(LayoutInflater.java:347)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at com.designfuture.music.ui.fragment.mymusic.TrackBrowserFragment.onCreateView(TrackBrowserFragment.java:179)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:870)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1080)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:622)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1416)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.app.FragmentManagerImpl.executePendingTransactions(FragmentManager.java:431)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.app.FragmentPagerAdapter.finishUpdate(FragmentPagerAdapter.java:139)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.view.ViewPager.populate(ViewPager.java:820)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.support.v4.view.ViewPager.onMeasure(ViewPager.java:1032)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:581)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:365)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4491)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4491)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.LinearLayout.measureVertical(LinearLayout.java:764)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.LinearLayout.onMeasure(LinearLayout.java:519)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4491)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1284)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.LinearLayout.measureVertical(LinearLayout.java:613)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.LinearLayout.onMeasure(LinearLayout.java:519)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4491)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4491)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4491)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at com.android.internal.policy.impl.tv.TvWindow$DecorView.onMeasure(TvWindow.java:1274)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.View.measure(View.java:10939)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewRoot.performTraversals(ViewRoot.java:949)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.view.ViewRoot.handleMessage(ViewRoot.java:2048)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.os.Handler.dispatchMessage(Handler.java:99)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.os.Looper.loop(Looper.java:132)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at android.app.ActivityThread.main(ActivityThread.java:4083)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at java.lang.reflect.Method.invokeNative(Native Method)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at java.lang.reflect.Method.invoke(Method.java:491)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
01-17 10:06:05.794: E/AndroidRuntime(26441):    at dalvik.system.NativeStart.main(Native Method)
01-17 10:06:05.794: E/AndroidRuntime(26441): Caused by: java.lang.reflect.InvocationTargetException
01-17 10:06:05.794: E/AndroidRuntime(26441):    at java.lang.reflect.Constructor.constructNative(Nat

РЕДАКТИРОВАНИЕ РЕШЕНО:

Я наконец нашел проблему, поэтому я опубликую здесь, что это было. У меня просто был этот res @drawable/ic_mp_sd_card только в папке res / drawable-xxx-finger / , поэтому проблема не имела никакого отношения к GoogleTV, но в целом была связана с телефонами, которые не поддерживают сенсорный экран.

...