99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何在OpenHarmony上實(shí)現(xiàn)?翻頁(yè)動(dòng)效呢?

OpenHarmony技術(shù)社區(qū) ? 來(lái)源:OST開(kāi)源開(kāi)發(fā)者 ? 2023-06-11 15:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

翻頁(yè)動(dòng)效是應(yīng)用開(kāi)發(fā)中常見(jiàn)的動(dòng)效場(chǎng)景,常見(jiàn)的如書(shū)籍翻頁(yè)、日歷翻頁(yè)等。

本文就為大家舉例講解如何通過(guò) ArkUI 提供的顯示動(dòng)畫(huà)接口 animateTo 實(shí)現(xiàn)書(shū)籍翻頁(yè)的效果。

效果呈現(xiàn)

本例最終實(shí)現(xiàn)效果如下:

39307cba-0826-11ee-962d-dac502259ad0.gif

環(huán)境要求

本例基于以下環(huán)境開(kāi)發(fā),開(kāi)發(fā)者也可以基于其他適配的版本進(jìn)行開(kāi)發(fā):

IDE:DevEco Studio 3.1 Beta1

SDK:Ohos_sdk_public 3.2.11.9 (API Version 9 Release)

實(shí)現(xiàn)思路

如圖,分上下兩層、左右兩側(cè)建立 4 個(gè)文本組件(下文用 A、B、C、D 代稱),左右兩側(cè)分別代表打開(kāi)書(shū)籍的左右兩面,上下兩層堆疊放置。

395d6fae-0826-11ee-962d-dac502259ad0.png

當(dāng) B 沿旋轉(zhuǎn)軸旋轉(zhuǎn) 180 度覆蓋在 A 上時(shí),就體現(xiàn)為翻頁(yè)效果。一個(gè)翻頁(yè)動(dòng)作的完成包括以下幾步:

B 沿旋轉(zhuǎn)軸旋轉(zhuǎn) 180 度。

B 旋轉(zhuǎn)時(shí),D 會(huì)在右側(cè)顯示出來(lái),作為書(shū)籍的下一頁(yè),此時(shí) D 承載的內(nèi)容要變?yōu)橄乱豁?yè)的內(nèi)容。

B 旋轉(zhuǎn)到左側(cè)后,A 承載的內(nèi)容變?yōu)?B 的內(nèi)容。

由于 A 和 B 互為鏡像,所以 A 顯示為 B 的內(nèi)容后,需要以 A 的中間為軸旋轉(zhuǎn) 180 度。

B 重新旋轉(zhuǎn)到右邊,其承載的內(nèi)容變?yōu)橄乱豁?yè)的內(nèi)容。

說(shuō)明:C 用來(lái)占位,不需要做動(dòng)作。連續(xù)重復(fù)上述動(dòng)作即可實(shí)現(xiàn)連續(xù)翻頁(yè)動(dòng)效。

開(kāi)發(fā)步驟

①創(chuàng)建文本組件

動(dòng)效中用到了 4 個(gè)文本組件,因此可以先定義一個(gè)文本組件,然后對(duì)其進(jìn)行重復(fù)調(diào)用。同時(shí)為文本組件添加 rotate 屬性,用來(lái)控制組件的旋轉(zhuǎn)。

由于各組件旋轉(zhuǎn)的角度和旋轉(zhuǎn)中心不同,需要父組件在調(diào)用時(shí)傳入對(duì)應(yīng)的參數(shù),所以需要為對(duì)應(yīng)變量添加 @Prop 裝飾器,用來(lái)控制變量傳遞。

具體代碼如下:

@Component
structBookCard{
//為變量添加@Prop裝飾器,用于接收父組件的動(dòng)態(tài)傳參
@Propnum:number
@Propy_position:string
@Propx_position:string
@Proprotate_angle:number
build(){
Text(`${this.num}`)
.fontWeight(FontWeight.Bold)
.backgroundColor('#18183C')
.fontColor('white')
.fontSize(80)
.width('25%')
.height('30%')
.fontFamily('Monospace')
.textAlign(TextAlign.Center)
.borderRadius(20)
//使用rotate屬性控制旋轉(zhuǎn)
.rotate({
x:0,
y:1,
z:0,
angle:this.rotate_angle,
centerY:this.y_position,
centerX:this.x_position
})
}
}

②創(chuàng)建父組件框架

由于文本組件分為上下兩層,所以在父組件中采用 Stack 組件進(jìn)行層疊布局。

同時(shí)使用 Divider 組件作為書(shū)籍兩個(gè)頁(yè)面間的分隔線。

具體代碼如下:

@Entry
@Component
structBookAnimation{

build(){
Stack(){
Row(){
//組件C
BookCard()
//組件D
BookCard()
}
Row(){
//組件A
BookCard()
//組件B
BookCard()
}
//添加兩個(gè)頁(yè)面間的分隔線
Divider()
.strokeWidth(5)
.color('white')
.height('26%')
.vertical(true)
}
.width('100%')
.height('100%')
.backgroundColor('#A4AE77')
}
}

③添加翻頁(yè)動(dòng)效

最后通過(guò)以下幾點(diǎn)來(lái)為靜態(tài)的組件添加動(dòng)效:

根據(jù)實(shí)現(xiàn)思路章節(jié)的分析,在父組件中定義對(duì)應(yīng)的變量,并在調(diào)用子組件時(shí)分別傳入子組件。

自定義 book_animate 函數(shù),在其中使用 animateTo 方法添加動(dòng)畫(huà)效果,同時(shí)控制動(dòng)畫(huà)的時(shí)長(zhǎng),以及動(dòng)畫(huà)過(guò)程中各元素狀態(tài)的改變。

在 aboutToAppear 方法中,使用 setInterval 方法重復(fù)調(diào)用 book_animate 函數(shù),以實(shí)現(xiàn)連續(xù)翻頁(yè)動(dòng)效。

具體代碼如下:

@Entry
@Component
structBookAnimation{
//父組件變量設(shè)置,注意使用@State做狀態(tài)管理
@Staterotate_angle1:number=0
@Staterotate_angle2:number=0
@Staterotate_angle3:number=0
@Statenum_before:number=0;
@Statenum:number=1;
@Statenum_next:number=0;
@Statey_center1:string='50%'
@Statex_center1:string='50%'
@Statey_center2:string='0%'
@Statex_center2:string='0%'

//在UI顯示前,傳入各項(xiàng)變量的具體值
aboutToAppear(){
//通過(guò)setInterval函數(shù)每秒調(diào)用一次動(dòng)畫(huà)效果,實(shí)現(xiàn)連續(xù)翻頁(yè)
setInterval(()=>{
this.book_animate()
},1000)//函數(shù)調(diào)用周期要大于每次動(dòng)畫(huà)持續(xù)的時(shí)長(zhǎng)
}

privatebook_animate(){
//通過(guò)animateTo方法為組件添加動(dòng)效,動(dòng)效時(shí)長(zhǎng)要小于setInterval函數(shù)調(diào)用周期
animateTo({duration:700,onFinish:()=>{
//動(dòng)畫(huà)結(jié)束時(shí),A顯示的數(shù)字跟B顯示的數(shù)字相等
this.num_before=this.num
//動(dòng)畫(huà)結(jié)束時(shí),A以中心線為軸旋轉(zhuǎn)180度
this.rotate_angle3=180
//動(dòng)畫(huà)結(jié)束時(shí),B返回至初始狀態(tài)
this.rotate_angle1=0
//動(dòng)畫(huà)結(jié)束時(shí),B顯示的數(shù)字加1
this.num=(this.num+1)%10
}
},()=>{
//動(dòng)畫(huà)開(kāi)始,B的旋轉(zhuǎn)角度變?yōu)?80度
this.rotate_angle1=180
//動(dòng)畫(huà)開(kāi)始,D的數(shù)字加1
this.num_next=this.num+1
})
}
build(){
Stack(){
Row(){
//C組件的引用配置
BookCard({num:0,rotate_angle:this.rotate_angle2,
y_position:this.y_center2,x_position:this.x_center2})
//D組件的引用配置
BookCard({num:this.num_next,rotate_angle:this.rotate_angle2,
y_position:this.y_center2,x_position:this.x_center2})
}
Row(){
//A組件的引用配置
BookCard({num:this.num_before,rotate_angle:this.rotate_angle3,
y_position:this.y_center1,x_position:this.x_center1})
//B組件的引用配置
BookCard({num:this.num,rotate_angle:this.rotate_angle1,
y_position:this.y_center2,x_position:this.x_center2})
}
Divider().strokeWidth(5).color('white').height('26%').vertical(true)
}.width('100%').height('50%').backgroundColor('#A4AE77')
}
}

通過(guò)以上步驟就可以實(shí)現(xiàn)翻頁(yè)動(dòng)效了。

完整代碼

示例完整代碼如下:

@Component
structBookCard{
@Propnum:number
@Propy_position:string
@Propx_position:string
@Proprotate_angle:number
build(){
Text(`${this.num}`)
.fontWeight(FontWeight.Bold)
.backgroundColor('#18183C')
.fontColor('white')
.fontSize(80)
.width('25%')
.height('30%')
.fontFamily('Monospace')
.textAlign(TextAlign.Center)
.borderRadius(20)
.rotate({
x:0,
y:1,
z:0,
angle:this.rotate_angle,
centerY:this.y_position,
centerX:this.x_position
})
}
}


@Entry
@Component
structBookAnimation{
@Staterotate_angle1:number=0
@Staterotate_angle2:number=0
@Staterotate_angle3:number=0
@Statenum_before:number=0;
@Statenum:number=1;
@Statenum_next:number=0;
@Statey_center1:string='50%'
@Statex_center1:string='50%'
@Statey_center2:string='0%'
@Statex_center2:string='0%'


aboutToAppear(){
setInterval(()=>{
this.book_animate()
},1000)
}

privatebook_animate(){
animateTo({duration:700,onFinish:()=>{
this.num_before=this.num
this.rotate_angle3=180
this.rotate_angle1=0
this.num=(this.num+1)%10
}
},()=>{
this.rotate_angle1=180
this.num_next=this.num+1
})
}


build(){
Stack(){
Row(){
BookCard({num:0,rotate_angle:this.rotate_angle2,y_position:this.y_center2,
x_position:this.x_center2})
BookCard({num:this.num_next,rotate_angle:this.rotate_angle2,y_position:this.y_center2,
x_position:this.x_center2})
}
Row(){
BookCard({num:this.num_before,rotate_angle:this.rotate_angle3,y_position:this.y_center1,
x_position:this.x_center1})
BookCard({num:this.num,rotate_angle:this.rotate_angle1,y_position:this.y_center2,
x_position:this.x_center2})
}
Divider().strokeWidth(5).color('white').height('26%').vertical(true)
}.width('100%').height('50%').backgroundColor('#A4AE77')
}
}

總結(jié)

OpenHarmony 當(dāng)前提供了相對(duì)比較豐富的能力可以在制作動(dòng)效時(shí)使用,基本可以滿足日常動(dòng)畫(huà)的開(kāi)發(fā),比如平移、旋轉(zhuǎn)、放大縮小、彈簧曲線、轉(zhuǎn)場(chǎng)動(dòng)畫(huà)、三維動(dòng)畫(huà)等等。 大家可以根據(jù)業(yè)務(wù)需要組合使用,也歡迎大家將自己的經(jīng)驗(yàn)分享出來(lái),我們一起學(xué)習(xí)啦!





審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • OpenHarmony
    +關(guān)注

    關(guān)注

    29

    文章

    3854

    瀏覽量

    18629

原文標(biāo)題:OpenHarmony上實(shí)現(xiàn)?翻頁(yè)動(dòng)效

文章出處:【微信號(hào):gh_834c4b3d87fe,微信公眾號(hào):OpenHarmony技術(shù)社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    LabVIEW實(shí)現(xiàn)波形圖表的翻頁(yè)顯示有什么辦法?

    各位好,我剛學(xué)LabVIEW不久,想請(qǐng)教下各位:LabVIEW中如何實(shí)現(xiàn)波形圖表的翻頁(yè)顯示? 波形回放在波形圖表控件中,怎樣用控件或鍵盤操作來(lái)實(shí)現(xiàn)波形的翻頁(yè)顯示,比如在前面板
    發(fā)表于 03-29 11:08

    動(dòng)設(shè)計(jì)的這些設(shè)計(jì)流程你知道嗎

    交互設(shè)計(jì)師想要認(rèn)真和你聊聊動(dòng)設(shè)計(jì)
    發(fā)表于 02-25 06:39

    何在OLED上面播放動(dòng)

    何在OLED上面播放動(dòng)?如何去實(shí)現(xiàn)?
    發(fā)表于 01-21 06:29

    何在RK3399 Android8.1實(shí)現(xiàn)APK靜默安裝功能

    何在RK3399 Android8.1實(shí)現(xiàn)APK靜默安裝功能?其測(cè)試過(guò)程是如何去實(shí)現(xiàn)?
    發(fā)表于 02-15 07:01

    何在RK3568芯片上面運(yùn)行OpenHarmony

    RK3568芯片有哪些功能?如何在RK3568芯片上面運(yùn)行OpenHarmony
    發(fā)表于 03-02 08:13

    OpenHarmony標(biāo)準(zhǔn)設(shè)備應(yīng)用開(kāi)發(fā)筆記匯總

    何在標(biāo)準(zhǔn)設(shè)備運(yùn)行一個(gè)最簡(jiǎn)單的 OpenHarmony 程序。2、如何在OpenHarmony實(shí)現(xiàn)
    發(fā)表于 03-28 14:19

    OpenHarmony 3.1 Beta版本關(guān)鍵特性解析——OpenHarmony圖形框架

    繪制與渲染流程解決了跨窗口聯(lián)動(dòng)問(wèn)題后,上面示例中桌面和壁紙模糊效果呈現(xiàn)時(shí),也能同步看到壁紙的動(dòng),如下:此外,OpenHarmony 圖形棧從時(shí)間和空間提供了更豐富的
    發(fā)表于 04-13 18:24

    app圖標(biāo)動(dòng)openharmony的源碼哪里實(shí)現(xiàn)的?

    openharmony點(diǎn)擊一個(gè)app圖標(biāo)的之后,應(yīng)用會(huì)從左上角一點(diǎn)點(diǎn)放大直至鋪滿屏幕;我想問(wèn)一下這個(gè)動(dòng)是在openharmony的源碼
    發(fā)表于 06-10 11:01

    華為圖像服務(wù)場(chǎng)景動(dòng)Java示例代碼

    簡(jiǎn)介 場(chǎng)景動(dòng)服務(wù)提供基礎(chǔ)動(dòng)和高級(jí)動(dòng),幫助您實(shí)現(xiàn)
    發(fā)表于 03-23 11:06 ?0次下載

    何在OpenHarmony開(kāi)源代碼基礎(chǔ)實(shí)現(xiàn)數(shù)字管家開(kāi)發(fā)宿舍全屋智能

    基于OpenAtom OpenHarmony(以下簡(jiǎn)稱“OpenHarmony”)、數(shù)字管家開(kāi)發(fā)宿舍全屋智能,實(shí)現(xiàn)碰一碰開(kāi)門、碰一碰開(kāi)燈、碰一碰開(kāi)風(fēng)扇以及煙感檢測(cè)。因?yàn)楦黜?xiàng)目開(kāi)發(fā)流程大體相似,本文主要以碰一碰開(kāi)門為例介紹如
    的頭像 發(fā)表于 08-26 09:55 ?2218次閱讀

    在DAYU200實(shí)現(xiàn)OpenHarmony跳轉(zhuǎn)撥號(hào)界面

    ,打電話是最常見(jiàn)的交流方式之一,那么如何在OpenAtom OpenHarmony(簡(jiǎn)稱“OpenHarmony”)中進(jìn)行電話服務(wù)相關(guān)的開(kāi)發(fā)?今天我們可以一起來(lái)了解一下如何通過(guò)電話服
    的頭像 發(fā)表于 10-17 22:05 ?936次閱讀

    玩嗨OpenHarmony:基于OpenHarmony的ArkUI翻頁(yè)時(shí)鐘

    設(shè)備,用電腦動(dòng)畫(huà)的方式實(shí)現(xiàn)翻頁(yè)時(shí)鐘,也是一種特別的復(fù)古UI交互體驗(yàn)。 本項(xiàng)目豈在通過(guò)OpenHarmony的ArkUI框架,用TS擴(kuò)展的聲明式開(kāi)發(fā)范式eTS,來(lái)實(shí)現(xiàn)
    的頭像 發(fā)表于 12-05 20:15 ?1835次閱讀

    何在OpenHarmony開(kāi)發(fā)服務(wù)卡片

    本篇文章我們將分享如何在 OpenHarmony 開(kāi)發(fā)服務(wù)卡片。
    的頭像 發(fā)表于 04-10 11:12 ?1525次閱讀

    OpenHarmony實(shí)現(xiàn)彈性動(dòng)的方法

    在動(dòng)畫(huà)開(kāi)發(fā)場(chǎng)景中,經(jīng)常用到彈性效果,尤其在拖拽某個(gè)對(duì)象時(shí)經(jīng)常伴隨彈性動(dòng)。
    的頭像 發(fā)表于 06-11 15:12 ?1080次閱讀
    在<b class='flag-5'>OpenHarmony</b><b class='flag-5'>上</b><b class='flag-5'>實(shí)現(xiàn)</b>彈性<b class='flag-5'>動(dòng)</b><b class='flag-5'>效</b>的方法

    2.4G激光翻頁(yè)筆方案,可實(shí)現(xiàn)多種功能,高性價(jià)比標(biāo)準(zhǔn)方案

    接收器插入計(jì)算機(jī)的USB接口,然后通過(guò)點(diǎn)擊翻頁(yè)對(duì)應(yīng)按鈕來(lái)實(shí)現(xiàn)翻頁(yè)等功能。2.4G翻頁(yè)筆在學(xué)校、事業(yè)單位、培訓(xùn)機(jī)構(gòu)、商務(wù)交流等場(chǎng)合下廣泛使
    的頭像 發(fā)表于 05-24 16:04 ?1302次閱讀
    2.4G激光<b class='flag-5'>翻頁(yè)</b>筆方案,可<b class='flag-5'>實(shí)現(xiàn)</b>多種功能,高性價(jià)比標(biāo)準(zhǔn)方案