MPowerKit.MediaPlugin 1.0.1

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package MPowerKit.MediaPlugin --version 1.0.1                
NuGet\Install-Package MPowerKit.MediaPlugin -Version 1.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="MPowerKit.MediaPlugin" Version="1.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MPowerKit.MediaPlugin --version 1.0.1                
#r "nuget: MPowerKit.MediaPlugin, 1.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install MPowerKit.MediaPlugin as a Cake Addin
#addin nuget:?package=MPowerKit.MediaPlugin&version=1.0.1

// Install MPowerKit.MediaPlugin as a Cake Tool
#tool nuget:?package=MPowerKit.MediaPlugin&version=1.0.1                

MPowerKit.MediaPlugin

Simple .NET MAUI cross platform plugin to take photos and video or pick them from a gallery.

Ported from James Montemagno's MediaPlugin to the latest .NET, cut off resize functionality.

"Buy Me A Coffee"

Setup

  • Available on NuGet: NuGet
  • Please see the additional setup for each platforms permissions.

Platform Support

Platform Min Version
.NET 8.0
iOS 14.2
MacCatalyst 14.2
Android 24
Windows 17763

API Usage

Call Media.Current from any project or PCL to gain access to APIs.

Before taking photos or videos you should check to see if a camera exists and if photos and videos are supported on the device. There are five properties that you can check:


/// <summary>
/// Only for Windows. Initialize all camera components, must be called before checking properties below
/// </summary>
/// <returns>If success</returns>
Task<bool> Initialize();

/// <summary>
/// Gets if a camera is available on the device
/// </summary>
bool IsCameraAvailable { get; }

/// <summary>
/// Gets if ability to take photos supported on the device
/// </summary>
bool IsTakePhotoSupported { get; }

/// <summary>
/// Gets if the ability to pick photo is supported on the device
/// </summary>
bool IsPickPhotoSupported { get; }

/// <summary>
/// Gets if ability to take video is supported on the device
/// </summary>
bool IsTakeVideoSupported { get; }

/// <summary>
/// Gets if the ability to pick a video is supported on the device
/// </summary>
bool IsPickVideoSupported { get; }

Photos

/// <summary>
/// Picks a photo from the default gallery
/// </summary>
/// <param name="token">Cancellation token</param>
/// <param name="request">Pick Photos Request</param>
/// <returns>Media file</returns>
/// <exception cref="OperationCanceledException">Thrown when the operation is canceled by user.</exception>
Task<MediaFile?> PickPhotoAsync(PickRequest? request = null, CancellationToken token = default);

/// <summary>
/// Picks multiple photos from the default gallery
/// </summary>
/// <param name="request">Pick Photos Request</param>
/// <param name="multiOptions">Options for picking multiple photos</param>
/// <param name="token">Cancellation token</param>
/// <returns>Media files</returns>
/// <exception cref="OperationCanceledException">Thrown when the operation is canceled by user.</exception>
Task<List<MediaFile>?> PickPhotosAsync(PickRequest? request = null, MultiPickerOptions? multiOptions = null, CancellationToken token = default);

/// <summary>
/// Takes a photo
/// </summary>
/// <param name="request">Camera Photo Request</param>
/// <param name="token">Cancellation token</param>
/// <returns>Media file of photo</returns>
/// <exception cref="OperationCanceledException">Thrown when the operation is canceled by user.</exception>
Task<MediaFile?> TakePhotoAsync(CaptureRequest? request = null, CancellationToken token = default);

Videos

/// <summary>
/// Picks a video from the default gallery
/// </summary>
/// <param name="request">Pick Video Request</param>
/// <param name="token">Cancellation token</param>
/// <returns>Media file of video or null if canceled</returns>
/// <exception cref="OperationCanceledException">Thrown when the operation is canceled by user.</exception>
Task<MediaFile?> PickVideoAsync(VideoPickRequest? request = null, CancellationToken token = default);

/// <summary>
/// Takes a video
/// </summary>
/// <param name="request">Camera Video Request</param>
/// <param name="token">Cancellation token</param>
/// <returns>Media file of new video</returns>
/// <exception cref="OperationCanceledException">Thrown when the operation is canceled by user.</exception>
Task<MediaFile?> TakeVideoAsync(CaptureRequest? request = null, CancellationToken token = default);

Set up

To be able to use this library you need to initialize in in you MauiProgram.cs file as next:


builder.
    .UseMauiApp<App>()
    .UseMpowerKitMediaPlugin(registerInterface: false); // This will register the IMedia interface for you if set to true

Android

By default, the library adds android.hardware.camera and android.hardware.camera.autofocus to your apps manifest as optional features. It is your responsbility to check whether your device supports the hardware before using it. If instead you'd like Google Play to filter out devices without the required hardware, add the following to your AssemblyInfo.cs file in your Android project:

[assembly: UsesFeature("android.hardware.camera", Required = true)]
[assembly: UsesFeature("android.hardware.camera.autofocus", Required = true)]

Other additional setup is not required.

iOS / MacCatalyst

Your app is required to have next keys in your Info.plist


<key>NSCameraUsageDescription</key>
<string>This app needs access to the camera to take photos.</string>


<key>NSMicrophoneUsageDescription</key>
<string>This app needs access to microphone.</string>


<key>NSPhotoLibraryUsageDescription</key>
<string>This app needs access to photos.</string>

<key>NSPhotoLibraryAddUsageDescription</key>
<string>This app needs access to the photo gallery.</string>

If you want the dialogs to be translated you must support the specific languages in your app. Read the iOS Localization Guide

Windows

Add this to your Package.appxmanifest if you want to take photo / video:

<Capabilities>
    <DeviceCapability Name="webcam"/>

    
    <DeviceCapability Name="microphone"/>
</Capabilities>

Permissions

By default, the Media Plugin will attempt to request multiple permissions, but each platform handles this a bit differently, such as iOS which will only pop up permissions once.

Usage

Via a Xamarin.Forms project with a Button and Image to take a photo:

takePhoto.Clicked += async (sender, args) =>
{
    // only for Windwos
    await Media.Current.Initialize();
    
    if (!Media.Current.IsCameraAvailable || !Media.Current.IsTakePhotoSupported)
    {
        DisplayAlert("No Camera", ":( No camera available.", "OK");
        return;
    }

    try
    {
        var file = await Media.Current.TakePhotoAsync(new CaptureRequest
        {
            DesiredDirectory = "Sample",
            DesiredName = "test.jpg"
        });

        image.Source = file.Path; 
    }
    catch (OperationCancelledException oce)
    { 
        // user cancelled
    }
};

To see more examples open up the Sample rpoject form this repo.

Photo & Video Settings

Directories and File Names

These settings are available only for taking photos and videos over CaptureRequest object. These properties are optional. Any illegal characters will be removed and if the name of the file is a duplicate then a number will be appended to the end. The default implementation is to specify a unique time code to each value.

Default Camera

By default when you take a photo or video the default system camera will be selected. Simply set the DefaultCamera on CaptureRequest. This option does not guarantee that the actual camera will be selected because each platform is different. It seems to work extremely well on iOS, but not so much on Android. Your mileage may vary.

var file = await Media.Current.TakePhotoAsync(new CaptureRequest
{
    DefaultCamera = CameraDevice.Front
});
Product Compatible and additional computed target framework versions.
.NET net8.0-android34.0 is compatible.  net8.0-ios17.5 is compatible.  net8.0-maccatalyst17.5 is compatible.  net8.0-windows10.0.22621 is compatible.  net9.0-android was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.2 877 9/4/2024
1.0.1 122 9/4/2024
1.0.0 125 8/28/2024