使用ShareActionProvider分享数据

如果你还不知道关于android分享的基础知识,请先看:Android应用程序间的内容分享机制 一文。

ShareActionProvider其实是ActionProvider的一种。官网的说法是ShareActionProvider让分享变得更容易,不过在我看来ShareActionProvider的真正优势是更简洁漂亮。下面是传统分享界面与ShareActionProvider分享界面的对比图:

一个是对话框的形式,一个是popupmenu的形式,而且ShareActionProvider方式一次不会显示完所有的选项。

下面是官网对ShareActionProvider介绍的译文:

ActionBar上使用ActionProvider实现一个高效的友好的分享操作在Android 4.0(API等级14)上更容易了。一个ActionProvider,一旦附加到action bar的菜单上了,就会处理外观和行为上的操作,至于ShareActionProvider,你值需要提供分享intent,然后它会完成剩下的事情。

**注意:**ShareActionProvider从API等级14以及更高版本中可用。

更新菜单的声明

要使用ShareActionProviders,在菜单资源文件中为相应的定义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你需要分享什么。

图1.Gallery app中的ShareActionProvider

设置分享Intent

为了让ShareActionProvider能运行,需要提供一个分享intent。这个分享intent应该和前面讲的一致,带有ACTION_SEND操作和附加的数据,像EXTRA_TEXT或EXTRA_STREAM。要分配一个分享intent,在加载菜单资源时首先要找到相应的MenuItem。接下来,调用MenuItem.getActionProvider()来获得ShareActionProvider实例。使用setShareIntent()来更新相关的分享intent。这里有一个例子:

private ShareActionProvider mShareActionProvider;
...
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // 加载菜单资源文件
    getMenuInflater().inflate(R.menu.share_menu, menu);
    // 用ShareActionProvider定位MenuItem
    MenuItem item = menu.findItem(R.id.menu_item_share);
    // 获取并存储ShareActionProvider
    mShareActionProvider = (ShareActionProvider) item.getActionProvider();
    // 然后true来显示菜单
    return true;
}
// 调用来更新share intent
private void setShareIntent(Intent shareIntent) {
    if (mShareActionProvider != null) {
        mShareActionProvider.setShareIntent(shareIntent);
    }
}

你可能需要设置一次share intent来创建自己的菜单,或者在UI改变时设置并更新它。比如,当才Gallery app中全屏查看照片时,sharing intent会在照片切换时改变。

更多关于ShareActionProvider的信息, 查看Action bar介绍。