代码拉取完成,页面将自动刷新
/*
* Copyright (c) 2024 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { media } from '@kit.MediaKit';
import { common } from '@kit.AbilityKit';
import Logger from '../utils/Logger';
export class AVPlayerUtil {
private surfaceId: string = '';
private avPlayer: media.AVPlayer | undefined = undefined;
private callBack: Function = () => {
};
setSurfaceId(surfaceId: string) {
this.surfaceId = surfaceId;
}
setAVPlayerCallback(avPlayer: media.AVPlayer) {
avPlayer.on('stateChange', async (state: string) => {
switch (state) {
case 'idle':
Logger.info('AVPlayer state idle called.');
avPlayer.release();
break;
case 'initialized':
Logger.info('AVPlayer state initialized called.');
avPlayer.surfaceId = this.surfaceId;
avPlayer.prepare();
break;
case 'prepared':
Logger.info('AVPlayer state prepared called.');
avPlayer.play();
break;
case 'playing':
Logger.info('AVPlayer state playing called.');
break;
case 'paused':
Logger.info('AVPlayer state paused called.');
break;
case 'completed':
Logger.info('AVPlayer state completed called.');
avPlayer.play();
break;
case 'stopped':
Logger.info('AVPlayer state stopped called.');
avPlayer.reset();
break;
case 'released':
Logger.info('AVPlayer state released called.');
break;
default:
break;
}
})
// get video height and width
avPlayer.on('videoSizeChange', (width: number, height: number) => {
Logger.info('videoSizeChange called,and width is:' + width + ', height is :' + height);
this.callBack(height / width);
})
}
async initPlayer(url: string, callBack: Function) {
this.avPlayer = await media.createAVPlayer();
this.callBack = callBack;
this.setAVPlayerCallback(this.avPlayer);
let context = getContext(this) as common.UIAbilityContext;
let fileDescriptor = await context.resourceManager.getRawFd(url);
let avFileDescriptor: media.AVFileDescriptor =
{ fd: fileDescriptor.fd, offset: fileDescriptor.offset, length: fileDescriptor.length };
this.avPlayer.fdSrc = avFileDescriptor;
Logger.info('fdSrc: ' + this.avPlayer.fdSrc);
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。