HarmonyOS 鸿蒙Next 播放视频的时候禁止息屏
HarmonyOS 鸿蒙Next 播放视频的时候禁止息屏 播放视频的时候禁止息屏代码实现
你好,可以使用setWindowKeepScreenOn实现,参考链接:https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-window-V5#windowgetlastwindow9
import { BusinessError } from '@kit.BasicServicesKit';
import { window } from '@kit.ArkUI';
@Entry
@Component
struct VideoPage4 {
@State message: string = 'Hello World';
@State videoSrc: Resource = $rawfile('video.mp4')
@State previewUri: Resource = $r('app.media.startIcon')
@State curRate: PlaybackSpeed = PlaybackSpeed.Speed_Forward_1_00_X
@State isAutoPlay: boolean = false
@State showControls: boolean = true
controller: VideoController = new VideoController()
@State isKeepScreenOn: boolean = true;
setWindowKeep() {
try {
let windowClass: window.Window | undefined = undefined;
let promise = window.getLastWindow(getContext());
promise.then((data) => {
windowClass = data;
windowClass.setWindowKeepScreenOn(this.isKeepScreenOn, (err: BusinessError) => {
const errCode: number = err.code;
if (errCode) {
console.error(`Failed to set the screen to be always on. Cause code: ${err.code}, message: ${err.message}`);
return;
}
console.info('Succeeded in setting the screen to be always on.');
});
})
} catch (exception) {
console.error(`Failed to set the screen to be always on. Cause code: ${exception.code}, message: ${exception.message}`);
}
}
build() {
Column(){
Video({
src: this.videoSrc,
previewUri: this.previewUri,
currentProgressRate: this.curRate,
controller: this.controller
})
.width('100%')
.height(600)
.autoPlay(this.isAutoPlay)
.controls(this.showControls)
.onStart(() => {
console.info('onStart')
})
.onPause(() => {
console.info('onPause')
})
.onFinish(() => {
console.info('onFinish')
})
.onError(() => {
console.info('onError')
})
.onStop(() => {
console.info('onStop')
})
Row() {
Button('start').onClick(() => {
this.controller.start() // 开始播放
this.setWindowKeep()
}).margin(2)
Button('pause').onClick(() => {
this.controller.pause() // 暂停播放
}).margin(2)
Button('stop').onClick(() => {
this.controller.stop() // 结束播放
}).margin(2)
Button('reset').onClick(() => {
this.controller.reset() // 重置AVPlayer
}).margin(2)
Button('setTime').onClick(() => {
this.controller.setCurrentTime(10, SeekMode.Accurate) // 精准跳转到视频的10s位置
}).margin(2)
}
}
}
}
更多关于HarmonyOS 鸿蒙Next 播放视频的时候禁止息屏的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
在HarmonyOS(鸿蒙)Next系统中,播放视频时禁止息屏的功能通常是由系统或应用自身管理的,以确保用户在观看视频时屏幕不会自动关闭。
HarmonyOS系统提供了多种API和设置选项,允许开发者在应用内控制屏幕常亮。对于视频播放应用来说,开发者可以在视频播放时发送一个请求到系统,以阻止屏幕进入休眠状态。这通常通过调用系统的电源管理API来实现,这些API允许应用请求特定的电源状态,如保持屏幕常亮。
具体到用户层面,如果使用的是第三方视频播放应用,可以检查该应用是否有“播放时保持屏幕常亮”的设置选项。如果有,开启该选项即可在播放视频时禁止息屏。
如果是开发者,需要在自己的应用中实现这一功能,可以查阅HarmonyOS的官方文档,了解如何使用电源管理API来请求屏幕常亮状态。
请注意,长时间保持屏幕常亮可能会消耗更多的电量,因此建议用户在不需要时及时关闭该功能以节省电量。
如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html,