在 Windows 文件管理器中构建自定义列有两种方法:使用 Windows 属性系统和云存储提供程序的属性定义。您通常会使用第一种方法为您拥有的文件类型创建自定义属性。在显示来自文档管理系统或任何其他存储的自定义数据时,您将使用第二种方法。
使用 Windows 属性系统。
对于 Windows Vista 及更高版本中的特定文件类型,您可以create custom properties。这些属性可以是只读的或读写的。以及它们可以被 Window Search 索引器索引并参与搜索。有一些限制:
...属性处理程序不能在托管代码中实现,应该是
用 C++ 实现。
- 该属性与通常属于您的应用程序的特定文件类型相关联。您不能为所有文件类型创建属性。
使用云存储提供商属性定义
在 Windows 10 Creators Update 及更高版本中,您可以为使用 Cloud Sync Engine API(存储提供程序、云过滤器 API)创建的文件系统添加自定义列。此 API 用于 OneDrive 等工具。您需要使用自定义属性定义注册 Cloud Storage Provider 同步根,为您的自定义列提供数据,最后使用 Cloud File/Cloud Filter API 实现 Cloud Storage 提供程序。
属性定义与文件类型无关,可以为所有文件添加。此外,即使 .NET 中只有一些 API 可用,您仍然可以调用 Win32 函数并仅使用托管代码构建云提供商。
注册云存储提供程序。以下是使用 C# 自定义列注册存储提供程序的示例:
StorageProviderSyncRootInfo storageInfo = new StorageProviderSyncRootInfo();
storageInfo.Path = await StorageFolder.GetFolderFromPathAsync("C:\\Users\\User1\\VFS\\");
...
// Adds columns to Windows File Manager.
// Show/hide columns in the "More..." context menu on the columns header.
var proDefinitions = storageInfo.StorageProviderItemPropertyDefinitions;
proDefinitions.Add(new StorageProviderItemPropertyDefinition { DisplayNameResource = "Lock Expires", Id = 2, });
proDefinitions.Add(new StorageProviderItemPropertyDefinition { DisplayNameResource = "Lock Scope", Id = 3, });
StorageProviderSyncRootManager.Register(storageInfo);
可以在here找到完整的注册示例。
为属性定义提供数据。要为列提供数据,您将使用 StorageProviderItemProperties.SetAsync() 调用:
IStorageItem storageItem = await Windows.Storage.StorageFile.GetFileFromPathAsync(path);
StorageProviderItemProperty propState = new StorageProviderItemProperty()
{
Id = 3,
Value = "Exclusive",
IconResource = "C:\\path\\icon.ico" // The optional icon to be displayed in the Status column.
};
await StorageProviderItemProperties.SetAsync(storageItem, new StorageProviderItemProperty[] { propState });
另一种方法是实现IStorageProviderItemPropertySource 接口。它会根据您的文件路径返回属性。
Cloud Storage Provider 实施。 最后,您需要一个完整的文件系统实施,为您的文件/文件夹占位符提供数据。您可以在 .NET/C# here 中找到完整的示例: