1# 使用Picker选择媒体库资源 2 3用户有时需要分享图片、视频等用户文件,开发者可以通过特定接口拉起系统图库,用户自行选择待分享的资源,然后最终完成分享。此接口本身无需申请权限,目前适用于界面UIAbility,使用窗口组件触发。具体使用方式如下: 4 51. 导入选择器模块和文件管理模块。 6 7 ```ts 8 import { photoAccessHelper } from '@kit.MediaLibraryKit'; 9 import { fileIo } from '@kit.CoreFileKit'; 10 import { BusinessError } from '@kit.BasicServicesKit'; 11 ``` 12 132. 创建图片-音频类型文件选择选项实例。 14 15 ```ts 16 const photoSelectOptions = new photoAccessHelper.PhotoSelectOptions(); 17 ``` 18 193. 配置可选的媒体文件类型和媒体文件的最大数目。 20 以下示例以图片选择为例,媒体文件类型请参见[PhotoViewMIMETypes](../../reference/apis-media-library-kit/js-apis-photoAccessHelper.md#photoviewmimetypes)。 21 22 ```ts 23 photoSelectOptions.MIMEType = photoAccessHelper.PhotoViewMIMETypes.IMAGE_TYPE; // 过滤选择媒体文件类型为IMAGE 24 photoSelectOptions.maxSelectNumber = 5; // 选择媒体文件的最大数目 25 ``` 26 274. 创建图库选择器实例,调用[PhotoViewPicker.select](../../reference/apis-media-library-kit/js-apis-photoAccessHelper.md#select)接口拉起图库界面进行文件选择。文件选择成功后,返回[PhotoSelectResult](../../reference/apis-media-library-kit/js-apis-photoAccessHelper.md#photoselectresult)结果集。 28 29 ```ts 30 let uris: Array<string> = []; 31 const photoViewPicker = new photoAccessHelper.PhotoViewPicker(); 32 photoViewPicker.select(photoSelectOptions).then((photoSelectResult: photoAccessHelper.PhotoSelectResult) => { 33 uris = photoSelectResult.photoUris; 34 console.info('photoViewPicker.select to file succeed and uris are:' + uris); 35 }).catch((err: BusinessError) => { 36 console.error(`Invoke photoViewPicker.select failed, code is ${err.code}, message is ${err.message}`); 37 }) 38 ``` 39 40 select返回的uri权限是只读权限,可以根据结果集中uri进行读取文件数据操作。注意不能在picker的回调里直接使用此uri进行打开文件操作,需要定义一个全局变量保存uri,类似使用一个按钮去触发打开文件。可参考[指定URI读取文件数据](#指定uri读取文件数据)。 41 42 也可以通过返回的uri[获取图片或视频资源](#指定uri获取图片或视频资源)。 43 44 如有获取元数据需求,可以通过[文件管理接口](../../reference/apis-core-file-kit/js-apis-file-fs.md)和[文件URI](../../reference/apis-core-file-kit/js-apis-file-fileuri.md)根据uri获取部分文件属性信息,比如文件大小、访问时间、修改时间、文件名、文件路径等。 45 46## 指定URI读取文件数据 47 481. 待界面从图库返回后,再通过一个类似按钮的组件去调用其他函数,使用[fileIo.openSync](../../reference/apis-core-file-kit/js-apis-file-fs.md#fsopensync)接口,通过[媒体文件uri](../../file-management/user-file-uri-intro.md#媒体文件uri)打开这个文件得到fd。这里需要注意接口权限参数是fileIo.OpenMode.READ_ONLY。 49 50 ```ts 51 let uri: string = ''; 52 let file = fileIo.openSync(uri, fileIo.OpenMode.READ_ONLY); 53 console.info('file fd: ' + file.fd); 54 ``` 55 562. 通过fd使用[fileIo.readSync](../../reference/apis-core-file-kit/js-apis-file-fs.md#readsync)接口读取这个文件内的数据,读取完成后关闭fd。 57 58 ```ts 59 let buffer = new ArrayBuffer(4096); 60 let readLen = fileIo.readSync(file.fd, buffer); 61 console.info('readSync data to file succeed and buffer size is:' + readLen); 62 fileIo.closeSync(file); 63 ``` 64 65## 指定URI获取图片或视频资源 66 67媒体库支持Picker选择[媒体文件](../../file-management/user-file-uri-intro.md#媒体文件uri)URI后,根据指定URI获取图片或视频资源,下面以查询指定URI为'file://media/Photo/1/IMG_datetime_0001/displayName.jpg'为例。 68 69```ts 70import { photoAccessHelper } from '@kit.MediaLibraryKit'; 71import { dataSharePredicates } from '@kit.ArkData'; 72 73const context = getContext(this); 74let phAccessHelper = photoAccessHelper.getPhotoAccessHelper(context); 75 76class MediaDataHandler implements photoAccessHelper.MediaAssetDataHandler<ArrayBuffer> { 77 onDataPrepared(data: ArrayBuffer) { 78 if (data === undefined) { 79 console.error('Error occurred when preparing data'); 80 return; 81 } 82 console.info('on image data prepared'); 83 // 应用自定义对资源数据的处理逻辑 84 } 85} 86 87async function example() { 88 let predicates: dataSharePredicates.DataSharePredicates = new dataSharePredicates.DataSharePredicates(); 89 let uri = 'file://media/Photo/1/IMG_datetime_0001/displayName.jpg' // 需保证此uri已存在。 90 predicates.equalTo(photoAccessHelper.PhotoKeys.URI, uri.toString()); 91 let fetchOptions: photoAccessHelper.FetchOptions = { 92 fetchColumns: [photoAccessHelper.PhotoKeys.TITLE], 93 predicates: predicates 94 }; 95 96 try { 97 let fetchResult: photoAccessHelper.FetchResult<photoAccessHelper.PhotoAsset> = await phAccessHelper.getAssets(fetchOptions); 98 let photoAsset: photoAccessHelper.PhotoAsset = await fetchResult.getFirstObject(); 99 console.info('getAssets photoAsset.uri : ' + photoAsset.uri); 100 // 获取属性值,以标题为例;对于非默认查询的属性,get前需要在fetchColumns中添加对应列名 101 console.info('title : ' + photoAsset.get(photoAccessHelper.PhotoKeys.TITLE)); 102 // 请求图片资源数据 103 let requestOptions: photoAccessHelper.RequestOptions = { 104 deliveryMode: photoAccessHelper.DeliveryMode.HIGH_QUALITY_MODE, 105 } 106 await photoAccessHelper.MediaAssetManager.requestImageData(context, photoAsset, requestOptions, new MediaDataHandler()); 107 console.info('requestImageData successfully'); 108 fetchResult.close(); 109 } catch (err) { 110 console.error('getAssets failed with err: ' + err); 111 } 112} 113``` 114