2013-04-17 2 views
4

Я хочу реализовать виджет вида поиска панели действий Шерлока. Моя проблема - OnOptionItemSelected элемента поиска. Я получаю исключение нулевого указателя в деятельности библиотеки.Исключительное исключение указателя в панели инструментов sherlock.

XML-меню:

<item android:id="@+id/menu_search" 
     android:actionViewClass="com.actionbarsherlock.widget.SearchView" 
     android:icon="@android:drawable/ic_menu_search" 
/> 

Фрагмент кода для меню опций:

public boolean onCreateOptionsMenu(Menu menu) 
{ 
    MenuInflater inflater = getSupportMenuInflater(); 
    inflater.inflate(R.menu.tvguide_menu, menu); 
    MenuItem mSearch = menu.findItem(R.id.menu_search); 
    searchView = new SearchView(getSupportActionBar().getThemedContext()); 
    searchView.setQueryHint("Search for countries…"); 
    searchView.setOnQueryTextListener(this); 
    mSearch.setActionView(searchView); 
    mSearch.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM | 
      MenuItem.SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW); 
} 

Я получаю вынужденная близко щелкать через поиск андроида. Я поделился своим журналом ниже

04-17 15:10:08.508: E/AndroidRuntime(23283): FATAL EXCEPTION: main 
04-17 15:10:08.508: E/AndroidRuntime(23283): java.lang.NullPointerException 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.view.menu.MenuItemImpl.toString(MenuItemImpl.java:490) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at java.lang.StringBuilder.append(StringBuilder.java:202) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.actionbarsherlock.app.SherlockFragmentActivity.onMenuItemSelected(SherlockFragmentActivity.java:201) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:953) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.view.menu.MenuBuilder.dispatchMenuItemSelected(MenuBuilder.java:735) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:149) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:874) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.view.menu.ActionMenuView.invokeItem(ActionMenuView.java:491) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.view.menu.ActionMenuItemView.onClick(ActionMenuItemView.java:110) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at android.view.View.performClick(View.java:3511) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at android.view.View$PerformClick.run(View.java:14105) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at android.os.Handler.handleCallback(Handler.java:605) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at android.os.Handler.dispatchMessage(Handler.java:92) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at android.os.Looper.loop(Looper.java:137) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at android.app.ActivityThread.main(ActivityThread.java:4438) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at java.lang.reflect.Method.invokeNative(Native Method) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at java.lang.reflect.Method.invoke(Method.java:511) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
04-17 15:10:08.508: E/AndroidRuntime(23283): at dalvik.system.NativeStart.main(Native Method) 
+0

stacktrace от logcat пожалуйста? –

+0

Я поделился с PLS. – user1526671

+0

ошибка logcat, которую вы добавили, не отображается PLS, проверьте это –

ответ

6

Это ошибка в версии 4.3.0 от ActionBarSherlock, я установил его таким образом (вы должны закомментировать строку 201 из ActionBarSherlock/SRC/COM/ActionBarSherlock/приложение/SherlockFragmentActivity.java:

--- a/actionbarsherlock/src/com/actionbarsherlock/app/SherlockFragmentActivity.java 
+++ b/actionbarsherlock/src/com/actionbarsherlock/app/SherlockFragmentActivity.java 
@@ -198,7 +198,7 @@ public class SherlockFragmentActivity extends Watson implements OnActionModeStar 

    @Override 
    public final boolean onMenuItemSelected(int featureId, android.view.MenuItem item) { 
-  if (BuildConfig.DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " + featureId + ", item: " + item); 
+  // if (BuildConfig.DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " + featureId + ", item: " + item); 

     if (featureId == Window.FEATURE_OPTIONS_PANEL && !mIgnoreNativeSelected) { 
      mIgnoreNativeSelected = true; 
8

проблема заключается в том, что ваш Menu элемент не указать заголовок, а в строке:

@Override 
public final boolean onMenuItemSelected(int featureId, android.view.MenuItem item) { 
    if (BuildConfig.DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " 
      + featureId + ", item: " + item); 
    ... 
} 

item Виль л inkove в toString() метод, который:

@Override 
public String toString() { 
    return mTitle.toString(); 
} 

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

android:title="" 

для MenuItem.

Кроме того, этого не произойдет при выпуске приложения.

0

В случае, если кто сталкивается с этой проблемой и хочет создать пункт меню без названия, это NullPointerException может быть решен путем простого изменения метода toString() в com/android/internal/view/menu/MenuItemImpl классе из исходного ActionBarSherlock кода, чтобы сделать нулевую проверку строки перед возвращением:

@Override 
public String toString() { 
    return (mTitle != null)? mTitle.toString(): ""; 
} 
Смежные вопросы