1# 使用MediaAssetManager请求媒体资源(C/C++)
2
3使用MediaAssetManager可以实现请求媒体资源到目标沙箱路径,本开发指导将以请求一张图片作为示例,向开发者讲解MediaAssetManager相关功能。
4
5请求图片资源的全流程包含:创建MediaAssetManager,设置请求资源,请求图片资源,取消本次请求(可选)。
6
7## 开发步骤及注意事项
8
9在CMake脚本中链接动态库
10
11```
12target_link_libraries(sample PUBLIC libmedia_asset_manager.so)
13```
14
15开发者通过引入[media_asset_manager.h](../../reference/apis-media-library-kit/media__asset__manager__capi_8h.md)和[media_asset_base_capi.h](../../reference/apis-media-library-kit/media__asset__base__capi_8h.md)头文件,使用MediaAssetManager相关API。
16详细的API说明请参考[MediaAssetManager API](../../reference/apis-media-library-kit/_media_asset_manager.md)。
17
18> **说明:**
19> 开发前,需要参考[开发准备](photoAccessHelper-preparation.md),申请`ohos.permission.READ_IMAGEVIDEO`权限。
20
211. 创建实例:OH_MediaAssetManager_Create()。
222. 设置资源:设置资源请求回调、设置资源请求策略、设置源图片Uri和目标Uri。
233. 请求图片资源:调用OH_MediaAssetManager_RequestImageForPath()请求图片资源到目标Uri。
244. 取消请求:调用OH_MediaAssetManager_CancelRequest()。(可选)
25
26## 完整示例
27
28```c
29#include "napi/native_api.h"
30#include "multimedia/media_library/media_asset_base_capi.h"
31#include "multimedia/media_library/media_asset_manager_capi.h"
32#include "hilog/log.h"
33#include <stdio.h>
34#include <string.h>
35
36const char ERROR_REQUEST_ID[UUID_STR_MAX_LENGTH] = "00000000-0000-0000-0000-000000000000";
37
38// 资源请求回调
39void OnDataPrepared(int32_t result, MediaLibrary_RequestId requestIdStruct)
40{
41    printf("OnDataPrepared requestId: %s result: %d\n", requestIdStruct.requestId, result);
42}
43
44int main()
45{
46    // 创建MediaAssetManager实例
47    OH_MediaAssetManager *manager = OH_MediaAssetManager_Create();
48    if (manager == nullptr) {
49        // 处理异常。
50        printf("Get MediaAssetManager failed.\n");
51    } else {
52        // 设置资源请求回调
53        OH_MediaLibrary_OnDataPrepared callback = OnDataPrepared;
54
55        // 设置资源请求策略
56        MediaLibrary_RequestOptions options;
57        options.deliveryMode = MEDIA_LIBRARY_HIGH_QUALITY_MODE;
58
59        // 预置图片资源Uri,默认为高质量图片。注:以下Uri是示例,开发者需根据实际情况创建或获取
60        const char *srcUri = "file://media/Photo/87/VID_1712195295_025/request_image_src.jpg";
61
62        // 提供目标路径Uri。注:以下Uri是示例,开发者需根据实际情况创建或获取
63        const char *destUri = "file://media/Photo/9/IMG_1712195237_008/request_image_dest.jpg";
64
65        // 将图片资源请求到目标路径
66        MediaLibrary_RequestId requestIdStruct = OH_MediaAssetManager_RequestImageForPath(manager, srcUri,
67            options, destUri, callback);
68
69        if (strcmp(requestIdStruct.requestId, ERROR_REQUEST_ID) == 0) {
70            // 处理异常
71            printf("Request image failed requestId:%s\n", requestIdStruct.requestId);
72        } else {
73            // 请求成功,打印请求Id
74            printf("Request image success, requestId: %s\n", requestIdStruct.requestId);
75
76            // 调用CancelRequest接口,用来取消尚在处理中的请求
77            // 注:OH_MediaAssetManager_CancelRequest不是必须流程,开发者可根据实际情况选择是否调用该接口来取消尚未回调返回的资源请求
78            bool ret = OH_MediaAssetManager_CancelRequest(manager, requestIdStruct);
79        }
80    }
81    return 0;
82}
83```