《鸿蒙开发-答案之书》获取视频第一帧和视频时间

《鸿蒙开发-答案之书》获取视频第一帧和视频时间
typescript 复制代码
/**
     * 获取视频信息
     *```
     *let result = await MySightUtil.getSightInfo(this.sightUri);
     *let base64 : string = result[0];
     *let duration : number = result[1]
     *```
     * @param uri 视频地址
     * @returns 第一个数据是缩略图 base64 字符串,第二个是视频时长(单位秒)
     */
    public static async getSightInfo(uri: string): Promise<[string, number]> {
        let file = fs.openSync(uri, fs.OpenMode.READ_ONLY);
        let fdSrc: media.AVFileDescriptor = {
            fd: file.fd
        };

        // 视频第一帧
        let base64 = '';
        try {
            // 获取第一帧
            let avImageGenerator: media.AVImageGenerator = await media.createAVImageGenerator();
            // 设置fdSrc

            avImageGenerator.fdSrc = fdSrc;
            // 初始化入参
            let timeUs = 0;
            let queryOption = media.AVImageQueryOptions.AV_IMAGE_QUERY_NEXT_SYNC;
            let param: media.PixelMapParams = {};
            // 获取缩略图(promise模式)
            let pixelMap = await avImageGenerator.fetchFrameByTime(timeUs, queryOption, param);
            // 释放资源(promise模式)
            await avImageGenerator.release();
            const MAX_SIZE = 240;
            const MIN_SIZE = 100;
            await calculateThumbnailScaling(pixelMap, MAX_SIZE, MIN_SIZE);

            const imagePackerApi: image.ImagePacker = image.createImagePacker();
            let packOpts: image.PackingOption = { format: 'image/jpeg', quality: 80 };
            let data: ArrayBuffer = await imagePackerApi.packing(pixelMap, packOpts);
            let buf: buffer.Buffer = buffer.from(data);
            base64 = buf.toString('base64', 0, buf.length);
        } catch (error) {
            let err = error as BusinessError;
            hilog.error(0x0000, '', `error code: ${err.code}, error message: ${err.message}`);
        }

        // 视频时长
        let duration: number = 0;
        try {
            // 获取视频时长
            let aVMetadataExtractor: media.AVMetadataExtractor = await media.createAVMetadataExtractor();
            aVMetadataExtractor.fdSrc = fdSrc;
            let metadata = await aVMetadataExtractor.fetchMetadata();
            aVMetadataExtractor.release();
            // 毫秒
            duration = new Number(metadata.duration).valueOf();

            hilog.error(0x0000, 'IM-APP', `metadata: %{public}s`, JSON.stringify(metadata));
        } catch (error) {
            let err = error as BusinessError;
            hilog.error(0x0000, '', `error code: ${err.code}, error message: ${err.message}`);
        }

        return [base64, duration / 1000];
    }
相关推荐
前端世界3 小时前
HarmonyOS 实战:6 种实现实时数据更新的方案全解析(含完整 Demo)
华为·harmonyos
万少14 小时前
可可图片编辑 HarmonyOS 上架应用分享
前端·harmonyos
zhanshuo14 小时前
鸿蒙开发实战:掌握 Promise 和 async/await,轻松搞定异步请求
harmonyos
simple_lau20 小时前
H5资源包热更新:从下载、解压到渲染的实现方案
typescript·harmonyos·arkts
程序员二师兄20 小时前
记一次鸿蒙webview图片渲染失败的问题
前端·javascript·harmonyos
缘澄20 小时前
ArkTs声明式UI开发
harmonyos
大雷神1 天前
鸿蒙中应用框架和应用模型
华为·harmonyos
马剑威(威哥爱编程)1 天前
鸿蒙 NEXT开发中轻松实现人脸识别功能
华为·harmonyos·arkts·鸿蒙
张风捷特烈1 天前
鸿蒙纪·Flutter卷#03 | 从配置证书到打包发布
android·flutter·harmonyos
大雷神2 天前
鸿蒙安卓前端中加载丢帧:ArkWeb分析
harmonyos