Android アプリを新しい Facebook 3.0 API と統合しようとしていますが、次の例外が発生します。
java.lang.RuntimeException: アクティビティを再開できません {dk.imu.konnekt/com.facebook.LoginActivity}: com.facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。
私はこのエラーを検索しましたが、他の誰も問題を抱えていないようです。タブごとに TabHost と TabsGroupActivities を使用しているためだと思います。しかし、私はそれを解決する方法についての手がかりがありません。
関連するコードをここに追加しました。
public class MainTabActivity extends TabActivity {
public void onCreate(Bundle savedInstanteState){
super.onCreate(savedInstanteState);
setContentView(R.layout.tab_layout);
TabHost tabHost = getTabHost();
View shareTab = getLayoutInflater().inflate(R.layout.share_tab, null);
tabHost.addTab(tabHost.newTabSpec("Share").setIndicator(shareTab)
.setContent(new Intent(MainTabActivity.this, ShareGroupActivity.class)));
...
}
}
-
public class ShareGroupActivity extends TabsGroupActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
startChildActivity("ShareActivity", new Intent(this, ShareActivity.class));
}
}
-
public class ShareActivity extends BaseActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.share);
testFacebookConnection();
}
public void testFacebookConnection(){
Session session = new Session(this);
Session.setActiveSession(session);
SessionState state = session.getState();
Settings.addLoggingBehavior(LoggingBehavior.INCLUDE_ACCESS_TOKENS);
Session.StatusCallback statusCallback =
new Session.StatusCallback() {
@Override
public void call(Session session, SessionState state, Exception exception) {
Toast.makeText(ShareActivity.this, "Facebook session status changed", Toast.LENGTH_SHORT).show();
}
};
if (!session.isOpened() && !session.isClosed() && session.getState() != SessionState.OPENING) {
OpenRequest open = new OpenRequest(this).setCallback(statusCallback);
List<String> permission = new ArrayList<String>();
permission.add("publish_actions");
open.setPermissions(permission);
session.openForPublish(open);
} else {
Session.openActiveSession(this, true, statusCallback);
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
Session.getActiveSession().onActivityResult(this, requestCode, resultCode, data);
}
}
それを解決する方法の手がかりはありますか?
1 つのスタック トレースを更新します。
致命的な例外: main java.lang.RuntimeException: アクティビティを再開できません {dk.imu.konnekt/com.facebook.LoginActivity}: com.facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。android.app.ActivityThread.performResumeActivity(ActivityThread.java:2812) で android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2851) で android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2234) で android.app. ActivityThread.access$600(ActivityThread.java:139) で android.app.ActivityThread$H.handleMessage(ActivityThread.java:1261) で android.os.Handler.dispatchMessage(Handler.java:99) android.os.Looper.loop (Looper.java:154) android.app.ActivityThread.main(ActivityThread.java:4945) で java.lang.reflect.Method で。java.lang.reflect.Method.invoke(Method.java:511) の invokeNative(ネイティブ メソッド) com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) の com.android.internal. os.ZygoteInit.main(ZygoteInit.java:551) at dalvik.system.NativeStart.main(Native Method) 原因: com.facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) at dalvik.system.NativeStart.main(Native Method) 原因: com. facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) at dalvik.system.NativeStart.main(Native Method) 原因: com. facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る
更新 2: コードを調べたところ、startChildActivity の実装が見つかりました。
public void startChildActivity(String Id, Intent intent) {
Window window = getLocalActivityManager().startActivity(Id,intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP));
if (window != null) {
mIdList.add(Id);
setContentView(window.getDecorView());
}
}
フラグ FLAG_ACTIVITY_CLEAR_TOP を使用します。削除しようとしましたが、結果に変化はありませんでした。
更新 3:
Facebookコードは使用します
callingPackage = getCallingPackage();
と
if (callingPackage == null) {
throw new FacebookException(NULL_CALLING_PKG_ERROR_MSG);
}
http://developer.android.com/reference/android/app/Activity.html#getCallingPackage()
このメソッドには次の注意事項があります。
呼び出し元のアクティビティが結果を予期していない場合 (つまり、要求コードを含む startActivityForResult(Intent, int) フォームを使用しなかった場合)、呼び出し元のパッケージは null になります。
メソッド startChildActivity では、ActivityGroup を拡張する TabsGroupActivity で getLocalActivityManager().startActivity を使用して、タブ アクティビティを処理します。 http://developer.android.com/reference/android/app/LocalActivityManager.html#startActivity(java.lang.String, android.content.Intent)
この方法は、メモに記載されていることではありません。結果を期待せず、startActivityForResult メソッドを使用しません。このメソッドは、singleinstance launchmode に似たものも保証します。このメソッドの実装をどのように変更すれば、Facebook で動作するようになりますか?