HarmonyOS 使用 mediaquery 监听屏幕旋转未触发回调

HarmonyOS 使用 mediaquery 监听屏幕旋转未触发回调。

HarmonyOS
2024-11-26 10:29:14
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
fox280

​建议使用窗口层面的方法监听屏幕方向变化:display.getDefaultDisplaySync().orientation

参考链接:

https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-display-V5

对应监听方法参考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%') 
  } 
}
分享
微博
QQ
微信
回复
2024-11-26 16:02:58
相关问题
监听屏幕旋转的案例有哪些
415浏览 • 1回复 待解决
有谁知道如何监听屏幕旋转
2053浏览 • 1回复 待解决
HarmonyOS如何设置应用跟随屏幕旋转
336浏览 • 1回复 待解决
如何实现应用的屏幕自动旋转
2236浏览 • 1回复 待解决
TextInput组件的onBlur、onFocus触发
669浏览 • 1回复 待解决
屏幕自动旋转的示例有哪些?
412浏览 • 1回复 待解决
屏幕旋转计算,有什么好的方案?
910浏览 • 1回复 待解决
禁用屏幕旋转的问题有知道的吗?
2559浏览 • 1回复 待解决
HarmonyOS 属性动画怎么监听帧回
286浏览 • 1回复 待解决
焦点事件onBlur/onFocus回无法触发
1998浏览 • 1回复 待解决