精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何通過顯示動畫實現書籍翻頁動效(OpenHarmony)

系統 OpenHarmony
本文就為大家舉例講解如何通過ArkUI提供的顯示動畫接口animateTo實現書籍翻頁的效果。

想了解更多關于開源的內容,請訪問:

51CTO 開源基礎軟件社區

https://ost.51cto.com

場景介紹

翻頁動效是應用開發中常見的動效場景,常見的如書籍翻頁、日歷翻頁等。本文就為大家舉例講解如何通過ArkUI提供的顯示動畫接口animateTo實現書籍翻頁的效果。

效果呈現

本例最終實現效果如下:

如何通過顯示動畫實現書籍翻頁動效(OpenHarmony)-開源基礎軟件社區

環境要求

本例基于以下環境開發,開發者也可以基于其他適配的版本進行開發:

  • IDE:DevEco Studio 3.1 Beta1
  • SDK:Ohos_sdk_public 3.2.11.9 (API Version 9 Release)

實現思路

如圖,分上下兩層、左右兩側建立4個文本組件(下文用A、B、C、D代稱),左右兩側分別代表打開書籍的左右兩面,上下兩層堆疊放置。
當B沿旋轉軸旋轉180度覆蓋在A上時,就體現為翻頁效果。一個翻頁動作的完成包括以下幾步:

  1. B沿旋轉軸旋轉180度。
  2. B旋轉時,D會在右側顯示出來,作為書籍的下一頁,此時D承載的內容要變為下一頁的內容。
  3. B旋轉到左側后,A承載的內容變為B的內容。
  4. 由于A和B互為鏡像,所以A顯示為B的內容后,需要以A的中間為軸旋轉180度。
  5. B重新旋轉到右邊,其承載的內容變為下一頁的內容。

說明:C用來占位,不需要做動作。
連續重復上述動作即可實現連續翻頁動效。

如何通過顯示動畫實現書籍翻頁動效(OpenHarmony)-開源基礎軟件社區

開發步驟

創建文本組件

動效中用到了4個文本組件,因此可以先定義一個文本組件,然后對其進行重復調用。同時為文本組件添加rotate屬性,用來控制組件的旋轉。
由于各組件旋轉的角度和旋轉中心不同,需要父組件在調用時傳入對應的參數,所以需要為對應變量添加@Prop裝飾器,用來控制變量傳遞。具體代碼如下:

@Component
struct BookCard{
  // 為變量添加@Prop裝飾器,用于接收父組件的動態傳參
  @Prop num:number
  @Prop y_position:string
  @Prop x_position:string
  @Prop rotate_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屬性控制旋轉
      .rotate({
        x: 0,
        y: 1,
        z: 0,
        angle: this.rotate_angle,
        centerY: this.y_position,
        centerX: this.x_position
      })
  }
}

創建父組件框架

由于文本組件分為上下兩層,所以在父組件中采用Stack組件進行層疊布局。同時使用Divider組件作為書籍兩個頁面間的分隔線。具體代碼如下:

@Entry
@Component
struct BookAnimation {

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

添加翻頁動效

最后通過以下幾點來為靜態的組件添加動效:

  • 根據實現思路章節的分析,在父組件中定義對應的變量,并在調用子組件時分別傳入子組件。
  • 自定義book_animate函數,在其中使用animateTo方法添加動畫效果,同時控制動畫的時長,以及動畫過程中各元素狀態的改變。
  • 在aboutToAppear方法中,使用setInterval方法重復調用book_animate函數,以實現連續翻頁動效。
    具體代碼如下:
@Entry
@Component
struct BookAnimation {
  // 父組件變量設置,注意使用@State做狀態管理
  @State rotate_angle1:number = 0
  @State rotate_angle2:number = 0
  @State rotate_angle3:number = 0
  @State num_before: number = 0;
  @State num: number = 1;
  @State num_next: number = 0;
  @State y_center1:string = '50%'
  @State x_center1:string = '50%'
  @State y_center2:string = '0%'
  @State x_center2:string = '0%'

  // 在UI顯示前,傳入各項變量的具體值
  aboutToAppear() {
    // 通過setInterval函數每秒調用一次動畫效果,實現連續翻頁
    setInterval(() => {
      this.book_animate()
    }, 1000)//函數調用周期要大于每次動畫持續的時長
  }

  private book_animate(){
    // 通過animateTo方法為組件添加動效,動效時長要小于setInterval函數調用周期
    animateTo({ duration:700,onFinish:()=>{
      // 動畫結束時,A顯示的數字跟B顯示的數字相等
      this.num_before = this.num
      // 動畫結束時,A以中心線為軸旋轉180度
      this.rotate_angle3 = 180
      // 動畫結束時,B返回至初始狀態
      this.rotate_angle1 = 0
      // 動畫結束時,B顯示的數字加1
      this.num = (this.num + 1) % 10
    }
    },()=>{
      // 動畫開始,B的旋轉角度變為180度
      this.rotate_angle1 = 180
      // 動畫開始,D的數字加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')
  }
}

通過以上步驟就可以實現翻頁動效了。

完整代碼

示例完整代碼如下:

@Component
struct BookCard{
  @Prop num:number
  @Prop y_position:string
  @Prop x_position:string
  @Prop rotate_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
struct BookAnimation {
  @State rotate_angle1:number = 0
  @State rotate_angle2:number = 0
  @State rotate_angle3:number = 0
  @State num_before: number = 0;
  @State num: number = 1;
  @State num_next: number = 0;
  @State y_center1:string = '50%'
  @State x_center1:string = '50%'
  @State y_center2:string = '0%'
  @State x_center2:string = '0%'


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

  private book_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')
  }
}

總結

OpenHarmony當前提供了相對比較豐富的能力可以在制作動效時使用,基本可以滿足日常動畫的開發,比如平移、旋轉、放大縮小、彈簧曲線、轉場動畫、三維動畫等等,大家可以根據業務需要組合使用,也歡迎大家將自己的經驗分享出來,我們一起學習啦!

想了解更多關于開源的內容,請訪問:

51CTO 開源基礎軟件社區

https://ost.51cto.com

責任編輯:jianghua 來源: 51CTO 開源基礎軟件社區
相關推薦

2025-08-11 09:13:31

2022-03-31 07:46:17

CSS動畫技巧

2010-08-18 09:03:46

jQueryJSONTrimpath

2015-09-28 09:07:51

2015-07-31 11:40:36

動效Swift

2022-07-20 15:32:25

時鐘翻頁Text組件

2021-04-15 07:50:45

Veu 動效Vue應用程序

2016-09-19 13:44:54

vue翻頁組件Web

2021-06-21 15:49:39

React動效組件

2014-09-28 10:39:24

AppleWatchUI

2015-08-03 10:40:45

動效設計優勢

2025-10-27 02:25:00

2019-07-24 09:00:19

谷歌Android開發者

2021-03-04 06:14:03

CSS webkit-box-動效

2020-10-13 21:23:52

數據

2025-11-20 10:12:49

2022-09-01 06:54:28

CSS前端

2022-01-26 18:46:46

Canvas煙花粒子特效

2012-05-09 12:25:55

2013-06-07 15:43:34

移動移動應用豐富動效
點贊
收藏

51CTO技術棧公眾號

亚洲欧美日韩在线高清直播| 亚洲一区二区三区视频在线| 91精品国产综合久久香蕉| 中文字幕美女视频| 中文字幕日韩在线| 日韩欧美在线第一页| 欧美性xxxx69| 国产女同91疯狂高潮互磨| 伊人成人网在线看| 一区二区三区无码高清视频| 日本成人xxx| 免费一二一二在线视频| 国产精品久久久久影院亚瑟| 亚洲自拍在线观看| 国产嫩bbwbbw高潮| 一区二区日韩欧美| 亚洲美女性视频| 亚洲制服中文字幕| 天堂av在线网| 亚洲女厕所小便bbb| 精品偷拍一区二区三区在线看 | 欧美婷婷精品激情| 精品国产av一区二区三区| 日韩午夜在线| xxxx性欧美| 成熟妇人a片免费看网站| 999国产精品亚洲77777| 婷婷久久综合九色综合绿巨人| 亚洲欧洲久久| 日本一卡二卡四卡精品| 国产麻豆精品95视频| 国产精品www色诱视频| 国产系列精品av| 天天久久综合| 国产一区二区三区在线视频| 久久久久国产精品无码免费看| 丁香婷婷久久| 色狠狠一区二区| av日韩一区二区三区| 国产淫片在线观看| 欧美国产精品一区| 欧美自拍资源在线| 完全免费av在线播放| 精品蜜桃传媒| 亚洲AV无码乱码国产精品牛牛 | 国产成人综合亚洲| 中文字幕日韩一级| 欧美aa国产视频| 综合激情国产一区| 欧美三级视频网站| 国产成人精品免费视| 日韩精品视频免费在线观看| 大桥未久恸哭の女教师| 中文一区二区三区四区| 日韩午夜在线播放| 黄色片免费网址| vam成人资源在线观看| 精品视频在线免费| 亚洲欧美国产精品久久久久久久| 国内精品久久国产| 精品人妻少妇AV无码专区| 久久99国产精品久久99| 国产美女精品视频免费观看| 中文区中文字幕免费看| 日韩福利视频网| 国产成人综合亚洲| 最近中文字幕免费在线观看| 久久这里只有| 亚洲二区在线视频| 制服.丝袜.亚洲.中文.综合| 一区二区三区动漫| 亚洲综合20p| 4438五月综合| 欧美一二三区在线观看| 人妻av一区二区三区| 在线日韩成人| 日韩av影片在线观看| 蜜桃精品一区二区| 欧美日韩一二| 日韩中文字幕免费视频| 黄色片在线观看网站| 亚洲国产高清一区二区三区| 日本午夜人人精品| 国产一级片av| 久久99深爱久久99精品| 国产精品久久久久久久久久久久冷 | 国产精品一二三在线| 91精品国产乱码久久久久| 国产乱码精品1区2区3区| 成人午夜电影免费在线观看| 色哟哟在线观看| 国产欧美精品一区| 国产小视频免费| 91久久国产综合久久91猫猫| 欧美日韩一卡二卡三卡 | 成人免费a级片| 另类专区亚洲| 欧美一区二区三区在线观看| 久久久久亚洲av无码专区喷水| 91麻豆国产福利在线观看宅福利| 午夜免费久久看| 日本人视频jizz页码69| 亚洲成人影音| 国产一区二区三区丝袜| 欧美人禽zoz0强交| 国产日韩欧美在线播放不卡| 国产精品稀缺呦系列在线| 精品国产伦一区二区三| 国产亚洲女人久久久久毛片| 中文字幕av久久| 亚洲美女炮图| 日韩视频免费直播| 公肉吊粗大爽色翁浪妇视频| 亚洲视频日本| 国产在线视频欧美| 亚洲av成人无码网天堂| 亚洲欧洲三级电影| 欧美女人性生活视频| 国产日本亚洲| 国产亚洲精品久久久久久| 国产网址在线观看| 韩国v欧美v日本v亚洲v| 欧美日韩一区二区视频在线观看| 青草视频在线免费直播 | 国产日韩三级| 日韩亚洲综合在线| 无码人妻av免费一区二区三区| 国产成人在线视频免费播放| 亚洲视频导航| 日韩免费小视频| 亚洲国产成人精品久久久国产成人一区 | 中文字幕日本精品| 亚洲av中文无码乱人伦在线视色| 粉嫩一区二区三区性色av| 一区二区三区四区欧美| 欧美日韩电影免费看| 亚洲第一av网站| 午夜精品久久久久久久男人的天堂| 色悠久久久久综合欧美99| 91免费精品国自产拍在线不卡| 日韩欧美国产不卡| 中文字幕不卡每日更新1区2区| sm久久捆绑调教精品一区| 日韩视频在线一区二区| 国产成人av免费在线观看| 三级亚洲高清视频| 久久久久久一区| 国产美女高潮在线| 亚洲精品国产综合久久| 久久久国产高清| 成人18精品视频| 丁香婷婷综合激情| 国产一区二区三区国产精品| 久久精品视频va| 亚洲无码精品国产| 国产精品美女久久久| 成人av免费看| 国产美女情趣调教h一区二区| 欧美一级久久久久久久大片| 国产67194| 国产一区999| 日韩a级黄色片| 日韩欧美另类中文字幕| 欧美国产日本在线| 香港三日本三级少妇66| 色悠悠久久综合| 黄色片在线观看免费| 美女国产一区二区| 日韩video| 777久久精品| 777午夜精品福利在线观看| 天天爱天天干天天操| 欧美色视频日本版| 欧美aaa级片| 国产福利一区二区三区| 水蜜桃色314在线观看| 任你躁在线精品免费| 国产成人精品在线观看| 1024免费在线视频| 日韩一二三区不卡| 中文字幕亚洲精品一区| 亚洲国产成人午夜在线一区| 一级片免费在线观看视频| 欧美一区二区三区免费看| av一区二区三区免费| 日韩av一卡| 伊人青青综合网站| 国产美女免费看| 午夜精品久久久| 1024手机在线观看你懂的| 国产馆精品极品| 人妻精品无码一区二区三区 | www 成人av com| 人人草在线视频| 最近2019中文字幕第三页视频| 国产不卡精品视频| 久久婷婷色综合| 亚洲成人福利在线| 午夜精品影院| 日本一区免费观看| 日本一区影院| 国产精品18久久久久久首页狼| bestiality新另类大全| 亚洲女人天堂色在线7777| 亚洲天堂777| 午夜天堂影视香蕉久久| 性爱在线免费视频| 成人18视频日本| av亚洲天堂网| 美女视频一区免费观看| 污污污污污污www网站免费| 精品理论电影在线| 精品中文字幕人| 激情综合婷婷| 国产精品国产三级国产专播精品人 | 日本一道高清亚洲日美韩| 欧美老女人性生活| 成人在线免费看| 精品国产亚洲在线| 97在线公开视频| 一本大道综合伊人精品热热| 国产亚洲欧美精品久久久久久| 国产欧美精品在线观看| 800av在线播放| 国产一区二区三区观看| 五月婷婷丁香综合网| 国产日韩欧美三级| 黄网站欧美内射| 欧美久久久久| 午夜啪啪福利视频| 三区四区不卡| 视频一区不卡| 国内精品久久久久久久影视简单| 国产伦精品一区二区三区四区免费 | 国产精品久久久久久超碰| 丁香花在线观看完整版电影| 久久中文字幕国产| 日本中文字幕电影在线免费观看| 亚洲欧洲视频在线| 视频一区二区在线播放| 精品国产精品网麻豆系列| 国产成人精品毛片| 5月丁香婷婷综合| 一级特黄aaa大片在线观看| 欧美三级电影在线看| 日日噜噜噜噜人人爽亚洲精品| 亚洲妇女屁股眼交7| 精品视频久久久久| 亚洲资源中文字幕| 久久国产在线视频| 夜夜操天天操亚洲| 国产真实乱人偷精品视频| 亚洲aⅴ怡春院| 日韩三级av在线| 偷窥少妇高潮呻吟av久久免费| 久久精品视频8| 婷婷亚洲久悠悠色悠在线播放| 国产成人无码精品| 富二代精品短视频| 中文字幕免费观看| 91福利在线播放| 亚洲一区二区人妻| 欧美一卡二卡在线| 亚洲第一页综合| 精品国产乱码久久久久久影片| 欧美一区二区三区成人片在线| 亚洲国产精品中文| 国产在线观看网站| 久久九九亚洲综合| 青草青在线视频| 7777kkkk成人观看| 国产精品久久乐| 91超碰在线电影| 老牛影视av一区二区在线观看| 蜜桃狠狠色伊人亚洲综合网站| 久久av免费看| 综合国产精品久久久| 好看的av在线不卡观看| 国产日韩一区二区在线| 久久99国产乱子伦精品免费| 91亚洲一线产区二线产区| 91免费在线播放| 免费黄色国产视频| 亚洲一二三四久久| 久久永久免费视频| 日韩亚洲欧美一区| 免费a在线观看| 久久成人亚洲精品| 男人久久天堂| 91精品久久久久久久久| 国产精品成人自拍| 亚洲不卡1区| 欧美激情1区2区3区| 亚洲爆乳无码专区| 国产精品66部| 国产高清一区二区三区四区| 亚洲免费视频成人| 懂色av蜜臀av粉嫩av分享吧最新章节| 欧美疯狂做受xxxx富婆| 日批视频在线播放| www.亚洲男人天堂| av2020不卡| 成人国产亚洲精品a区天堂华泰| 久久a爱视频| 亚洲人成影视在线观看| 中文一区二区| 日本黄色三级网站| 欧美激情综合五月色丁香小说| 麻豆国产尤物av尤物在线观看 | 欧美a v在线播放| 另类的小说在线视频另类成人小视频在线 | 亚洲第一av在线| 黄网站在线播放| 国产精品高潮呻吟久久av野狼| 久久香蕉精品香蕉| 法国空姐在线观看免费| 丝袜亚洲另类欧美| 亚洲熟女一区二区| 一区二区三区四区在线免费观看| 中文字幕永久在线| 亚洲国产精品成人av| 18加网站在线| 成人av番号网| 欧美一区电影| 精品一区久久久| 一区二区三区国产精华| 男女男精品视频站| 久久免费美女视频| 日韩av女优在线观看| 日韩免费视频一区二区| 国产在线二区| 国产主播喷水一区二区| 不卡视频在线| 欧美日韩在线成人| 26uuu另类欧美| 日韩精品人妻中文字幕| 亚洲成人激情图| 欧美色图天堂| 91九色蝌蚪嫩草| 午夜欧美理论片| 国产大片一区二区三区| 一区二区中文字幕在线| 国产精品区在线观看| 久久精品久久久久| 日本免费成人| 正义之心1992免费观看全集完整版| 日本午夜一本久久久综合| a天堂中文字幕| 一本大道av一区二区在线播放| 亚洲色偷精品一区二区三区| 欧美性受xxxx白人性爽| 国产亚洲精品精品国产亚洲综合| 欧美一区二区三区在线免费观看 | 红桃av在线播放| 99久久er热在这里只有精品15| 精品成人久久久| 亚洲美女av在线播放| 日韩欧美一区二区三区免费观看| 欧美一级二级三级九九九| 日韩激情视频在线观看| 精品手机在线视频| 欧美精品xxxxbbbb| 在线中文字幕视频观看| 99久久免费国| 亚洲美女一区| 亚洲午夜久久久久久久久红桃| 色综合天天综合在线视频| 浮生影视网在线观看免费| 国产一区二区丝袜| 欧美久久久久| 变态另类丨国产精品| 91久久线看在观草草青青| 98在线视频| yellow视频在线观看一区二区| 激情欧美日韩| 色欲狠狠躁天天躁无码中文字幕 | 国产一区日韩| 欧美日韩一区二区三区69堂| 亚洲美女视频在线| 婷婷综合激情网| 国产精品久久久久秋霞鲁丝| 99久久精品费精品国产风间由美| 欧美性猛交乱大交| 疯狂欧美牲乱大交777| 91免费在线| 国产伦精品一区二区三区视频孕妇| 久久99伊人| a在线视频播放观看免费观看| 亚洲二区中文字幕| 国产成人免费| 91精品国产91久久久久麻豆 主演| 国产亚洲欧美日韩在线一区| 精品人妻伦一二三区久久| 日本成人精品在线| 亚洲女同中文字幕| 久久只有这里有精品| 欧美一卡二卡三卡四卡| 性欧美hd调教| 激情五月婷婷六月| 中文一区二区在线观看|