【问题标题】:Action_Send Intent not work for ActivityAction_Send Intent 不适用于 Activity
【发布时间】:2015-11-09 22:24:57
【问题描述】:

我使用此代码分享我的内容。我不能将其用于我的活动,但我可以将其用于我的片段!当我在我的活动中调用它时,应用程序崩溃了!请帮助我,谢谢。

Intent sharingIntent = new Intent(android.content.Intent.ACTION_SEND);
                sharingIntent.setType("text/plain");
                String shareBody = itemsArrayList.get(position).getDes();
                //sharingIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, "Subject Here");
                sharingIntent.putExtra(android.content.Intent.EXTRA_TEXT, shareBody);
                context.startActivity(Intent.createChooser(sharingIntent, "اشتراک با"));

我的 logcat 错误:

11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 致命异常: main 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: android.util.AndroidRuntimeException: 从 Activity 上下文外部调用 startActivity() 需要 FLAG_ACTIVITY_NEW_TASK 标志。这真的是你想要的吗? 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.app.ContextImpl.startActivity(ContextImpl.java:1244) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.app.ContextImpl.startActivity(ContextImpl.java:1231) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: at com.katibehpayam.mahdi.katibehpayam.adapter_common$4.onClick(adapter_common.java:138) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.view.View.performClick(View.java:4377) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.view.View$PerformClick.run(View.java:18044) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.os.Handler.handleCallback(Handler.java:725) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.os.Handler.dispatchMessage(Handler.java:92) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.os.Looper.loop(Looper.java:137) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 android.app.ActivityThread.main(ActivityThread.java:5306) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 java.lang.reflect.Method.invokeNative(Native Method) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 java.lang.reflect.Method.invoke(Method.java:511) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869) 11-10 01:57:32.597 11723-11723/com.katibehpayam.mahdi.katibehpayam E/AndroidRuntime: at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

  • 请分享您的 logcat 错误。
  • 好的,补充说 Deepak Goyal。
  • 尝试使用getActivity() 而不是context....告诉我....
  • Deepak Goyal ,还没有工作。

标签: android


【解决方案1】:

任何时候您不使用活动作为您的上下文,您都必须包含标志 FLAG_ACTIVITY_NEW_TASK,如错误所述。由于您是从片段中执行此操作,因此您必须添加:

sharingIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

【讨论】:

  • logcat 现在的输出是什么?
  • 我添加了第二个 logcat。
  • 该错误不应该仍然出现。发布您的更新代码。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多