HarmonyOS 鸿蒙Next 播放视频的时候禁止息屏

发布于 1周前 作者 caililin 来自 鸿蒙OS

HarmonyOS 鸿蒙Next 播放视频的时候禁止息屏 播放视频的时候禁止息屏代码实现

2 回复

你好,可以使用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,

回到顶部