Приложение Android аварийно завершает работу на телефонах HTC и Sony Ericsson

Сегодня мы запустили приложение на Маркете - Nomad. Я получаю сообщения о сбое приложения на телефонах HTC и Sony Ericsson. Я получил следующий отчет журнала от одного из пользователей USER.

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.m7.nomad/com.m7.nomad.SplashActivity}: java.lang.UnsupportedOperationException: Can't convert to dimension: type=0x3
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
at android.app.ActivityThread.access$600(ActivityThread.java:123)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4424)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.UnsupportedOperationException: Can't convert to dimension: type=0x3
at android.content.res.TypedArray.getDimensionPixelSize(TypedArray.java:463)
at android.view.ViewGroup$MarginLayoutParams.<init>(ViewGroup.java:5459)
at android.widget.LinearLayout$LayoutParams.<init>(LinearLayout.java:1776)
at android.widget.LinearLayout.generateLayoutParams(LinearLayout.java:1700)
at android.widget.LinearLayout.generateLayoutParams(LinearLayout.java:56)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:741)
at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
at com.android.internal.policy.impl.PhoneWindow.generateLayout(PhoneWindow.java:2707)
at com.android.internal.policy.impl.PhoneWindow.installDecor(PhoneWindow.java:2767)
at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:247)
at android.app.Activity.setContentView(Activity.java:1835)
at com.m7.nomad.SplashActivity.onCreate(SplashActivity.java:46)
at android.app.Activity.performCreate(Activity.java:4465)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
... 11 more

Не в состоянии понять, почему это происходит.

SplashActivity.java

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    context = this;

    // Remove title bar
    this.requestWindowFeature(Window.FEATURE_NO_TITLE);

    setContentView(R.layout.activity_splash);

    // Shared Preferences
    settings = getSharedPreferences(SETTINGS_PREFS, 0);

    configRun = settings.getInt("database_version", 0);

    this.assetManager = this.getAssets();


}

Строка 46 указывает на setContentView(R.layout.activity_splash);

activity_splash.java

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

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:contentDescription="Splash Screen"
        android:gravity="center"
        android:src="@drawable/splash_logo" />

</RelativeLayout>

person Harsha M V    schedule 22.01.2013    source источник
comment
Возможно, вы захотите поделиться некоторым кодом... Особенно той частью, которая потерпела крах. В противном случае самое разумное, что мы могли бы сказать, это: «У вас ошибка».   -  person Veger    schedule 22.01.2013
comment
Кажется, что-то не так с макетом вашего SplashActivity. Пожалуйста, опубликуйте макет xml и код из com.m7.nomad.SplashActivity.onCreate(SplashActivity.java:46) строки 46 вашей деятельности.   -  person Evos    schedule 22.01.2013
comment
@Veger добавил код :)   -  person Harsha M V    schedule 22.01.2013
comment
@Evos также поделился кодом действия.   -  person Harsha M V    schedule 22.01.2013
comment
Вы действительно уверены, что вам нужны эти 2 тега для вашего относительного макета: android:textAlignment="center" android:gravity="center". Не могли бы вы попробовать их удалить?   -  person Evos    schedule 22.01.2013
comment
@ Эвос, да. у меня был другой контент, поэтому я использовал его. Думаю, я могу удалить их сейчас.   -  person Harsha M V    schedule 22.01.2013
comment
@Evos, я думаю, мне понадобится гравитация = центр, так как изображение должно отображаться в центре   -  person Harsha M V    schedule 22.01.2013
comment
Возможный дубликат @stackoverflow.com/questions/10146057/   -  person Anders Metnik    schedule 22.01.2013
comment
@AndersMetnik Я не использую здесь никаких измерений. так что есть идеи, как это можно решить?   -  person Harsha M V    schedule 22.01.2013
comment
Попробуйте после удаления ориентации относительного макета...   -  person AndroidLearner    schedule 22.01.2013
comment
@Harsha M V, пока это относительный тег гравитации макета, там не работает, поэтому вы можете безопасно удалить его. А как насчет второго тега textAlignement?   -  person Evos    schedule 22.01.2013
comment
@Evos yesh, я удалил это: D, спасибо, я проверю это: D   -  person Harsha M V    schedule 22.01.2013
comment
@AndroidLearner, о, хорошо. я тоже удалю :D   -  person Harsha M V    schedule 22.01.2013


Ответы (3)


Используйте это в макете заставки

<?xml version="1.0" encoding="utf-8"?>
 <ImageView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#ffe5492a"
android:contentDescription="Splash Screen"
android:scaleType="fitCenter"
android:src="@drawable/splash_logo" >

person M-WaJeEh    schedule 22.01.2013
comment
почему я не могу использовать макет? мне нужно заполнить цвет фона - person Harsha M V; 22.01.2013
comment
вы можете использовать android:background="@color/primary_color", если хотите, кстати того же цвета. :) - person M-WaJeEh; 22.01.2013
comment
любая идея, почему это происходит ??? я имею в виду, почему это происходит только на HTC. у меня нет htc в моем распоряжении. проверял у друга :D - person Harsha M V; 22.01.2013
comment
Я предполагаю, что android:textAlignment="center" глючит на устройствах HTC, просто предположение.... ;) - person M-WaJeEh; 22.01.2013
comment
Вот подсказка: запустите AboutActivity или MainActivity вместо SplashActivity. Если он все еще вылетает, значит, проблема в вашей теме, удалите этот тег android:theme="@style/Theme.Nomad" из вашего манифеста, и он обязательно заработает. Если это сработает, вы будете знать, где искать. - person M-WaJeEh; 23.01.2013
comment
Я был прав :P Проблема здесь <item name="android:layout_marginStart">@drawable/ic_menu_share</item> в вашей теме. ;) - person M-WaJeEh; 23.01.2013
comment
давайте продолжим это обсуждение в чате - person M-WaJeEh; 23.01.2013
comment
Спасибо :) это было то, что вы сказали :) - person Harsha M V; 24.01.2013

Причина вашего сбоя, скорее всего, скрыта в ваших стилях. Скорее всего, он содержит атрибут, ссылающийся на измерение, содержащееся в Android SDK, в то время как ваше приложение работает в более старой версии SDK, которая не содержит этого измерения.

В этом примере автор использовал следующий атрибут:

android:paddingLeft="?android:attr/listPreferredItemPaddingLeft"

Однако, как указано в принятом ответе, запись listPreferredItemPaddingLeft в android.R.attr доступен только с SDK уровня 14 и выше.

Либо удалите неверные записи, либо замените их, либо разделите файлы ресурсов, чтобы они соответствовали уровню SDK. Например, вы можете указать один стиль в res/values-14, а другой исключить эти записи из версии в res/values.

person Paul Lammertsma    schedule 07.04.2013
comment
удаление их просто сработало и ничего не изменило, поэтому мы сделали это сейчас. спасибо за указание, как приспособить то же самое, используя значение-14. я попробую это и дам вам знать: D - person Harsha M V; 07.04.2013

Примените этот 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="@color/primary_color"
    android:textAlignment="center" >

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:contentDescription="Splash Screen"
        android:gravity="center"
        android:src="@drawable/splash_logo" />

</RelativeLayout>

Прокомментируйте эту строку ::

context = this;
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
person AndroidLearner    schedule 22.01.2013
comment
черт, у меня нет телефона htc .. протестировал его: P отчитается: D - person Harsha M V; 22.01.2013
comment
Вы установили то же имя пакета в манифесте? Поделитесь дополнительным кодом активности всплеска и XML-файлами. - person AndroidLearner; 22.01.2013
comment
Могу ли я отправить его вам по почте, чтобы мне не пришлось делиться файлом с общественностью? - person Harsha M V; 22.01.2013
comment
я не нашел твой адрес электронной почты :D - person Harsha M V; 22.01.2013