AndroidRuntimeException:在添加Honeycomb 3.1 - 3.2.1独有的内容之前,必须调用requestFeature()

时间:2013-10-07 07:43:55

标签: android exception oncreate android-actionbar-compat

上次更新后,我的应用存在以下问题:

java.lang.RuntimeException: Unable to start activity ComponentInfo{my.package/my.package.MyMainActivity}: android.util.AndroidRuntimeException: requestFeature() must be called before adding content
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1818)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1834)
at android.app.ActivityThread.access$500(ActivityThread.java:122)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1027)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:132)
at android.app.ActivityThread.main(ActivityThread.java:4126)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:491)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:844)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
at dalvik.system.NativeStart.main(Native Method)
Caused by: android.util.AndroidRuntimeException: requestFeature() must be called before adding content
at com.android.internal.policy.impl.PhoneWindow.requestFeature(PhoneWindow.java:214)
at android.support.v7.app.ActionBarActivityDelegateHC.onCreate(ActionBarActivityDelegateHC.java:38)
at android.support.v7.app.ActionBarActivity.onCreate(ActionBarActivity.java:98)
at my.package.MyBaseActivity.onCreate(MyBaseActivity.java:68)
at my.package.MyApiServiceActivity.onCreate(MyApiServiceActivity.java:51)
at my.package.MyActivity.onCreate(MyActivity.java:88)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1050)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1782)
... 11 more

但是,我从不打电话给requestWindowFeature或类似的人。也没有涉及对话。该报告本身来自BugSense,我自己从未遇到过这个问题。这是一个相当受欢迎的应用程序,问题是独占到Android Honeycomb :3.2,3.2.1和3.1。它在以前版本的应用程序中没有发生。自更新以来onCreate功能的唯一变化是我从ActionBarSherlock切换到ActionBarCompat

任何人都发现了这个问题和/或有任何想法如何克服这个问题?

修改 我正在从v7包添加the source for ActionBarActivityDelegateHC的链接,其中崩溃堆栈跟踪(由...引起)开始。在那里发生了r​​equestFeature调用,但它被正确调用,甚至在super.onCreate之前。

我使用Gradle导入包:compile 'com.android.support:appcompat-v7:18.0.+'

1 个答案:

答案 0 :(得分:6)

所以看起来@shomeser的解决方案(对问题的评论)是一种暂时的方法。

有两种妥协方式:

  • 如果横向和纵向没有不同的布局,则可以禁用方向更改(在AndroidManifest中:android:configChanges="screenSize|orientation"
  • 如果您对方向更改有一些处理而无法使用“configChanges”,则可以锁定方向(onCreate
    if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB
            || Build.VERSION.SDK_INT <= Build.VERSION_CODES.HONEYCOMB_MR2)
    {
        this.setRequestedOrientation( ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
    }
  • 最后我最不喜欢(虽然发布此内容已完成),请删除ABC并返回ABS。

我还发布了一个ticket on Android Issue Tracker,但这是一个Honeycomb问题,我不希望得到答案。

更新:在针对特定Honeycomb设备发布具有锁定方向的应用后,我仍然看到报告此崩溃,但频率较低。

更新2: 问题已修复!现在只需等待新支持库的发布:google issue tracker