開源項目 OpenHarmony是每個人的 OpenHarmony
data:image/s3,"s3://crabby-images/b88c5/b88c5ac2a1af0cde88c756cc3d8b2db849e8ffed" alt="9579cde2-9692-11ed-bfe3-dac502259ad0.png"
徐建國(堅果)
江蘇潤開鴻數字科技有限公司 生態技術專家
前言
在日常開發中,大多APP可能根據實際情況直接將APP的界面方向固定,或豎屏或橫屏。但在使用過程中,我們還是會遇到橫豎屏切換的功能需求,可能是通過物理重力感應觸發,也有可能是用戶手動觸發。所以本文主要帶大家了解在OpenAtom OpenHarmony(以下簡稱“OpenHarmony”)應用開發的過程中,如何在Stage模型和FA模型下使用對應的接口去完成橫豎屏的切換。 本文中OpenHarmony版本為3.2 Beta4,API版本為9。開發板為DAYU200。FA模型
FA模型下,setDisplayOrientation和setDisplayOrientation是切換橫豎屏的接口。文檔:
https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis/js-apis-inner-app-context.md#contextsetdisplayorientation7
context.setDisplayOrientation setDisplayOrientation(orientation: bundle.DisplayOrientation, callback: AsyncCallback): void 設置當前能力的顯示方向(callback形式)。 系統能力: SystemCapability.Ability.AbilityRuntime.Core 參數:data:image/s3,"s3://crabby-images/d3598/d3598c57a292f111dc0cd756f6c2423c3ac03178" alt="95a190e8-9692-11ed-bfe3-dac502259ad0.png"
import featureAbility from '@ohos.ability.featureAbility';
import bundle from '@ohos.bundle';
//FA模型下獲取context
var context = featureAbility.getContext();
var orientation = bundle.DisplayOrientation.UNSPECIFIED;
context.setDisplayOrientation(orientation, (err) => {
console.info("setDisplayOrientation err: " + JSON.stringify(err));
});
完整代碼
import bundle from '@ohos.bundle';
import featureAbility from '@ohos.ability.featureAbility';
struct Index {
string = '橫豎屏切換 '
message: boolean = true
portrait: build() {
Row() {
Column() {
Text(this.message)
.fontSize(30)
.fontWeight(FontWeight.Bold).onClick(() => {
var context = featureAbility.getContext();
if (this.portrait) {
// 橫屏
var orientation = bundle.DisplayOrientation.LANDSCAPE;
context.setDisplayOrientation(orientation, (err) => {
this.portrait = !this.portrait
console.info("setDisplayOrientation err: " + JSON.stringify(err));
});
} else {
//豎屏
var orientation = bundle.DisplayOrientation.PORTRAIT;
context.setDisplayOrientation(orientation, (err) => {
this.portrait = !this.portrait
console.info("setDisplayOrientation err: " + JSON.stringify(err));
});
}
})
}
.width('100%')
}
.height('100%')
}
}
上面這樣寫太亂了,我們可以封裝一下:
import bundle from '@ohos.bundle';
import featureAbility from '@ohos.ability.featureAbility';
struct Index {
string = '橫豎屏切換 '
message: boolean = true
portrait: private changePortrait() {
var context = featureAbility.getContext();
if (this.portrait) {
// 橫屏
var orientation = bundle.DisplayOrientation.LANDSCAPE;
context.setDisplayOrientation(orientation, (err) => {
this.portrait = !this.portrait
console.info("setDisplayOrientation err: " + JSON.stringify(err));
});
} else {
//豎屏
var orientation = bundle.DisplayOrientation.PORTRAIT;
context.setDisplayOrientation(orientation, (err) => {
this.portrait = !this.portrait
console.info("setDisplayOrientation err: " + JSON.stringify(err));
});
}
}
build() {
Row() {
Column() {
Text(this.message)
.fontSize(30)
.fontWeight(FontWeight.Bold).onClick(() => {
this.changePortrait()
})
}
.width('100%')
}
.height('100%')
}
}
Stage模型
從API 9開始,可以使用setPreferredOrientation來切換橫豎屏。文檔:
https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis/js-apis-window.md#setpreferredorientation9
在Stage模型中,使用到的主要是Window(窗口)。在設置橫豎屏切換的時候,需要先使用getLastWindow()、createWindow()、findWindow()中的任一方法獲取到Window實例,再通過此實例調用對應的方法,本文使用的是getLastWindow。 Window.getLastWindow getLastWindow(ctx: BaseContext): Promise獲取當前應用內最后顯示的窗口,使用Promise異步回調。 系統能力: SystemCapability.WindowManager.WindowManager.Core 參數:data:image/s3,"s3://crabby-images/c9081/c9081d26f605c8f2263abc746629e30a01b00ac1" alt="95cba716-9692-11ed-bfe3-dac502259ad0.png"
data:image/s3,"s3://crabby-images/3935c/3935cc7b5609f7d7c3bf29bb2b0cddc12cba360f" alt="95d47fa8-9692-11ed-bfe3-dac502259ad0.png"
data:image/s3,"s3://crabby-images/3e0fd/3e0fd046ba4fb2a46536b16cdc1b464dd725752a" alt="95fa15f6-9692-11ed-bfe3-dac502259ad0.png"
let windowClass = null;
try {
let promise = window.getLastWindow(this.context);
promise.then((data)=> {
windowClass = data;
console.info('Succeeded in obtaining the top window. Data: ' + JSON.stringify(data));
}).catch((err)=>{
console.error('Failed to obtain the top window. Cause: ' + JSON.stringify(err));
});
} catch (exception) {
console.error('Failed to obtain the top window. Cause: ' + JSON.stringify(exception));
}
然后就可以使用setPreferredOrientation屬性。
setPreferredOrientation
setPreferredOrientation(orientation: Orientation): Promise
設置窗口的顯示方向屬性,使用Promise異步回調。
系統能力:
SystemCapability.WindowManager.WindowManager.Core
參數:data:image/s3,"s3://crabby-images/109e0/109e0319a117e31602a59dfc88a4f702c8ff3a04" alt="9610352a-9692-11ed-bfe3-dac502259ad0.png"
data:image/s3,"s3://crabby-images/d659f/d659fc9ad9fb226de64316bf4f4d33eb06542a87" alt="963309f6-9692-11ed-bfe3-dac502259ad0.png"
data:image/s3,"s3://crabby-images/dfc9a/dfc9a4b1c375317bf949d62be26c6e07cd8efc52" alt="96482ffc-9692-11ed-bfe3-dac502259ad0.png"
let orientation = window.Orientation.AUTO_ROTATION;
try {
let promise = windowClass.setPreferredOrientation(orientation);
promise.then(()=> {
console.info('Succeeded in setting the window orientation.');
}).catch((err)=>{
console.error('Failed to set the window orientation. Cause: ' + JSON.stringify(err));
});
} catch (exception) {
console.error('Failed to set window orientation. Cause: ' + JSON.stringify(exception));
}
完整代碼
importWindowfrom'@ohos.window'
import common from '@ohos.app.ability.common';
struct ArkUIClubTest {
private portrait: boolean = true
build() {
Stack() {
Button("橫豎屏切換")
.onClick(() => {
this.changeOrientation()
})
}
.width('100%')
.height('100%')
}
private changeOrientation() {
let windowClass = null;
//獲取上下文
//var context = getContext(this) as any
// 獲取上下文,使用common模塊
var context = getContext(this) as common.UIAbilityContext;
let promise = Window.getLastWindow(context);
promise.then((data) => {
windowClass = data;
if (this.portrait) {
//切換成橫屏
let orientation = Window.Orientation.LANDSCAPE;
windowClass.setPreferredOrientation(orientation, (err) => {
});
this.portrait = !this.portrait
console.info('Succeeded in obtaining the top window. Data: ' + JSON.stringify(data));
}
else {
//切換成豎屏
let orientation = Window.Orientation.PORTRAIT;
windowClass.setPreferredOrientation(orientation, (err) => {
});
this.portrait = !this.portrait
console.info('Succeeded in obtaining the top window. Data: ' + JSON.stringify(data));
}
}).catch((err) => {
console.error('Failed to obtain the top window. Cause: ' + JSON.stringify(err));
});
}
}
總結
本文帶大家使用對應的接口,在Stage模型和FA模型下完成了橫豎屏的切換。其中還涉及到了上下文的獲取:Stage模型用(getContext(this) as any),FA模型(featureAbility.getContext()),大家可以在此基礎上利用生命周期的回調,在合適的地方完成對應的操作。
原文標題:OpenHarmony如何切換橫豎屏?
文章出處:【微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。
-
鴻蒙
+關注
關注
57文章
2401瀏覽量
43177 -
OpenHarmony
+關注
關注
25文章
3757瀏覽量
16795
原文標題:OpenHarmony如何切換橫豎屏?
文章出處:【微信號:gh_e4f28cfa3159,微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
OpenHarmony默認30秒熄屏太麻煩?觸覺智能鴻蒙開發板教你輕松取消
data:image/s3,"s3://crabby-images/4ba01/4ba01898a210801373f09a0587675c4b9a7449c6" alt="<b class='flag-5'>OpenHarmony</b>默認30秒熄<b class='flag-5'>屏</b>太麻煩?觸覺智能鴻蒙開發板教你輕松取消"
貝啟科技亮相OpenHarmony人才生態大會2024
第三屆OpenHarmony技術大會星光璀璨、致謝OpenHarmony社區貢獻者
OpenHarmony年度技術俱樂部、個人及活動評選結果公示
基于ArkTS語言的OpenHarmony APP應用開發:HelloOpenharmony
data:image/s3,"s3://crabby-images/8dd00/8dd0023612e82eb10761f7533e54a00b18aabdf9" alt="基于ArkTS語言的<b class='flag-5'>OpenHarmony</b> APP應用開發:Hello<b class='flag-5'>Openharmony</b>"
基于ArkTS語言的OpenHarmony APP應用開發:HelloOpenharmony
鴻蒙開發系統基礎能力:ohos.screenLock 鎖屏管理
data:image/s3,"s3://crabby-images/b6741/b6741adffd1a8f6b645170fe02fb080f5eea9865" alt="鴻蒙開發系統基礎能力:ohos.screenLock 鎖<b class='flag-5'>屏</b>管理"
鴻蒙開發接口資源管理:【@ohos.resourceManager (資源管理)】
data:image/s3,"s3://crabby-images/ee100/ee100e55fe797f3bcd44411af6995a9c99fd9d8c" alt="鴻蒙開發接口資源管理:【@ohos.resourceManager (資源管理)】"
求助,關于STM32F429I-EVAL評估板橫屏切換豎屏問題求解
九聯開鴻加入開放原子開源基金會OpenHarmony醫療健康專委會
data:image/s3,"s3://crabby-images/44695/44695b413a0f44af3367d01ed73bd2c611896024" alt="九聯開鴻加入開放原子開源基金會<b class='flag-5'>OpenHarmony</b>醫療健康專委會"
stm32f429 emwin切換窗口閃屏的原因?
OpenHarmony南向能力征集令
OpenHarmony內核編程實戰
data:image/s3,"s3://crabby-images/a8a7e/a8a7e70bcfdd025829d4eb259a443012cd873d23" alt="<b class='flag-5'>OpenHarmony</b>內核編程實戰"
評論