androidx.appcompat.widget.SearchView setSearchableInfo () выбрасывает ресурсы $ NotFoundException на некоторых устройствах - PullRequest
0 голосов
/ 01 ноября 2019

Я заметил несколько исключений в журналах отчетов, и я понятия не имею, в чем причина проблемы:

android.content.res.Resources$NotFoundException: 
  at android.content.res.Resources.getText (Resources.java:363)
  at android.content.Context.getText (Context.java:567)
  at androidx.appcompat.widget.SearchView.getQueryHint (SearchView.java:622)
  at androidx.appcompat.widget.SearchView.updateQueryHint (SearchView.java:1102)
  at androidx.appcompat.widget.SearchView.setSearchableInfo (SearchView.java:409)
  at com.myApp.MainActivity.onCreateOptionsMenu (MainActivity.java:161)
  at android.app.Activity.onCreatePanelMenu (Activity.java:3575)
  at androidx.fragment.app.FragmentActivity.onCreatePanelMenu (FragmentActivity.java:325)
  at androidx.appcompat.view.WindowCallbackWrapper.onCreatePanelMenu (WindowCallbackWrapper.java:94)
  at androidx.appcompat.app.AppCompatDelegateImpl$AppCompatWindowCallback.onCreatePanelMenu (AppCompatDelegateImpl.java:2830)
  at androidx.appcompat.view.WindowCallbackWrapper.onCreatePanelMenu (WindowCallbackWrapper.java:94)
  at androidx.appcompat.app.ToolbarActionBar.populateOptionsMenu (ToolbarActionBar.java:455)
  at androidx.appcompat.app.ToolbarActionBar$1.run (ToolbarActionBar.java:56)
  at android.view.Choreographer$CallbackRecord.run (Choreographer.java:949)
  at android.view.Choreographer.doCallbacks (Choreographer.java:761)
  at android.view.Choreographer.doFrame (Choreographer.java:693)
  at android.view.Choreographer$FrameDisplayEventReceiver.run (Choreographer.java:935)
  at android.os.Handler.handleCallback (Handler.java:873)
  at android.os.Handler.dispatchMessage (Handler.java:99)
  at android.os.Looper.loop (Looper.java:214)
  at android.app.ActivityThread.main (ActivityThread.java:7094)
  at java.lang.reflect.Method.invoke (Native Method)
  at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:494)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:975)

MainActivity.java

public class MainActivity extends AppCompatActivity {
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.main_activity_actions, menu);
        mainMenu = menu;
        SearchManager searchManager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
        MenuItem searchItem = menu.findItem(R.id.action_search);
        searchView = (SearchView) searchItem.getActionView();
        if(searchManager != null) {
            searchView.setSearchableInfo(searchManager.getSearchableInfo(getComponentName()));
        }
        return super.onCreateOptionsMenu(menu);
    }
}

R.menu.main_activity_actions.xml выглядит как

<menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto">
    <item android:id="@+id/action_search"
          android:title="@string/search"
          android:icon="@drawable/ic_search_white"
          android:orderInCategory="1"
          app:showAsAction="ifRoom|collapseActionView"
          app:actionViewClass="androidx.appcompat.widget.SearchView"/>
</menu>

Устройства, которые выдают исключения: Samsung Galaxy J6 + (Android 9) , Xiaomi Redmi 6A (Android 9)

Я не знаю, какое решениеправильно, потому что я пытался повторить эту проблему, но не смог этого сделать. Это исключения выбрасываются редко. Это началось после перехода на AndroidX

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...