NPE при накачивании ActionBarSherlock на старых Android

Я использую ActionBarSherlock и имею страшную проблему:

01-08 22:16:05.803: E/AndroidRuntime(432): java.lang.RuntimeException: Unable to start activity ComponentInfo{ar.android.app.glarm/ar.android.app.glarm.gui.GLarmMain}: android.view.InflateException: Binary XML file line #32: Error inflating class com.actionbarsherlock.internal.widget.ActionBarView
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1736)
[CUT]
01-08 22:16:05.803: E/AndroidRuntime(432): Caused by: android.view.InflateException: Binary XML file line #32: Error inflating class com.actionbarsherlock.internal.widget.ActionBarView
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.createView(LayoutInflater.java:596)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:671)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.rInflate(LayoutInflater.java:724)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.rInflate(LayoutInflater.java:727)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.inflate(LayoutInflater.java:479)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.inflate(LayoutInflater.java:391)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.inflate(LayoutInflater.java:347)
01-08 22:16:05.803: E/AndroidRuntime(432):  at com.actionbarsherlock.internal.ActionBarSherlockCompat.generateLayout(ActionBarSherlockCompat.java:1010)
01-08 22:16:05.803: E/AndroidRuntime(432):  at com.actionbarsherlock.internal.ActionBarSherlockCompat.installDecor(ActionBarSherlockCompat.java:902)
01-08 22:16:05.803: E/AndroidRuntime(432):  at com.actionbarsherlock.internal.ActionBarSherlockCompat.setContentView(ActionBarSherlockCompat.java:855)
01-08 22:16:05.803: E/AndroidRuntime(432):  at com.actionbarsherlock.ActionBarSherlock.setContentView(ActionBarSherlock.java:672)
01-08 22:16:05.803: E/AndroidRuntime(432):  at com.actionbarsherlock.app.SherlockListActivity.setContentView(SherlockListActivity.java:239)
01-08 22:16:05.803: E/AndroidRuntime(432):  at ar.android.app.glarm.gui.GLarmMain.onCreate(GLarmMain.java:117)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1048)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1700)
01-08 22:16:05.803: E/AndroidRuntime(432):  ... 11 more
01-08 22:16:05.803: E/AndroidRuntime(432): Caused by: java.lang.reflect.InvocationTargetException
01-08 22:16:05.803: E/AndroidRuntime(432):  at java.lang.reflect.Constructor.constructNative(Native Method)
01-08 22:16:05.803: E/AndroidRuntime(432):  at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
01-08 22:16:05.803: E/AndroidRuntime(432):  at android.view.LayoutInflater.createView(LayoutInflater.java:576)
01-08 22:16:05.803: E/AndroidRuntime(432):  ... 25 more
01-08 22:16:05.803: E/AndroidRuntime(432): Caused by: java.lang.NullPointerException
01-08 22:16:05.803: E/AndroidRuntime(432):  at com.actionbarsherlock.internal.widget.ActionBarView$HomeView.setUp(ActionBarView.java:1219)
01-08 22:16:05.803: E/AndroidRuntime(432):  at com.actionbarsherlock.internal.widget.ActionBarView.(ActionBarView.java:231)
01-08 22:16:05.803: E/AndroidRuntime(432):  ... 28 more

Я неВ манифесте нет никакого стиля, так как мое приложение принимает Theme.Sherlock напрямую. Моя версия ABS является последней 4.4.0, и я пытаюсь запустить свое приложение в эмуляторе API 11 (API 8 приводит к тому же результату). API 18 работает нормально.

После небольшой отладки в Eclipse выглядит, что следующее возвращает оба нулевых представления (ActionBarView.java):

@Override
protected void onFinishInflate() {
    mUpView = findViewById(R.id.abs__up);
    mIconView = (ImageView) findViewById(R.id.abs__home);
}

и конечно последующие звонки возвращают NPE. Похоже, у меня есть предупреждение в LogCat:

01-08 22:54:20.093: I/dalvikvm(626): Could not find method com.actionbarsherlock.internal.nineoldandroids.widget.NineFrameLayout.onHoverEvent, referenced from method com.actionbarsherlock.internal.widget.ActionBarContainer.onHoverEvent
01-08 22:54:20.093: W/dalvikvm(626): VFY: unable to resolve virtual method 8116: Lcom/actionbarsherlock/internal/nineoldandroids/widget/NineFrameLayout;.onHoverEvent (Landroid/view/MotionEvent;)Z
01-08 22:54:20.093: D/dalvikvm(626): VFY: replacing opcode 0x6f at 0x0000
01-08 22:54:49.864: I/dalvikvm(626): Could not find method com.actionbarsherlock.internal.widget.ActionBarView$HomeView.onHoverEvent, referenced from method com.actionbarsherlock.internal.widget.ActionBarView$HomeView.dispatchHoverEvent
01-08 22:54:49.864: W/dalvikvm(626): VFY: unable to resolve virtual method 8980: Lcom/actionbarsherlock/internal/widget/ActionBarView$HomeView;.onHoverEvent (Landroid/view/MotionEvent;)Z
01-08 22:54:49.864: D/dalvikvm(626): VFY: replacing opcode 0x6e at 0x0000
01-08 22:54:49.864: I/dalvikvm(626): Could not find method android.widget.FrameLayout.onPopulateAccessibilityEvent, referenced from method com.actionbarsherlock.internal.widget.ActionBarView$HomeView.onPopulateAccessibilityEvent
01-08 22:54:49.864: W/dalvikvm(626): VFY: unable to resolve virtual method 5731: Landroid/widget/FrameLayout;.onPopulateAccessibilityEvent (Landroid/view/accessibility/AccessibilityEvent;)V
01-08 22:54:49.864: D/dalvikvm(626): VFY: replacing opcode 0x6f at 0x0006

В чем может быть моя проблема?

PS: я использую Eclipse + Maven и включаю поддержку android-v4 19.0.1 и NineOldAndroids 2.4.0.

РЕДАКТИРОВАТЬ

После некоторой другой отладки выглядит, что сгенерированные номера ресурсов в ActionBarSherlock и R.txt (цель / папка, сгенерированные Maven) не совпадают. Проверяя в отладчике, у меня есть:

R.txt -> int layout abs__action_bar_home 0x7f030000 | Debug -> same
R.txt -> int id abs__up 0x7f07000b | Debug -> ox7f04000b
R.txt -> int id abs__home 0x7f07000a | Debug -> 0x7f04000a

ОБНОВИТЬ

Похоже, что проблема при импорте apklibs ... что-то не так с компиляцией R. Обходной путь должен удалить пользовательские ресурсы, которые смещают идентификаторы abs __ * и портят нумерацию. Например, я сделал следующее:

Я проверил, где происходит сбой ActionBarSherlock, для меня это было при загрузке ресурса R.id.abs__up.Я получил номер ресурса из моего файла R.java и записал его (0x7f07XXXX);Я удалил все ресурсы до 0x7f07XXXX, очистил проект, заново сгенерировал R. Я хотел выровнять обратно R.id.abs__up по его номеру apklib (0x7f04000b). Мне пришлось удалить три папки (anim /, xml /, raw /) и три фактических ресурса из моей строки xml.Теперь R.id.abs__up имел правильный номер в моем скомпилированном R.java.

Смотрите обсуждениеВот.

Ответы на вопрос(0)

Ваш ответ на вопрос