【问题标题】:Starting FragmentActivity from Activity with Intent从带有 Intent 的 Activity 启动 FragmentActivity
【发布时间】:2012-08-01 21:02:19
【问题描述】:

每次我尝试使用 Intent 从 Activity 启动 FragmentActivity 时,我都会强制关闭。以下是 Activity 的代码:

Intent intent = new Intent(getApplicationContext(), OrgHome.class);
intent.putExtra("Username", organization_name.getText().toString());
startActivity(intent);

这是 logcat:

08-01 16:52:45.823: E/AndroidRuntime(600): FATAL EXCEPTION: main
08-01 16:52:45.823: E/AndroidRuntime(600): java.lang.NoClassDefFoundError: com.project3.organizations.OrgHome
08-01 16:52:45.823: E/AndroidRuntime(600):  at com.project3.organizations.MainActivity$1$1.mobDBResponse(MainActivity.java:76)
08-01 16:52:45.823: E/AndroidRuntime(600):  at com.mobdb.android.MobDBRequest.onPostExecute(MobDBRequest.java:78)
08-01 16:52:45.823: E/AndroidRuntime(600):  at com.mobdb.android.MobDBRequest.onPostExecute(MobDBRequest.java:1)
08-01 16:52:45.823: E/AndroidRuntime(600):  at android.os.AsyncTask.finish(AsyncTask.java:417)
08-01 16:52:45.823: E/AndroidRuntime(600):  at android.os.AsyncTask.access$300(AsyncTask.java:127)
08-01 16:52:45.823: E/AndroidRuntime(600):  at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
08-01 16:52:45.823: E/AndroidRuntime(600):  at android.os.Handler.dispatchMessage(Handler.java:99)
08-01 16:52:45.823: E/AndroidRuntime(600):  at android.os.Looper.loop(Looper.java:123)
08-01 16:52:45.823: E/AndroidRuntime(600):  at android.app.ActivityThread.main(ActivityThread.java:3683)
08-01 16:52:45.823: E/AndroidRuntime(600):  at java.lang.reflect.Method.invokeNative(Native Method)
08-01 16:52:45.823: E/AndroidRuntime(600):  at java.lang.reflect.Method.invoke(Method.java:507)
08-01 16:52:45.823: E/AndroidRuntime(600):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
08-01 16:52:45.823: E/AndroidRuntime(600):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
08-01 16:52:45.823: E/AndroidRuntime(600):  at dalvik.system.NativeStart.main(Native Method)
08-01 16:52:48.053: I/Process(600): Sending signal. PID: 600 SIG: 9

OrgHome.class 在清单中正确定义。这是怎么回事?

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.project3.organizations"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />
    <uses-permission android:name="android.permission.INTERNET"/>

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="OrgHome"></activity>
    </application>

</manifest>

【问题讨论】:

  • 你怎么知道“OrgHome.class 在 manifest 中定义正确”?
  • OrgHome.java 顶部的 package 声明是什么?
  • @Eric package com.project3.organizations;
  • 您使用 getApplicationContext() 的任何特殊原因?如果您从 Activity 启动它,最好使用“this”(因为 Activity 子类 Context),而且我知道使用 getAppCtx() 时会发生奇怪的事情
  • @mfrankli thisGAC() 在这种情况下应该做同样的事情

标签: android android-fragmentactivity


【解决方案1】:

更改清单:

如果 OrgHome 与 MainActivity 位于同一位置,则使用此选项

<activity android:name=".OrgHome" />

如果它在子文件夹中,请使用它

<activity android:name=".sub.path.to.OrgHome" />

或者指定整个路径

<activity android:name="entire.path.to.OrgHome" />

【讨论】:

  • 我使用 WYSIWYG 编辑器添加了类,所以我觉得它不应该像这样出错,但我会添加 .,因为它在同一个文件夹中
  • 清单中的定义本身并没有错。我相信,这只是你如何定义它和你如何称呼它的结合。这个答案绝对是解决它的最佳方法。
  • 您是否更改了文件路径?如果您在包之间移动它们,WYSIWYG 编辑器不会进行引用更改。
  • @DeeV 不,我没有更改路径。这两个文件都在同一个包目录中。
【解决方案2】:

为了解决您应该编写的片段活动 (getactivity(),nameofOtherActivity.class);你应该没事。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-08-25
    • 1970-01-01
    • 2017-07-20
    • 1970-01-01
    • 1970-01-01
    • 2012-10-23
    • 2017-06-21
    相关资源
    最近更新 更多