在HarmonyOS NEXT 中使用 mediaquery 监听屏幕旋转未触发回调的解决方法?

阅读 695
1 个回答

建议使用窗口层面的方法监听屏幕方向变化:display.getDefaultDisplaySync().orientation
参考链接:
https://developer.huawei.com/consumer/cn/doc/harmonyos-refere...
对应监听方法参考Demo如下:

display.on("change",(data)=>{ 
  let o=display.getDefaultDisplaySync().orientation; 
  switch (o){ 
    case 0:this.status='竖屏';break; 
    case 1:this.status='横屏';break; 
    case 2:this.status='反向竖屏';break; 
    case 3:this.status='反向横屏';break; 
  } 
})

display.on监听屏幕旋转正常触发回调,参考Demo如下:

import { Callback } from '@ohos.base'; 
import { display, window } from '@kit.ArkUI'; 
 
@Entry 
@Component 
struct DisplayTest { 
  @State message: string = 'Hello World'; 
 
  aboutToAppear(): void { 
    let callback: Callback<number> = (data: number) => { 
      console.info('Listening enabled. Data: ' + JSON.stringify(data)); 
        }; 
    try { 
      display.on("change", callback); 
    } catch (exception) { 
      console.error('Failed to register callback. Code: ' + JSON.stringify(exception)); 
    } 
  } 
 
  build() { 
    Column() { 
      Text(this.message) 
        .id('HelloWorld') 
        .fontSize(50) 
        .fontWeight(FontWeight.Bold) 
        .alignRules({ 
          center: { anchor: '__container__', align: VerticalAlign.Center }, 
          middle: { anchor: '__container__', align: HorizontalAlign.Center } 
        }) 
      Button('点击横屏') 
        .onClick(() => { 
          window.getLastWindow(getContext(this), (err, win) => { 
            win.setPreferredOrientation(window.Orientation.LANDSCAPE_INVERTED) 
          }) 
        }) 
      Button('点击竖屏') 
        .onClick(() => { 
          window.getLastWindow(getContext(this), (err, win) => { 
            win.setPreferredOrientation(window.Orientation.PORTRAIT) 
          }) 
        }) 
    } 
    .height('100%') 
    .width('100%') 
  } 
}

本文参与了 【 HarmonyOS NEXT 技术问答冲榜,等你来战!】欢迎正在阅读的你也加入。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题