CloudMediaProvider Class
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Base class for a cloud media provider.
[Android.Runtime.Register("android/provider/CloudMediaProvider", ApiSince=33, DoNotGenerateAcw=true)]
public abstract class CloudMediaProvider : Android.Content.ContentProvider
[<Android.Runtime.Register("android/provider/CloudMediaProvider", ApiSince=33, DoNotGenerateAcw=true)>]
type CloudMediaProvider = class
inherit ContentProvider
- Inheritance
- Attributes
Remarks
Base class for a cloud media provider. A cloud media provider offers read-only access to durable media files, specifically photos and videos stored on a local disk, or files in a cloud storage service. To create a cloud media provider, extend this class, implement the abstract methods, and add it to your manifest like this:
<manifest>
...
<application>
...
<provider
android:name="com.example.MyCloudProvider"
android:authorities="com.example.mycloudprovider"
android:exported="true"
android:permission="com.android.providers.media.permission.MANAGE_CLOUD_MEDIA_PROVIDERS"
<intent-filter>
<action android:name="android.content.action.CLOUD_MEDIA_PROVIDER" />
</intent-filter>
</provider>
...
</application>
</manifest>
When defining your provider, you must protect it with the CloudMediaProviderContract#MANAGE_CLOUD_MEDIA_PROVIDERS_PERMISSION
, which is a permission only the system can obtain, trying to define an unprotected CloudMediaProvider
will result in a SecurityException
.
Applications cannot use a cloud media provider directly; they must go through MediaStore#ACTION_PICK_IMAGES
which requires a user to actively navigate and select media items. When a user selects a media item through that UI, the system issues narrow URI permission grants to the requesting application. <h3>Media items</h3>
A media item must be an openable stream (with a specific MIME type). Media items can belong to zero or more albums. Albums cannot contain other albums.
Each item under a provider is uniquely referenced by its media or album id, which must not change which must be unique across all collection IDs as returned by #onGetMediaCollectionInfo
.
Java documentation for android.provider.CloudMediaProvider
.
Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.
Constructors
CloudMediaProvider() | |
CloudMediaProvider(IntPtr, JniHandleOwnership) |
Properties
CallingAttributionSource |
Gets the attribution source of the calling app. (Inherited from ContentProvider) |
CallingAttributionTag |
Return the attribution tag of the caller that initiated the request being processed on the current thread. (Inherited from ContentProvider) |
CallingPackage |
Return the package name of the caller that initiated the request being processed on the current thread. (Inherited from ContentProvider) |
CallingPackageUnchecked |
Return the package name of the caller that initiated the request being processed on the current thread. (Inherited from ContentProvider) |
Class |
Returns the runtime class of this |
Context |
Retrieves the Context this provider is running in. (Inherited from ContentProvider) |
Handle |
The handle to the underlying Android instance. (Inherited from Object) |
IsTemporary |
Returns true if this instance is a temporary content provider. (Inherited from ContentProvider) |
JniIdentityHashCode | (Inherited from Object) |
JniPeerMembers | |
PeerReference | (Inherited from Object) |
ReadPermission |
Obsolete.
Return the name of the permission required for read-only access to this content provider. -or- Change the permission required to read data from the content provider. (Inherited from ContentProvider) |
ThresholdClass | |
ThresholdType | |
WritePermission |
Obsolete.
Return the name of the permission required for read/write access to this content provider. -or- Change the permission required to read and write data in the content provider. (Inherited from ContentProvider) |
Methods
ApplyBatch(IList<ContentProviderOperation>) |
Override this to handle requests to perform a batch of operations, or the
default implementation will iterate over the operations and call
|
ApplyBatch(String, IList<ContentProviderOperation>) |
Override this to handle requests to perform a batch of operations, or the
default implementation will iterate over the operations and call
|
AttachInfo(Context, ProviderInfo) |
Implementation is provided by the parent class. |
BulkInsert(Uri, ContentValues[]) |
Override this to handle requests to insert a set of new rows, or the
default implementation will iterate over the values and call
|
Call(String, String, Bundle) |
Implementation is provided by the parent class. |
Call(String, String, String, Bundle) |
Call a provider-defined method. (Inherited from ContentProvider) |
Canonicalize(Uri) |
Implementation is provided by the parent class. |
ClearCallingIdentity() |
Reset the identity of the incoming IPC on the current thread. (Inherited from ContentProvider) |
Clone() |
Creates and returns a copy of this object. (Inherited from Object) |
Delete(Uri, Bundle) |
Implement this to handle requests to delete one or more rows. (Inherited from ContentProvider) |
Delete(Uri, String, String[]) |
Implementation is provided by the parent class. |
Dispose() | (Inherited from Object) |
Dispose(Boolean) | (Inherited from Object) |
Dump(FileDescriptor, PrintWriter, String[]) |
Print the Provider's state into the given stream. (Inherited from ContentProvider) |
DumpAsync(FileDescriptor, PrintWriter, String[]) | (Inherited from ContentProvider) |
Equals(Object) |
Indicates whether some other object is "equal to" this one. (Inherited from Object) |
GetHashCode() |
Returns a hash code value for the object. (Inherited from Object) |
GetPathPermissions() |
Return the path-based permissions required for read and/or write access to this content provider. (Inherited from ContentProvider) |
GetStreamTypes(Uri, String) |
Called by a client to determine the types of data streams that this content provider supports for the given URI. (Inherited from ContentProvider) |
GetType(Uri) |
Implementation is provided by the parent class. |
GetTypeAnonymous(Uri) |
Implement this to handle requests for MIME type of URIs, that does not need to reveal any internal information which should be protected by any permission. (Inherited from ContentProvider) |
Insert(Uri, ContentValues, Bundle) |
Implement this to handle requests to insert a new row. (Inherited from ContentProvider) |
Insert(Uri, ContentValues) |
Implementation is provided by the parent class. |
JavaFinalize() |
Called by the garbage collector on an object when garbage collection determines that there are no more references to the object. (Inherited from Object) |
Notify() |
Wakes up a single thread that is waiting on this object's monitor. (Inherited from Object) |
NotifyAll() |
Wakes up all threads that are waiting on this object's monitor. (Inherited from Object) |
OnCallingPackageChanged() |
Called whenever the value of |
OnConfigurationChanged(Configuration) |
To be added This method is always called on the application main thread, and must not perform lengthy operations. (Inherited from ContentProvider) |
OnCreate() |
Implement this to initialize your content provider on startup. (Inherited from ContentProvider) |
OnCreateCloudMediaSurfaceController(Bundle, CloudMediaProvider+CloudMediaSurfaceStateChangedCallback) | |
OnGetMediaCollectionInfo(Bundle) |
Returns metadata about the media collection itself. |
OnLowMemory() |
To be added This method is always called on the application main thread, and must not perform lengthy operations. (Inherited from ContentProvider) |
OnOpenMedia(String, Bundle, CancellationSignal) |
Returns the full size media item identified by |
OnOpenPreview(String, Point, Bundle, CancellationSignal) |
Returns a thumbnail of |
OnQueryAlbums(Bundle) |
Returns a cursor representing all album items in the media collection optionally filtered
by |
OnQueryDeletedMedia(Bundle) |
Returns a |
OnQueryMedia(Bundle) |
Returns a cursor representing all media items in the media collection optionally filtered by
|
OnTrimMemory(TrimMemory) |
Called when the operating system has determined that it is a good time for a process to trim unneeded memory from its process. (Inherited from ContentProvider) |
OpenAssetFile(Uri, String, CancellationSignal) |
This is like |
OpenAssetFile(Uri, String) |
This is like |
OpenFile(Uri, String, CancellationSignal) |
Implementation is provided by the parent class. |
OpenFile(Uri, String) |
Implementation is provided by the parent class. |
OpenFileHelper(Uri, String) |
Convenience for subclasses that wish to implement |
OpenPipeHelper(Uri, String, Bundle, Object, ContentProvider+IPipeDataWriter) |
A helper function for implementing |
OpenTypedAssetFile(Uri, String, Bundle, CancellationSignal) |
Implementation is provided by the parent class. |
OpenTypedAssetFile(Uri, String, Bundle) |
Implementation is provided by the parent class. |
Query(Uri, String[], Bundle, CancellationSignal) |
Implementation is provided by the parent class. |
Query(Uri, String[], String, String[], String, CancellationSignal) |
Implementation is provided by the parent class. |
Query(Uri, String[], String, String[], String) |
Implementation is provided by the parent class. |
Refresh(Uri, Bundle, CancellationSignal) |
Implement this to support refresh of content identified by |
RequireContext() |
Retrieves a Non-Nullable Context this provider is running in, this is intended to be called
after |
RestoreCallingIdentity(ContentProvider+CallingIdentity) |
Restore the identity of the incoming IPC on the current thread back to a
previously identity that was returned by |
SetHandle(IntPtr, JniHandleOwnership) |
Sets the Handle property. (Inherited from Object) |
SetPathPermissions(PathPermission[]) |
Change the path-based permission required to read and/or write data in the content provider. (Inherited from ContentProvider) |
SetReadPermission(String) | (Inherited from ContentProvider) |
SetWritePermission(String) | (Inherited from ContentProvider) |
Shutdown() |
Implement this to shut down the ContentProvider instance. (Inherited from ContentProvider) |
ToArray<T>() | (Inherited from Object) |
ToString() |
Returns a string representation of the object. (Inherited from Object) |
Uncanonicalize(Uri) |
Remove canonicalization from canonical URIs previously returned by
|
UnregisterFromRuntime() | (Inherited from Object) |
Update(Uri, ContentValues, Bundle) |
Implement this to handle requests to update one or more rows. (Inherited from ContentProvider) |
Update(Uri, ContentValues, String, String[]) |
Implementation is provided by the parent class. |
Wait() |
Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>. (Inherited from Object) |
Wait(Int64, Int32) |
Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>, or until a certain amount of real time has elapsed. (Inherited from Object) |
Wait(Int64) |
Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>, or until a certain amount of real time has elapsed. (Inherited from Object) |
Explicit Interface Implementations
IJavaPeerable.Disposed() | (Inherited from Object) |
IJavaPeerable.DisposeUnlessReferenced() | (Inherited from Object) |
IJavaPeerable.Finalized() | (Inherited from Object) |
IJavaPeerable.JniManagedPeerState | (Inherited from Object) |
IJavaPeerable.SetJniIdentityHashCode(Int32) | (Inherited from Object) |
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) | (Inherited from Object) |
IJavaPeerable.SetPeerReference(JniObjectReference) | (Inherited from Object) |
Extension Methods
JavaCast<TResult>(IJavaObject) |
Performs an Android runtime-checked type conversion. |
JavaCast<TResult>(IJavaObject) | |
GetJniTypeName(IJavaPeerable) |
Gets the JNI name of the type of the instance |
JavaAs<TResult>(IJavaPeerable) |
Try to coerce |
TryJavaCast<TResult>(IJavaPeerable, TResult) |
Try to coerce |