Introduction
Xamarin.Forms code runs on multiple platforms - each of which has its own filesystem. This means that reading and writing files is most easily done using the native file APIs on each platform. Alternatively, embedded resources are a simpler solution to distribute data files with an app.
Prerequisites
- Visual Studio 2017 or later (Windows or Mac)
Setting up a Xamarin.Forms Project
Start by creating a new Xamarin.Forms project. You wíll learn more by going through the steps yourself.
Create a new or existing Xamarin forms(.Net standard) Project with Android and iOS Platform.
Nuget
Install the following Nuget from Nuget Manager In your Visual Studio.
Name |
Xamarin.Plugin.FilePicker |
Version |
2.1.41 |
Url |
https://www.nuget.org/packages/Xamarin.Plugin.FilePicker/ |
Xamarin.Essentials
Xamarin.Essentials also supports File Picker but it's in Preview. Once the FilePicker is moved to stable you can update Xamarin.Pulgin.FilePicker to Xamarin.Essentials from
here.
Setup UI
Now, I created a simple UI for file browser.
MainPage.xaml
- <?xml version="1.0" encoding="utf-8"?>
- <ContentPage xmlns="http://xamarin.com/schemas/2014/forms" xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" xmlns:d="http://xamarin.com/schemas/2014/forms/design" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d" x:Class="FileUploadPOC.MainPage">
- <StackLayout HorizontalOptions="Center">
- <!-- Place new controls here -->
- <Image Source="xamarinmonkeysbanner.png" HorizontalOptions="Center" Margin="0,100,0,0"/>
- <Button Margin="0,20,0,0" Text="Browse File" Clicked="Button_Clicked"></Button>
- <Label x:Name="lblName"/>
- <Label x:Name="lblFilePath"/>
- </StackLayout>
- </ContentPage>
File Browser
Below code is for file picker. Here we will get two values, FileName and FilePath.
- private async Task PickAndShow(string[] fileTypes)
- {
- try
- {
-
- var pickedFile = await CrossFilePicker.Current.PickFile(fileTypes);
- if (pickedFile != null)
- {
- lblName.Text = pickedFile.FileName;
- lblFilePath.Text = pickedFile.FilePath;
- }
- }
- catch (Exception ex)
- {
-
- }
- }
File Types
Note, you can define the file types for platform specific.
- if (Device.RuntimePlatform == Device.Android)
- {
- fileTypes = new string[] { "image/png", "image/jpeg" };
- }
-
- if (Device.RuntimePlatform == Device.iOS)
- {
- fileTypes = new string[] { "public.image" };
- }
-
- if (Device.RuntimePlatform == Device.UWP)
- {
- fileTypes = new string[] { ".jpg", ".png" };
- }
-
- if (Device.RuntimePlatform == Device.WPF)
- {
- fileTypes = new string[] { "JPEG files (*.jpg)|*.jpg", "PNG files (*.png)|*.png" };
- }
Reference for other file types,
https://stackoverflow.com/questions/41797644/xamarin-ios-filtering-out-the-filetype-show-on-document-picker
MainPage.Xaml.cs
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using Xamarin.Forms;
- using Plugin.FilePicker;
- using Xamarin.Essentials;
- using System.Security.Cryptography.X509Certificates;
-
- namespace FileUploadPOC
- {
-
-
- [DesignTimeVisible(false)]
- public partial class MainPage : ContentPage
- {
- public MainPage()
- {
- InitializeComponent();
- }
-
- async void Button_Clicked(System.Object sender, System.EventArgs e)
- {
- try
- {
- string[] fileTypes = null;
- if (Device.RuntimePlatform == Device.iOS)
- {
- fileTypes = new string[] {"com.adobe.pdf", "public.rft", "com.microsoft.word.doc", "org.openxmlformats.wordprocessingml.document" }; }
- await PickAndShow(fileTypes);
- }
- catch (Exception ex)
- {
-
- }
-
- }
-
- private async Task PickAndShow(string[] fileTypes)
- {
- try
- {
-
- var pickedFile = await CrossFilePicker.Current.PickFile(fileTypes);
- if (pickedFile != null)
- {
- lblName.Text = pickedFile.FileName;
- lblFilePath.Text = pickedFile.FilePath;
- }
- }
- catch (Exception ex)
- {
-
- }
- }
- }
- }
Debug your App
Download source code
here.
I hope you have understood how to browse files in your device and drive in Xamarin.Forms.
Thanks for reading. Please share your comments and feedback. Happy Coding :)