2013-08-12 2 views
6

до сих пор у меня не было больше проблем с переходом от ActionBarSherlock к ActionBarCompat. На моем Nexus 4 он работает очень хорошо. Когда я начал тестировать свой старый Nexus One под управлением 2.3.6, я столкнулся с проблемой при повороте устройства. Я запросить функцию окна, чтобы показать промежуточный прогресс в ActionBar:Использование ActionBarCompat и requestWindowFeature

@Override 
protected void onCreate(final Bundle savedInstanceState) 
{ 
    super.onCreate(savedInstanceState); 

    requestWindowFeature(android.view.Window.FEATURE_PROGRESS); 
    requestWindowFeature(android.view.Window.FEATURE_INDETERMINATE_PROGRESS); 

    setupActionBar(getSupportActionBar()); 

} 

Это работает очень хорошо на Jelly Bean.

На 2.3.6 это получить этот трассировки стека:

08-12 13:34:09.242: E/AndroidRuntime(4602): FATAL EXCEPTION: main 
08-12 13:34:09.242: E/AndroidRuntime(4602): java.lang.RuntimeException: Unable to start activity ComponentInfo{net.app.packagename/net.app.fragment.CustomActivity}: android.util.AndroidRuntimeException: requestFeature() must be called before adding content 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:2832) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.ActivityThread.access$1600(ActivityThread.java:117) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.os.Handler.dispatchMessage(Handler.java:99) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.os.Looper.loop(Looper.java:130) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.ActivityThread.main(ActivityThread.java:3683) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at java.lang.reflect.Method.invokeNative(Native Method) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at java.lang.reflect.Method.invoke(Method.java:507) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at dalvik.system.NativeStart.main(Native Method) 
08-12 13:34:09.242: E/AndroidRuntime(4602): Caused by: android.util.AndroidRuntimeException: requestFeature() must be called before adding content 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at com.android.internal.policy.impl.PhoneWindow.requestFeature(PhoneWindow.java:181) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.Activity.requestWindowFeature(Activity.java:2729) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at net.app.fragment.BaseFragmentActivity.onCreate(BaseFragmentActivity.java:50) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at net.app.fragment.CustomActivity.onCreate(CustomActivity.java:55) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
08-12 13:34:09.242: E/AndroidRuntime(4602):  ... 12 more 
08-12 13:34:12.092: I/Process(4602): Sending signal. PID: 4602 SIG: 9 

Каждый знает, как это исправить?

рассматривает

ответ

0

Использование supportRequestWindowFeature(WindowCompat.FEATURE_xxx)

т.е. Вы также должны использовать WindowCompat.FEATURE_xxx вместо Window.FEATURE_xxx для обратной comptability.

0

Для тех, кто не называют requestWindowFeature() метод, но все еще получаю исключение, попробуйте этот обходной путь:

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    try { 
     super.onCreate(savedInstanceState); 
    } catch (Throwable e) { 
     //dummy workaround 
    } 
    setContentView(getLayoutResId()); 

см https://code.google.com/p/android/issues/detail?id=60841

0

Журнал ошибок ясно говорит «requestFeature() должна вызываться перед добавлением содержание. Поэтому вам нужно вызвать «super.onCreate (savedInstanceState)»; после вызова 'requestWindowFeature'. И нет необходимости ссылаться на supportRequestWindowFeature (Window.FEATURE _...), как указано выше. См. Рабочий код ниже.

@Override 
    public void onCreate(Bundle savedInstanceState) { 
     requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS); 
     requestWindowFeature(Window.FEATURE_PROGRESS); 
     super.onCreate(savedInstanceState); 
Смежные вопросы