私は現在、バージョン 4.2.0 の ActionbarSherlock を Android アプリケーションに実装しています。そして、SearchView ウィジェットに問題があります。
現在、ウィジェットを次のように実装しています。
import com.actionbarsherlock.app.ActionBar.Tab;
import com.actionbarsherlock.app.SherlockFragmentActivity;
import com.actionbarsherlock.view.Menu;
import com.actionbarsherlock.view.MenuItem;
import com.actionbarsherlock.widget.SearchView;
import com.actionbarsherlock.widget.SearchView.OnQueryTextListener;
public class MainActivity extends SherlockFragmentActivity
{
/*...*/
@Override
public boolean onCreateOptionsMenu(Menu menu) {
SearchView searchView = new SearchView(getSupportActionBar().getThemedContext());
searchView.setQueryHint(getResources().getString(R.string.searchHint_Label));
searchView.setIconifiedByDefault(true);
searchView.setOnQueryTextListener(new OnQueryTextListener(){
@Override
public boolean onQueryTextSubmit(String query) {
// Do stuff
}
@Override
public boolean onQueryTextChange(String newText) {
// TODO Auto-generated method stub
return false;
}
});
menu.add("Search")
.setIcon(R.drawable.abs__ic_search)
.setActionView(searchView)
.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM | MenuItem.SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW);
return true;
}
}
アプリケーションのデバッグを開始するたびに、SearchView のコンストラクターで次のエラーが発生します。
01-01 11:46:40.365: E/dalvikvm(1385): Could not find class 'com.actionbarsherlock.widget.SearchView$11', referenced from method com.actionbarsherlock.widget.SearchView.<init>
Call Stack:
Thread [<1> main] (Suspended (exception ClassNotFoundException))
<VM does not provide monitor information>
PathClassLoader.findClass(String) line: 240
PathClassLoader(ClassLoader).loadClass(String, boolean) line: 551
PathClassLoader(ClassLoader).loadClass(String) line: 511
DexFile.defineClass(String, ClassLoader, int, ProtectionDomain) line: not available [native method]
DexFile.loadClassBinaryName(String, ClassLoader) line: 207
PathClassLoader.findClass(String) line: 200
PathClassLoader(ClassLoader).loadClass(String, boolean) line: 551
PathClassLoader(ClassLoader).loadClass(String) line: 511
MainActivity.onCreateOptionsMenu(Menu) line: 124
MainActivity(Watson).onCreatePanelMenu(int, Menu) line: 45
ActionBarSherlockCompat(ActionBarSherlock).callbackCreateOptionsMenu(Menu) line: 559
ActionBarSherlockCompat.preparePanel() line: 479
ActionBarSherlockCompat.dispatchInvalidateOptionsMenu() line: 272
ActionBarSherlockCompat$1.run() line: 984
ViewRoot(Handler).handleCallback(Message) line: 587
ViewRoot(Handler).dispatchMessage(Message) line: 92
Looper.loop() line: 130
ActivityThread.main(String[]) line: 3683
Method.invokeNative(Object, Object[], Class, Class[], Class, int, boolean) line: not available [native method]
Method.invoke(Object, Object...) line: 507
ZygoteInit$MethodAndArgsCaller.run() line: 839
ZygoteInit.main(String[]) line: 597
NativeStart.main(String[]) line: not available [native method]
このエラーは、アプリケーションでサポートしているすべての Android バージョン (2.2 - 4.2) で発生します。この例外が発生した後にデバッグを再開すると、アプリケーションは正常に動作し、SearchView も正常に動作しますが、なぜこの例外が発生するのか疑問に思っています。