belongs to Maven artifact com.android.support:support-compat:28.0.0-alpha1
ShareCompat
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.
Summary
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
|
Constants
EXTRA_CALLING_ACTIVITY
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"
EXTRA_CALLING_PACKAGE
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"
Public methods
configureMenuItem
void configureMenuItem (MenuItem item, ShareCompat.IntentBuilder shareIntent)
Configure a MenuItem
to act as a sharing action.
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(int)
to request
that behavior in addition to calling this method.
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:
- Call
invalidateOptionsMenu(Activity)
. If the app uses the Action Bar its menu will be recreated and rebuilt. If not, the activity will receive a call toonPrepareOptionsMenu(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. - Keep a reference to the MenuItem object for the share item once it has been created and call configureMenuItem to update the associated sharing intent as needed.
Parameters | |
---|---|
item |
MenuItem : MenuItem to configure for sharing |
shareIntent |
ShareCompat.IntentBuilder : IntentBuilder with data about the content to share
|
configureMenuItem
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 |
getCallingActivity
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 |
getCallingPackage
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 |
Annotations
Interfaces
- ActionBarDrawerToggle.Delegate
- ActionBarDrawerToggle.DelegateProvider
- ActivityCompat.OnRequestPermissionsResultCallback
- ActivityCompat.PermissionCompatDelegate
- FragmentManager.BackStackEntry
- FragmentManager.OnBackStackChangedListener
- LoaderManager.LoaderCallbacks
- NotificationCompat.Action.Extender
- NotificationCompat.Extender
- SharedElementCallback.OnSharedElementsReadyListener
- TaskStackBuilder.SupportParentable
Classes
- ActionBarDrawerToggle
- ActivityCompat
- ActivityManagerCompat
- ActivityOptionsCompat
- AlarmManagerCompat
- AppLaunchChecker
- AppOpsManagerCompat
- BundleCompat
- DialogFragment
- Fragment
- Fragment.SavedState
- FragmentActivity
- FragmentContainer
- FragmentController
- FragmentHostCallback
- FragmentManager
- FragmentManager.FragmentLifecycleCallbacks
- FragmentManagerNonConfig
- FragmentPagerAdapter
- FragmentStatePagerAdapter
- FragmentTabHost
- FragmentTransaction
- FrameMetricsAggregator
- JobIntentService
- ListFragment
- LoaderManager
- NavUtils
- NotificationCompat
- NotificationCompat.Action
- NotificationCompat.Action.Builder
- NotificationCompat.Action.WearableExtender
- NotificationCompat.BigPictureStyle
- NotificationCompat.BigTextStyle
- NotificationCompat.Builder
- NotificationCompat.CarExtender
- NotificationCompat.CarExtender.UnreadConversation
- NotificationCompat.CarExtender.UnreadConversation.Builder
- NotificationCompat.DecoratedCustomViewStyle
- NotificationCompat.InboxStyle
- NotificationCompat.MessagingStyle
- NotificationCompat.MessagingStyle.Message
- NotificationCompat.Style
- NotificationCompat.WearableExtender
- NotificationCompatExtras
- NotificationCompatSideChannelService
- NotificationManagerCompat
- RemoteInput
- RemoteInput.Builder
- ServiceCompat
- ShareCompat
- ShareCompat.IntentBuilder
- ShareCompat.IntentReader
- SharedElementCallback
- TaskStackBuilder
Exceptions
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2024-04-11 UTC.