在Android 4.0(API Level 14)中,通过ActionProvider的介绍,可以在ActionBar中更容易地实现一个有效且用户友好的share action。对于一个ActionProvider,一旦在操作栏中附加到一个菜单项,就要处理菜单项的样式和动作。ShareActionProvider的出现,使你可以提供一个共享的Intent,它会完成剩余的工作。
注意:ShareActionProvider只能在API版本为14或更高的版本中使用。
更新菜单声明:
在使用ShareActionProvider时,首先在你的菜单资源文件中的item标签下定义android:actionProviderClass属性:
<menu xmlns:android="http://schemas.android.com/apk/res/android"> <item android:id="@+id/menu_item_share" android:showAsAction="ifRoom" android:title="Share" android:actionProviderClass="android.widget.ShareActionProvider" /> ... </menu>
这会向ShareActionProvider声明菜单项的外观和功能所需的职责。然而,你也需要告诉提供者(provider)你想要共享的内容。
设置共享Intent:
为了使ShareActionProvider运用到功能中,必须提供一个共享Intent。共享Intent应该与SendingContent to Other Apps课程所描述的一致,要用到ACTION_SEND动作,并且通过类似EXTRA_TEXT、EXTRA_STREAM的extras设置附加数据。要想指定一个共享Intent,首先在Activity或Fragment中填充menu资源时找到相匹配的MenuItem。然后调用MenuItem.getActionProvider()方法检索ShareActionProvider的实例。使用setShareIntent()更新与action条目相关的共享Intent。下面是一个例子:
private ShareActionProvider mShareActionProvider; ... @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate menu resource file. getMenuInflater().inflate(R.menu.share_menu, menu); // Locate MenuItem with ShareActionProvider MenuItem item = menu.findItem(R.id.menu_item_share); // Fetch and store ShareActionProvider mShareActionProvider = (ShareActionProvider) item.getActionProvider(); // Return true to display menu return true; } // Call to update the share intent private void setShareIntent(Intent shareIntent) { if (mShareActionProvider != null) { mShareActionProvider.setShareIntent(shareIntent); } }
在创建菜单期间,设置共享Intent可能只需要一次;或者在设置之后随着UI的改变而更新。例如,在Gallery应用中,当你全屏浏览照片时,共享Intent就会随着照片切换而不断更新。
对于ShareActionProvider更深入的探讨,参考Action Bar指南。
原文链接:https://developer.android.com/training/sharing/shareaction.html#set-share-intent