StorageFile Class
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.
Represents a file. Provides information about the file and its content, and ways to manipulate them.
public ref class StorageFile sealed : IStorageFile, IStorageFile2, IStorageFilePropertiesWithAvailability, IStorageItem2, IStorageItemProperties2, IStorageItemPropertiesWithProvider
/// [Windows.Foundation.Metadata.ContractVersion(Windows.Foundation.UniversalApiContract, 65536)]
class StorageFile final : IStorageFile, IStorageFile2, IStorageFilePropertiesWithAvailability, IStorageItem2, IStorageItemProperties2, IStorageItemPropertiesWithProvider
[Windows.Foundation.Metadata.ContractVersion(typeof(Windows.Foundation.UniversalApiContract), 65536)]
public sealed class StorageFile : IStorageFile, IStorageFile2, IStorageFilePropertiesWithAvailability, IStorageItem2, IStorageItemProperties2, IStorageItemPropertiesWithProvider
Public NotInheritable Class StorageFile
Implements IStorageFile, IStorageFile2, IStorageFilePropertiesWithAvailability, IStorageItem2, IStorageItemProperties2, IStorageItemPropertiesWithProvider
- Inheritance
- Attributes
- Implements
Device family |
Windows 10 (introduced in 10.0.10240.0)
|
API contract |
Windows.Foundation.UniversalApiContract (introduced in v1.0)
|
App capabilities |
documentsLibrary
musicLibrary
picturesLibrary
videosLibrary
|
This example shows you how to call a file picker, using FileOpenPicker.PickSingleFileAsync to capture and process a file that the users picks.
var openPicker = new FileOpenPicker();
StorageFile file = await openPicker.PickSingleFileAsync();
// Process picked file
if (file != null)
{
// Store file for future access
Windows.Storage.AccessCache.StorageApplicationPermissions.FutureAccessList.Add(file);
}
else
{
// The user didn't pick a file
}
After PickSingleFileAsync completes, file
gets the picked file as a StorageFile.
In the example, openPicker
contains a FileOpenPicker object. To learn more about using file picker see Open files and folders with a picker.
Additionally, fileToken
gets an identifier that you can use to retrieve the file from the FutureAccessList. To learn more about storing files and folders so you can access them again later, see FutureAccessList, MostRecentlyUsedList and Track recently used files and folders.
Typically, you access StorageFile objects as the result of asynchronous method and/or function calls. For example, both of the static methods GetFileFromPathAsync and GetFileFromApplicationUriAsync return a StorageFile that represents the specified file.
Additionally, whenever you call a file picker to let the user pick a file (or files) the file picker will return the file as a StorageFile.
Note
StorageFile objects can't represent files that are ".lnk", ".url", or ".wsh" file types.
Windows version | SDK version | Value added |
---|---|---|
2004 | 19041 | GetFileFromPathForUserAsync |
Attributes |
Gets the attributes of a file. |
Content |
Gets the MIME type of the contents of the file. |
Date |
Gets the date and time when the current file was created. |
Display |
Gets a user-friendly name for the file. |
Display |
Gets a user-friendly description of the type of the file. |
File |
Gets the type (file name extension) of the file. |
Folder |
Gets an identifier for the file. This ID is unique for the query result or StorageFolder that contains the file and can be used to distinguish between items that have the same name. |
Is |
Indicates if the file is local, is cached locally, or can be downloaded. |
Name |
Gets the name of the file including the file name extension. |
Path |
Gets the full file-system path of the current file, if the file has a path. |
Properties |
Gets an object that provides access to the content-related properties of the file. |
Provider |
Gets the StorageProvider object that contains info about the service that stores the current file. |
Copy |
Replaces the specified file with a copy of the current file. |
Copy |
Creates a copy of the file in the specified folder and renames the copy. This method also specifies what to do if a file with the same name already exists in the destination folder. |
Copy |
Creates a copy of the file in the specified folder and renames the copy. |
Copy |
Creates a copy of the file in the specified folder. |
Create |
Creates a StorageFile to represent the specified stream of data. This method lets the app produce the data on-demand by specifying a function to be invoked when the StorageFile that represents the stream is first accessed. |
Create |
Creates a StorageFile to represent a stream of data from the specified Uniform Resource Identifier (URI) resource. This method lets the app download the data on-demand when the StorageFile that represents the stream is first accessed. |
Delete |
Deletes the current file. |
Delete |
Deletes the current file, optionally deleting the item permanently. |
Get |
Gets the basic properties of the current file. |
Get |
Gets a StorageFile object to represent the specified Uniform Resource Identifier (URI) app resource. For examples of sample URIs see Load images and assets tailored for scale, theme, high contrast, and others. |
Get |
Gets a StorageFile object to represent the file at the specified path. |
Get |
Gets a StorageFile object based on an absolute path in the file system for a given user. |
Get |
Gets the parent folder of the current file. |
Get |
Gets a scaled image as a thumbnail, determined by the purpose of the thumbnail, the requested size, and the specified options |
Get |
Gets a scaled image as a thumbnail, determined by the purpose of the thumbnail and the requested size. |
Get |
Gets a scaled image as a thumbnail, determined by the purpose of the thumbnail. |
Get |
Retrieves an adjusted thumbnail image for the file, determined by the purpose of the thumbnail, the requested size, and the specified options. |
Get |
Retrieves an adjusted thumbnail image for the file, determined by the purpose of the thumbnail and the requested size. |
Get |
Retrieves an adjusted thumbnail image for the file, determined by the purpose of the thumbnail. |
Is |
Indicates whether the current file is equal to the specified file. |
Is |
Determines whether the current StorageFile matches the specified StorageItemTypes value. |
Move |
Moves the current file to the location of the specified file and replaces the specified file in that location. |
Move |
Moves the current file to the specified folder and renames the file according to the desired name. This method also specifies what to do if a file with the same name already exists in the specified folder. |
Move |
Moves the current file to the specified folder and renames the file according to the desired name. |
Move |
Moves the current file to the specified folder. |
Open |
Opens a random-access stream with the specified options over the specified file. |
Open |
Opens a random-access stream with the specified options over the specified file. |
Open |
Opens a random-access stream over the current file for reading file contents. |
Open |
Opens a sequential-access stream over the current file for reading file contents. |
Open |
Opens a random-access stream to the file that can be used for transacted-write operations. |
Open |
Opens a random-access stream to the file that can be used for transacted-write operations with the specified options. |
Rename |
Renames the current file. This method also specifies what to do if an existing item in the current file's location has the same name. |
Rename |
Renames the current file. |
Replace |
Replaces the contents of the file referred to by the specified IStorageFile object with a new data stream. This method lets the app produce the data on-demand by specifying a function to be invoked when the StorageFile that represents the stream is first accessed. |
Replace |
Replaces the contents of the file referred to by the specified IStorageFile object with a new data stream of the specified Uniform Resource Identifier (URI). This method lets the app download the data on-demand when the StorageFile that represents the stream is first accessed. The data stream is accessed through the StorageFile that is returned and the data is downloaded on-demand when the StorageFile is first accessed. Replaces the IStorageFile object that represents the specified file with a new StorageFile that provides a stream of the specified Uniform Resource Identifier (URI). |