2013-08-12 9 views
6

do tej pory nie miałem większych problemów z przejściem od ActionBarSherlock do ActionBarCompat. Na moim Nexusie 4 działa całkiem nieźle. Kiedy zacząłem testować na moim starszym Nexusie z systemem 2.3.6, podczas obracania urządzenia wystąpił problem. Proszę o funkcję okna, aby pokazać pośredni postęp w pasku akcji:Używanie ActionBarCompat i 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()); 

} 

Działa to całkiem dobrze na Jelly Bean.

Na 2.3.6 jest uzyskać ten ślad stosu:

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 

Ktoś wie jak to naprawić?

pozdrowienia

Odpowiedz

0

Zastosowanie supportRequestWindowFeature(WindowCompat.FEATURE_xxx)

to też trzeba używać WindowCompat.FEATURE_xxx zamiast Window.FEATURE_xxx wstecznej comptability.

0

Dla tych, którzy nie nazywają requestWindowFeature() metody, ale nadal pojawia się wyjątek, spróbuj tego rozwiązania:

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

widzieć https://code.google.com/p/android/issues/detail?id=60841

0

Error log wyraźnie mówi „requestFeature() musi być wywołana przed dodaniem zadowolony'. Musisz więc zadzwonić "super.onCreate (savedInstanceState);" po wywołaniach "requestWindowFeature". I nie ma potrzeby wywoływania funkcji supportRequestWindowFeature (Window.FEATURE _...), jak wspomniano powyżej. Zobacz działający kod poniżej.

@Override 
    public void onCreate(Bundle savedInstanceState) { 
     requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS); 
     requestWindowFeature(Window.FEATURE_PROGRESS); 
     super.onCreate(savedInstanceState); 
Powiązane problemy