Вчера я конвертировал приложение из ActionBarSherlock в ActionBarCompat. У меня были некоторые проблемы, но ничего серьезного.
У меня есть некоторые комментарии:
Чтобы обновить темы, мне просто нужно переопределить «Шерлока», чтобы «AppCompat». Например, вместо наследования из @ style/Theme.Sherlock.Light.DarkActionBar, я наследую от @ style/Theme.AppCompat.Light.DarkActionBar.
Для деталей действия, просто обновить этот путь:
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:yourapp="http://schemas.android.com/apk/res-auto" >
<item android:id="@+id/action_search"
android:icon="@drawable/ic_action_search"
android:title="@string/action_search"
yourapp:showAsAction="ifRoom" />
...
</menu>
И в onCreateOptionsMenu, используйте обычную MenuItem, но использовать статические методы MenuItemCompat делать вещи ActionBar в. Например: MenuItemCompat.expandActionView (searchMenuItem);
Если вы используете RoboGuice, наследующий RoboSherlockActivity, у вас возникнут проблемы, если вы просто скопируете его и перейдете в ActionBarActivity. Вот мое решение:
public class RoboActionBarActivity extends ActionBarActivity implements RoboContext {
protected EventManager eventManager;
protected HashMap<Key<?>, Object> scopedObjects = new HashMap<Key<?>, Object>();
@Inject
ContentViewListener ignored; // BUG find a better place to put this
@Override
protected void onCreate(Bundle savedInstanceState) {
final RoboInjector injector = RoboGuice.getInjector(this);
eventManager = injector.getInstance(EventManager.class);
injector.injectMembersWithoutViews(this);
super.onCreate(savedInstanceState);
eventManager.fire(new OnCreateEvent(savedInstanceState));
}
@Override
public void setContentView(int layoutResID) {
super.setContentView(layoutResID);
contentViewChanged();
}
@Override
public void setContentView(View view) {
super.setContentView(view);
contentViewChanged();
}
@Override
public void setContentView(View view, ViewGroup.LayoutParams params) {
super.setContentView(view, params);
contentViewChanged();
}
@Override
public void addContentView(View view, ViewGroup.LayoutParams params) {
super.addContentView(view, params);
contentViewChanged();
}
private void contentViewChanged() {
RoboGuice.getInjector(this).injectViewMembers(this);
eventManager.fire(new OnContentChangedEvent());
}
@Override
protected void onRestart() {
super.onRestart();
eventManager.fire(new OnRestartEvent());
}
@Override
protected void onStart() {
super.onStart();
eventManager.fire(new OnStartEvent());
}
@Override
protected void onResume() {
super.onResume();
eventManager.fire(new OnResumeEvent());
}
@Override
protected void onPause() {
super.onPause();
eventManager.fire(new OnPauseEvent());
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
eventManager.fire(new OnNewIntentEvent());
}
@Override
protected void onStop() {
try {
eventManager.fire(new OnStopEvent());
} finally {
super.onStop();
}
}
@Override
protected void onDestroy() {
try {
eventManager.fire(new OnDestroyEvent());
} finally {
try {
RoboGuice.destroyInjector(this);
} finally {
super.onDestroy();
}
}
}
@Override
public void onConfigurationChanged(Configuration newConfig) {
final Configuration currentConfig = getResources().getConfiguration();
super.onConfigurationChanged(newConfig);
eventManager.fire(new OnConfigurationChangedEvent(currentConfig, newConfig));
}
@Override
public void onContentChanged() {
super.onContentChanged();
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
eventManager.fire(new OnActivityResultEvent(requestCode, resultCode, data));
}
@Override
public Map<Key<?>, Object> getScopedObjectMap() {
return scopedObjects;
}
}
Теперь вы начинаете ActionMode с supportStartActionMode() и импортирует ActionMode из пакета библиотеки.
Чтобы использовать SearchView, что вам нужно сделать что-то вроде этого:
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/search"
app:actionViewClass="android.support.v7.widget.SearchView"
android:icon="@drawable/abc_ic_search"
app:showAsAction="always|collapseActionView"
android:title="@string/search"/>
</menu>
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.search_menu, menu);
searchMenuItem = menu.findItem(R.id.search);
searchView = (SearchView) MenuItemCompat.getActionView(searchMenuItem);
if (searchView != null) {
searchView.setIconifiedByDefault(false);
SearchView.OnQueryTextListener queryTextListener = new SearchView.OnQueryTextListener() {
public boolean onQueryTextChange(String newText) {
return true;
}
public boolean onQueryTextSubmit(String query) {
doSomething(query);
return true;
}
};
searchView.setOnQueryTextListener(queryTextListener);
}
return super.onCreateOptionsMenu(menu);
}
Другие вещи работают без изменений, но пакет импорта.
Более подробную информацию вы можете найти здесь: http://developer.android.com/guide/topics/ui/actionbar.html.
Я очень хочу узнать ваш опыт работы с совместимостью ActionBar и Nav drawer, я также использовал Nav drawer и ABS, и он работает нормально. –
Работает отлично, за исключением пунктов меню. Проверьте этот ответ для правильного синтаксиса http://stackoverflow.com/questions/17913311/is-it-possible-to-have-a-action-bar-menu-using-the-appcompat-library – Zeezer
AppMart Drawer Nav очень медленный даже на моей M860 Motorola я пробовал некоторые пользовательские библиотеки Drawer, и их производительность намного лучше. – Singgum3b