public
final
class
ShareCompat
extends Object
java.lang.Object | |
↳ | android.support.v4.app.ShareCompat |
Extra helper functionality for sharing data between activities.
ShareCompat provides functionality to extend the ACTION_SEND
/
ACTION_SEND_MULTIPLE
protocol and support retrieving more info
about the activity that invoked a social sharing action.
ShareCompat.IntentBuilder
provides helper functions for constructing a sharing
intent that always includes data about the calling activity and app.
This lets the called activity provide attribution for the app that shared
content. Constructing an intent this way can be done in a method-chaining style.
To obtain an IntentBuilder with info about your calling activity, use the static
method from(Activity)
.
ShareCompat.IntentReader
provides helper functions for parsing the defined extras
within an ACTION_SEND
or ACTION_SEND_MULTIPLE
intent
used to launch an activity. You can also obtain a Drawable for the caller's
application icon and the application's localized label (the app's human-readable name).
Social apps that enable sharing content are encouraged to use this information
to call out the app that the content was shared from.
Nested classes | |
---|---|
class |
ShareCompat.IntentBuilder
IntentBuilder is a helper for constructing |
class |
ShareCompat.IntentReader
IntentReader is a helper for reading the data contained within a sharing (ACTION_SEND) Intent. |
Constants | |
---|---|
String |
EXTRA_CALLING_ACTIVITY
Intent extra that stores the |
String |
EXTRA_CALLING_PACKAGE
Intent extra that stores the name of the calling package for an ACTION_SEND intent. |
Public methods | |
---|---|
static
void
|
configureMenuItem(MenuItem item, ShareCompat.IntentBuilder shareIntent)
Configure a |
static
void
|
configureMenuItem(Menu menu, int menuItemId, ShareCompat.IntentBuilder shareIntent)
Configure a menu item to act as a sharing action. |
static
ComponentName
|
getCallingActivity(Activity calledActivity)
Retrieve the ComponentName of the activity that launched calledActivity from a share intent. |
static
String
|
getCallingPackage(Activity calledActivity)
Retrieve the name of the package that launched calledActivity from a share intent. |
Inherited methods | |
---|---|
From
class
java.lang.Object
|
String EXTRA_CALLING_ACTIVITY
Intent extra that stores the ComponentName
of the calling activity for
an ACTION_SEND intent.
Constant Value: "android.support.v4.app.EXTRA_CALLING_ACTIVITY"
String EXTRA_CALLING_PACKAGE
Intent extra that stores the name of the calling package for an ACTION_SEND intent.
When an activity is started using startActivityForResult this is redundant info.
(It is also provided by getCallingPackage()
.)
Instead of using this constant directly, consider using getCallingPackage(Activity)
or getCallingPackage()
.
Constant Value: "android.support.v4.app.EXTRA_CALLING_PACKAGE"
void configureMenuItem (MenuItem item, ShareCompat.IntentBuilder shareIntent)
Configure a MenuItem
to act as a sharing action.
If the app is running on API level 14 or higher (Android 4.0/Ice Cream Sandwich)
this method will configure a ShareActionProvider to provide a more robust UI
for selecting the target of the share. History will be tracked for each calling
activity in a file named with the prefix ".sharecompat_" in the application's
private data directory. If the application wishes to set this MenuItem to show
as an action in the Action Bar it should use
setShowAsAction(MenuItem, int)
to request that behavior
in addition to calling this method.
If the app is running on an older platform version this method will configure a standard activity chooser dialog for the menu item.
During the calling activity's lifecycle, if data within the share intent must change the app should change that state in one of several ways:
invalidateOptionsMenu(Activity)
. If the app is running
on API level 11 or above and uses the Action Bar its menu will be recreated and rebuilt.
If not, the activity will receive a call to onPrepareOptionsMenu(Menu)
the next time the user presses the menu key to open the options menu panel. The activity
can then call configureMenuItem again with a new or altered IntentBuilder to reconfigure
the share menu item.Parameters | |
---|---|
item |
MenuItem :
MenuItem to configure for sharing |
shareIntent |
ShareCompat.IntentBuilder :
IntentBuilder with data about the content to share
|
void configureMenuItem (Menu menu, int menuItemId, ShareCompat.IntentBuilder shareIntent)
Configure a menu item to act as a sharing action.
Parameters | |
---|---|
menu |
Menu :
Menu containing the item to use for sharing |
menuItemId |
int :
ID of the share item within menu |
shareIntent |
ShareCompat.IntentBuilder :
IntentBuilder with data about the content to share |
ComponentName getCallingActivity (Activity calledActivity)
Retrieve the ComponentName of the activity that launched calledActivity from a share intent. Apps that provide social sharing functionality can use this to provide attribution for the app that shared the content.
Note: This data may have been provided voluntarily by the calling application. As such it should not be trusted for accuracy in the context of security or verification.
Parameters | |
---|---|
calledActivity |
Activity :
Current activity that was launched to share content |
Returns | |
---|---|
ComponentName |
ComponentName of the calling activity |
String getCallingPackage (Activity calledActivity)
Retrieve the name of the package that launched calledActivity from a share intent. Apps that provide social sharing functionality can use this to provide attribution for the app that shared the content.
Note: This data may have been provided voluntarily by the calling application. As such it should not be trusted for accuracy in the context of security or verification.
Parameters | |
---|---|
calledActivity |
Activity :
Current activity that was launched to share content |
Returns | |
---|---|
String |
Name of the calling package |