Ответ 1
Я снова использую то же самое в другом приложении. Кажется, что это вызвано необработанным исключением в getView
в адаптере списка.
У меня есть следующий код, пытаясь создать простой ListAdapter в ListView (у меня был этот код, работающий до этого, и это единственное место, где я что-то изменил):
public BuddyListAdapter(Context context, HashMap<String, Buddy> hashMap) {
buddyList = new ArrayList<Buddy>(hashMap.values());
mInflater = LayoutInflater.from(context);
ctx = context;
}
При переходе ничего не происходит, но при запуске я получаю NullPointerException
в ChoreoGrapher.doCallbacks
, когда я создаю пустой ArrayList
, он не сбой:
public BuddyListAdapter(Context context, HashMap<String, Buddy> hashMap) {
buddyList = new ArrayList<Buddy>();
mInflater = LayoutInflater.from(context);
ctx = context;
}
Что такое ChoreoGrapher
и почему это сбой моего приложения?
Я полностью застрял в том, что может быть проблемой, или как понять, что не так. Отладчик Eclipse или информация о сбоях на самом деле не помогают.
Вся трассировка стека выглядит следующим образом:
Thread [<1> main] (Suspended (exception NullPointerException))
Choreographer.doCallbacks(int, long) line: 558
Choreographer.doFrame(long, int) line: 525
Choreographer$FrameDisplayEventReceiver.run() line: 711
Handler.handleCallback(Message) line: 615
Choreographer$FrameHandler(Handler).dispatchMessage(Message) line: 92
Looper.loop() line: 137
ActivityThread.main(String[]) line: 4745
Method.invokeNative(Object, Object[], Class, Class[], Class, int, boolean) line: not available [native method]
Method.invoke(Object, Object...) line: 511
ZygoteInit$MethodAndArgsCaller.run() line: 786
ZygoteInit.main(String[]) line: 553
NativeStart.main(String[]) line: not available [native method]
У меня также есть Handler
в основной деятельности. Когда он ничего не делает, список не падает. Тем не менее, я удаляю все обратные вызовы из него перед открытием списка.
Я снова использую то же самое в другом приложении. Кажется, что это вызвано необработанным исключением в getView
в адаптере списка.
У меня эта ошибка в моем приложении только на Android 4.4.
В отладчике отображается то же сообщение, что и вопрос. Однако, когда отладка полной стеки в DDMS не выполняется:
Полный стек:
11-13 16:34:53.088: E/AndroidRuntime(1964): FATAL EXCEPTION: main
11-13 16:34:53.088: E/AndroidRuntime(1964): Process: appname, PID: 1964
11-13 16:34:53.088: E/AndroidRuntime(1964): java.lang.NullPointerException
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.TextView.makeNewLayout(TextView.java:6124)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.TextView.onMeasure(TextView.java:6419)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.View.measure(View.java:16458)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.Spinner.setUpChild(Spinner.java:632)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.Spinner.makeView(Spinner.java:585)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.Spinner.getBaseline(Spinner.java:431)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.LinearLayout.measureHorizontal(LinearLayout.java:1262)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.LinearLayout.onMeasure(LinearLayout.java:590)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.View.measure(View.java:16458)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1404)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.LinearLayout.measureVertical(LinearLayout.java:695)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.LinearLayout.onMeasure(LinearLayout.java:588)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.View.measure(View.java:16458)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.View.measure(View.java:16458)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125)
11-13 16:34:53.088: E/AndroidRuntime(1964): at com.android.internal.widget.ActionBarOverlayLayout.onMeasure(ActionBarOverlayLayout.java:327)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.View.measure(View.java:16458)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-13 16:34:53.088: E/AndroidRuntime(1964): at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2289)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.View.measure(View.java:16458)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:1914)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1111)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1293)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:998)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5582)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.Choreographer.doCallbacks(Choreographer.java:562)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.Choreographer.doFrame(Choreographer.java:532)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.os.Handler.handleCallback(Handler.java:733)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.os.Handler.dispatchMessage(Handler.java:95)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.os.Looper.loop(Looper.java:137)
11-13 16:34:53.088: E/AndroidRuntime(1964): at android.app.ActivityThread.main(ActivityThread.java:4998)
11-13 16:34:53.088: E/AndroidRuntime(1964): at java.lang.reflect.Method.invokeNative(Native Method)
11-13 16:34:53.088: E/AndroidRuntime(1964): at java.lang.reflect.Method.invoke(Method.java:515)
11-13 16:34:53.088: E/AndroidRuntime(1964): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
11-13 16:34:53.088: E/AndroidRuntime(1964): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
11-13 16:34:53.088: E/AndroidRuntime(1964): at dalvik.system.NativeStart.main(Native Method)
Просматривая исходный код 4.4 TextView в строке 6124, выясняется, что это вызвано отсутствием параметров макета при эллипсе. Это странно, так как код не работает внутри ListAdapter
, где вы не задаете параметры макета в getView
.
Я использовал для раздувания android.R.layout.simple_spinner_item
для стандартных элементов-счетчиков. Похоже, этот элемент использует ellipsing
. Поэтому в моем getView
теперь я вызываю:
view.setEllipsize(null);
Это устраняет мои проблемы на Android 4.4.
Edit
Оказывается, проблема заключается не в эллипсировании, а в неправильном надувании вида в getView
.
inflater.inflate(android.R.layout.simple_spinner_item, null);//WRONG
inflater.inflate(android.R.layout.simple_spinner_item, parent, false);//GOOD
Обратите внимание, что вы поставляете false
, чтобы сразу не привязывать представление к родительскому объекту, потому что это адаптер, который при необходимости прикрепляет детей. В противном случае вы получите ошибки.
Когда вы правильно надуваете, вам не нужно устанавливать ellipseSize
на null
. Это связано с тем, что когда вы надуваете хороший путь с родителем, он правильно обрабатывает LayoutParams
, заставляя код эллипса не поднимать NullPointerException
.
Итак, раздуйте правильно, а затем вам больше не придется беспокоиться.
Проверьте места, где у вас могут быть недопустимые приведения типов при манипулировании вашими представлениями в коде. У меня была такая же ошибка с этой строкой
picture.setLayoutParams(new ViewGroup.LayoutParams(50, 50));
Хореограф выбрасывал эту ошибку: "android.view.ViewGroup $LayoutParams нельзя отбрасывать в android.widget.LinearLayout $LayoutParams"
изменив его на
picture.setLayoutParams(new android.widget.LinearLayout.LayoutParams(50, 50));
чтобы устранить проблему.