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

跟著小白一起學鴻蒙—[番外]一起學做FlappyBird

系統 OpenHarmony
本文主要介紹小游戲的開發,畫布功能的使用。

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

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

簡介

記得很久以前有個大火的像素游戲叫FlappyBird,我們就一起看看如何能用OpenHarmony學習做個FlappyBird。本文中引用的圖片資源均來自與Github。

#跟著小白一起學鴻蒙# [番外]一起學做FlappyBird-開源基礎軟件社區

開發

1、HAP應用建立

這里我們就不贅述Hap項目的建立過程,以下就是基礎的Hap的page文件:index.ets

build() {
Row() {
Column() {
Canvas(this.context)
.width('100%')
.height('100%')
.onClick((ev: ClickEvent) => {
console.info("click!!")
//響應鼠標左擊
this.doClick()
})
.onReady(() =>{
//繪制基礎
this.context.imageSmoothingEnabled = false
this.drawBlock()
})
}
.width('100%')
}
.height('100%')
.backgroundImage($r("app.media.backgroundday"))
.backgroundImageSize(ImageSize.Cover)
}

build是基礎頁面的構造函數,用于界面的元素構造,其他的頁面的生命周期函數如下:

declare class CustomComponent {
/**
* Customize the pop-up content constructor.
* @since 7
*/
build(): void;

/**
* aboutToAppear Method
* @since 7
*/
aboutToAppear?(): void;

/**
* aboutToDisappear Method
* @since 7
*/
aboutToDisappear?(): void;

/**
* onPageShow Method
* @since 7
*/
onPageShow?(): void;

/**
* onPageHide Method
* @since 7
*/
onPageHide?(): void;

/**
* onBackPress Method
* @since 7
*/
onBackPress?(): void;
}

2、Canvas介紹

canvas是畫布組件用于自定義繪制圖形,具體的API頁面如下:

https://developer.harmonyos.com/cn/docs/documentation/doc-references/ts-components-canvas-canvas-0000001333641081。

頁面顯示前會調用aboutToAppear()函數,此函數為頁面生命周期函數。

canvas組件初始化完畢后會調用onReady()函數,函數內部實現小游戲的初始頁面的繪制。

(1)初始化頁面數據
drawBlock() {
this.context.clearRect(0,0,this.context.width,this.context.height)
this.context.drawImage( this.baseImg,this.baseX,this.baseY,500,300)
switch(this.flappyState) {
case 0:
this.context.drawImage( this.messageImg,this.startX,this.startY,300,500)
this.drawBird()
break;
case 1:
this.drawBird()
this.context.drawImage( this.pipegreenImg,this.pipeX,this.pipeY,50,150)
break;
case 2:
this.context.drawImage( this.gameoverImg,this.startX,this.startY*3,300,90)
break
}
}

頁面狀態有三:

  • 0:等待開始界面
  • 1:游戲進行
  • 2:游戲結束
(2)繪制Bird
drawBird() {
switch(this.birdType) {
case 0:
this.context.drawImage( this.midbirdImg,this.slotX,this.slotY,this.birdH,this.birdW)
break
case 1:
this.context.drawImage( this.upbirdImg,this.slotX,this.slotY,this.birdH,this.birdW)
break;
case 2:
this.context.drawImage( this.downbirdImg,this.slotX,this.slotY,this.birdH,this.birdW)
break;
default:
break;
}
}

小鳥飛行狀態有三種:

  • 翅膀在中間:0
  • 翅膀在上:1
  • 翅膀在下:2

3、游戲邏輯

簡單的小游戲主體游戲邏輯為:等待開始,開始,結束流程圖如下:

graph LR
等待開始 --> click[點擊]
click[點擊] --> 游戲開始
游戲開始 --> 點擊 --> |游戲開始|小鳥飛,水管動 --> |小鳥碰到水管| 游戲結束 --> 點擊 --> |游戲結束| 等待開始
小鳥飛,水管動 --> |小鳥沒碰到水管| 游戲繼續 --> 點擊
doClick() {
switch (this.flappyState) {
case 0:
{
// 開始
this.flappyState = 1
break
}
case 1:
{
//上下飛
// this.flappyState = 2
this.slotY -= this.flyHeight
console.log(this.slotY.toString())
break
}
case 2:
{
//由結束到待開始
this.flappyState = 0
this.slotY = this.slotStartY
this.pipeX = this.pipeStartX
break
}
default:
break
}
this.drawBlock()
}

4、完整邏輯

@Entry
@Component
struct Index {
@State message: string = 'Hello World'
private baseImg:ImageBitmap = new ImageBitmap("common/images/base.png")
private messageImg:ImageBitmap = new ImageBitmap("common/images/message.png")
private zeroImg:ImageBitmap = new ImageBitmap("common/images/0.png")
private gameoverImg:ImageBitmap = new ImageBitmap("common/images/gameover.png")
private upbirdImg:ImageBitmap = new ImageBitmap("common/images/bluebirdupflap.png")
private midbirdImg:ImageBitmap = new ImageBitmap("common/images/bluebirdmidflap.png")
private downbirdImg:ImageBitmap = new ImageBitmap("common/images/bluebirddownflap.png")
private pipegreenImg:ImageBitmap = new ImageBitmap("common/images/pipegreen.png")
private settings: RenderingContextSettings = new RenderingContextSettings(true);
private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings);
private flappyState: number = 0
private startX = 30;
private startY = 100;
private slotStartY = 410;
private slotX = 50;
private slotY = this.slotStartY;
private baseX = 0;
private baseY = 650;
private pipeStartX = 330;
private pipeX = this.pipeStartX;
private pipeY = 500;
private birdH = 60;
private birdW = 50;
private birdTimer: number;
private birdType: number = 0;
private count = 1;
private flyHeight = 20;
private pipeMove = 10;


drawBird() {
switch(this.birdType) {
case 0:
this.context.drawImage( this.midbirdImg,this.slotX,this.slotY,this.birdH,this.birdW)
break
case 1:
this.context.drawImage( this.upbirdImg,this.slotX,this.slotY,this.birdH,this.birdW)
break;
case 2:
this.context.drawImage( this.downbirdImg,this.slotX,this.slotY,this.birdH,this.birdW)
break;
default:
break;
}
}

drawBlock() {
this.context.clearRect(0,0,this.context.width,this.context.height)
this.context.drawImage( this.baseImg,this.baseX,this.baseY,500,300)
switch(this.flappyState) {
case 0:
this.context.drawImage( this.messageImg,this.startX,this.startY,300,500)
this.drawBird()
break;
case 1:
this.drawBird()
this.context.drawImage( this.pipegreenImg,this.pipeX,this.pipeY,50,150)
break;
case 2:
this.context.drawImage( this.gameoverImg,this.startX,this.startY*3,300,90)
break
}
}

doClick() {
switch (this.flappyState) {
case 0:
{
// 開始
this.flappyState = 1
break
}
case 1:
{
//上下飛
// this.flappyState = 2
this.slotY -= this.flyHeight
console.log(this.slotY.toString())
break
}
case 2:
{
//由結束到待開始
this.flappyState = 0
this.slotY = this.slotStartY
this.pipeX = this.pipeStartX
break
}
default:
break
}
this.drawBlock()
}

doFly(): void {
console.log("dofly ------ !!")
this.birdType += 1
if (this.birdType/5 == 0) {
this.message = "dofly ---555--- !!"
}
}

async sleep(ms: number) {
return new Promise((r) => {
setInterval(() => {
this.birdType += 1
this.message = this.birdType.toString()
if (this.birdType == 3) {
this.birdType = 0
}
console.log(this.message)
if (this.flappyState == 1) {
this.pipeX -= this.pipeMove
if (this.pipeX < 0) {
this.pipeX = 330
}
this.slotY += this.flyHeight/5
}

if ((((this.pipeX-this.slotX) <= this.birdW) && ((this.pipeY-this.slotY) <= this.birdH)) ||
this.pipeY >= this.baseY) {
this.flappyState = 2
}
this.drawBlock()
}, ms)
})
}

aboutToDisappear() {
}

aboutToAppear() {
this.sleep(200)
}

build() {
Row() {
Column() {
Canvas(this.context)
.width('100%')
.height('100%')
.onClick((ev: ClickEvent) => {
console.info("click!!")
this.doClick()
})
.onReady(() =>{
this.context.imageSmoothingEnabled = false
this.drawBlock()
})
}
.width('100%')
}
.height('100%')
.backgroundImage($r("app.media.backgroundday"))
.backgroundImageSize(ImageSize.Cover)
}
}

遺留問題:

  1. 水管只在下層顯示:可以在上層顯示;
  2. 地面沒有讓動
  3. 游戲聲音問題:目前ohos不支持音頻播放資源音頻,看之后版本是否支持
  4. DevEcoy用setInterval重繪canvas會導致ide崩潰

5、獲取源碼

見附件
https://gitee.com/wshikh/ohosflappybird。

總結

本文主要介紹了小游戲的開發,畫布功能的使用。

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

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??。

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

2022-11-29 16:35:02

Tetris鴻蒙

2022-12-02 14:20:09

Tetris鴻蒙

2023-03-30 09:32:27

2023-02-27 16:30:32

鴻蒙開源協議分析

2023-03-30 09:19:54

SELinux安全子系統

2022-08-19 19:02:20

開源鴻蒙操作系統

2023-04-04 09:24:11

鴻蒙HiDumper

2022-10-10 14:47:04

藍牙應用鴻蒙

2023-01-03 15:09:10

鴻蒙常用工具

2022-12-06 15:39:16

鴻蒙主干代碼

2023-03-15 16:19:03

BinderIPC工具

2022-11-24 14:34:41

Hap程序鴻蒙

2022-10-20 16:40:16

JS應用控制LED鴻蒙

2022-10-09 15:05:50

NAPI框架鴻蒙

2022-09-28 13:57:41

鴻蒙開源

2023-04-06 09:18:52

鴻蒙AVPlayerAVRecorder

2023-02-24 16:02:45

WebSocket網絡通訊協議

2022-11-28 15:42:39

分布式軟總線鴻蒙

2022-12-09 15:34:38

2022-12-05 15:02:14

鴻蒙用戶鑒權
點贊
收藏

51CTO技術棧公眾號

日韩一卡二卡三卡国产欧美| 亚洲欧洲日产国码二区| 午夜精品国产精品大乳美女| 国产精品无码一区二区三区免费| 欧美性猛交xxxx乱大交hd| 欧美一二区在线观看| 欧美挠脚心视频网站| av免费看网址| h视频网站在线观看| 国产精品亚洲人在线观看| 2019最新中文字幕| 午夜爽爽爽男女免费观看| 性欧美xxx69hd高清| 中文字幕av一区二区三区免费看| 99久久伊人精品影院| chinese国产精品| 欧美在线黄色| 在线播放日韩av| 中文字幕一区二区三区乱码不卡| 日韩成人在线电影| 欧美午夜久久久| 97av中文字幕| 国产高清在线看| 久久久久国产精品一区三寸| 成人97在线观看视频| 91激情视频在线观看| 久久精品色播| 日韩一区二区三区免费看| 91最新在线观看| 天堂在线中文网官网| 一二三区精品福利视频| 中文字幕精品一区日韩| 国产在线中文字幕| 91丨九色丨蝌蚪富婆spa| 97人人模人人爽人人喊38tv| 91av久久久| 日韩电影在线一区| 热99精品里视频精品| 国产极品美女高潮无套嗷嗷叫酒店| 四季av一区二区三区免费观看 | 国产免费999| 亚洲色图官网| 精品久久久久久久久久国产| 麻豆映画在线观看| 直接在线观看的三级网址| 亚洲视频在线一区二区| 永久久久久久| 欧美日韩视频在线播放| 国产精品久久久久婷婷| 亚洲狠狠婷婷综合久久久| sese在线视频| 中文字幕av资源一区| 亚洲精品中文字幕在线| 国产成人天天5g影院在线观看 | 极品色av影院| 日韩午夜电影网| 色婷婷久久一区二区| 色偷偷男人天堂| 999久久久亚洲| 久久天天躁狠狠躁老女人| 亚洲精品卡一卡二| 欧美在线亚洲综合一区| 久久久久久久色| 日韩和一区二区| 香蕉视频一区二区三区| 欧美亚一区二区| 丁香婷婷激情网| 香蕉成人影院| 91精品国产入口在线| 怡红院av亚洲一区二区三区h| 123区在线| 岛国av一区二区| 久久久久亚洲av无码专区喷水| 免费黄色在线看| 亚洲精品国久久99热| 无码专区aaaaaa免费视频| 午夜激情电影在线播放| 在线精品视频一区二区| av在线免费看片| 成人爽a毛片| 亚洲精品永久免费精品| 久久视频一区二区三区| 欧美激情五月| 日本精品va在线观看| 男操女视频网站| 国产精品一级黄| 就去色蜜桃综合| 97人人在线| 亚洲国产视频在线| 青青在线视频免费| 久久av网站| 欧美性猛交xxxxxx富婆| 一二三级黄色片| 麻豆成人入口| www.美女亚洲精品| 日韩免费在线视频观看| 美女视频一区二区| 日韩av第一页| 国产丰满美女做爰| 久久久久国产免费免费| 国产伦精品一区二区三区| 91亚洲国产成人久久精品麻豆| 国产91在线|亚洲| 日韩精品一区二区三区四区五区| 天天摸天天干天天操| 欧美激情在线看| 日韩成人三级视频| 婷婷色在线播放| 日本精品一区二区三区高清| 岛国大片在线免费观看| 欧美日韩激情| 亚洲性猛交xxxxwww| 波多野结衣亚洲色图| 日日噜噜夜夜狠狠视频欧美人| 99久久久精品免费观看国产 | 2021久久国产精品不只是精品| 一区二区在线观看网站| 色综合桃花网| 亚洲成人1区2区| 亚洲最大天堂网| 全球中文成人在线| 精品中文视频在线| 久久久无码精品亚洲国产| 奇米在线7777在线精品| 免费日韩电影在线观看| 久久免费电影| 欧美一区二区三区在线| 亚洲图片第一页| 久久久久久夜| 精品一区二区不卡| av小说在线播放| 精品捆绑美女sm三区| 成人18视频免费69| 日本不卡一二三区黄网| 秋霞久久久久久一区二区| 鲁鲁在线中文| 亚洲精品久久视频| 懂色av.com| 国产成人免费在线视频| 超碰97免费观看| 久久不射影院| 精品少妇一区二区三区在线播放| 艳妇荡乳欲伦69影片| 六月婷婷色综合| 亚洲欧美日韩不卡一区二区三区| 日韩免费小视频| 91麻豆精品国产91久久久久| 久久午夜精品视频| 免费一级欧美片在线观看| 日韩精品伦理第一区| 欧美xxxx做受欧美护士| 国产一区二区三区在线观看视频| 自拍偷拍18p| 国产精品网站在线| 午夜免费看视频| 亚洲视频在线免费| 高清国产在线一区| 黄色软件视频在线观看| 亚洲精品在线看| 日韩欧美一级大片| **欧美大码日韩| 麻豆精品国产传媒| 日韩亚洲国产精品| 欧美亚洲精品日韩| 国产三级一区| 久久国产加勒比精品无码| www.99视频| 欧美日韩黄色大片| 国产又粗又黄又猛| 国产美女精品人人做人人爽| av日韩在线看| 中文字幕伦av一区二区邻居| 国产精品狼人色视频一区| 成人在线影视| 色欧美片视频在线观看| 在线观看天堂av| 高清久久久久久| 精品视频无码一区二区三区| 欧美理论电影大全| 97超碰人人看人人| 亚洲人成午夜免电影费观看| 亚洲天堂日韩电影| 国产日韩欧美视频在线观看| 亚洲午夜久久久久久久久电影网| aaaaa级少妇高潮大片免费看| 麻豆精品在线播放| 久久99久久99精品| 欧美日韩精品在线一区| 91久久极品少妇xxxxⅹ软件 | 特级西西人体wwwww| 老牛国产精品一区的观看方式 | 国产欧美一级| 亚洲日本欧美在线| 日韩精品三区| 久久av在线播放| 日韩大胆视频| 日韩欧美在线影院| 69av视频在线观看| 亚洲第一久久影院| 最新av电影网站| 99re这里只有精品视频首页| 在线观看免费的av| 性久久久久久| 男女日批视频在线观看| 久久精品国产99久久| 欧亚洲嫩模精品一区三区| 欧美日韩一区高清| 舐め犯し波多野结衣在线观看| 国产传媒欧美日韩成人| 久草福利视频在线| 亚洲美女视频在线免费观看| 黄色一级片网址| 一呦二呦三呦国产精品| 国产精品二区三区| 国产高清亚洲| 国产精品久久9| 韩国久久久久久| 久久久久久久久亚洲| 黄色大片在线播放| 中文字幕日韩精品在线| 国产成人精品一区二三区| 国产精品伦理在线| 熟女俱乐部一区二区| 成人黄色小视频在线观看| 色www免费视频| 日韩和欧美的一区| 成 年 人 黄 色 大 片大 全| 欧美片第1页综合| 熟妇熟女乱妇乱女网站| 色狮一区二区三区四区视频| 欧美一区二区高清在线观看| 欧美黑人巨大videos精品| aa成人免费视频| 麻豆国产一区二区三区四区| 成人av电影天堂| 91精品国产一区二区在线观看| 国产精品黄色av| 三级成人黄色影院| 正在播放亚洲1区| 欧美日韩视频精品二区| 亚洲国产精品中文| 日本精品999| 日韩欧美亚洲综合| 韩国av免费观看| 黄色精品在线看| 国产精品一区二区6| 五月激情综合色| 男人的天堂一区二区| 婷婷亚洲久悠悠色悠在线播放| 久久精品国产亚洲AV无码麻豆| 亚洲乱码国产乱码精品精可以看| 伊人av在线播放| 国产高清不卡二三区| 欧美xxxx日本和非洲| 成人精品国产免费网站| 国模无码视频一区| 99riav久久精品riav| 超碰97人人干| 国产色婷婷亚洲99精品小说| 性欧美精品男男| 中文字幕制服丝袜成人av | 国产精品欧美在线观看| 日本不卡一区| 水蜜桃久久夜色精品一区| 中文字幕精品在线播放| 在线观看一区视频| 亚洲精品一卡二卡三卡四卡| 99国产**精品****| 欧美精品久久| 日韩成人影院| 欧美少妇在线观看| 亚洲久色影视| 9久久婷婷国产综合精品性色| 精品写真视频在线观看| 无码人妻丰满熟妇区毛片蜜桃精品| 成人黄色a**站在线观看| 人妻精品久久久久中文字幕 | 亚洲国产精品一区二区第一页| 国产精品7m凸凹视频分类| 国产肉体ⅹxxx137大胆| 久久精品二区三区| 性欧美在线视频| av网站免费线看精品| 欧美激情视频二区| 亚洲一区二区综合| 波多野结衣毛片| 日韩欧美在线综合网| 国产乱理伦片a级在线观看| 久久久精品电影| 性欧美freesex顶级少妇| 91美女片黄在线观| 西野翔中文久久精品字幕| 一道本在线观看视频| 鲁大师成人一区二区三区| 欧美成人乱码一二三四区免费| 成人免费黄色大片| 国产精品麻豆一区| 欧美视频在线观看 亚洲欧| 国产农村老头老太视频| 亚洲欧美日韩在线高清直播| 成人片在线看| 国产精品电影观看| 国产图片一区| 亚洲永久一区二区三区在线| 亚洲精品激情| 男人女人拔萝卜视频| 欧美国产在线观看| 西西44rtwww国产精品| 91精选在线观看| 国产免费av在线| 欧美做受高潮电影o| 一区二区在线视频观看| 亚洲欧美精品| 日韩精品成人一区二区三区 | 卡通动漫精品一区二区三区| 成年人免费观看的视频| 日韩国产一区二| 一二三不卡视频| 亚洲国产精品人人做人人爽| 国产精品国产三级国产aⅴ| 亚洲人精选亚洲人成在线| 男人天堂资源在线| 欧美精品激情视频| 国产电影一区| 最近中文字幕免费mv| 男女男精品视频网| 鲁丝一区二区三区| 色悠悠久久综合| 欧美日韩在线中文字幕| 2019中文在线观看| 网曝91综合精品门事件在线| 日韩精品一区在线视频| 国产成人精品三级| 欧美日韩精品在线观看视频| 欧美一区国产二区| 黄色国产网站在线播放| 91社区国产高清| 亚洲精品国产偷自在线观看| 亚洲图色中文字幕| 综合欧美一区二区三区| 中文字幕在线观看你懂的| 日韩欧美在线123| 免费高清在线观看| 国产精品一区二区久久| 成人在线免费观看网站| 91网址在线播放| 国产精品女同互慰在线看| 在线观看免费观看在线| 日韩视频在线免费观看| 日本免费成人| 在线观看三级网站| 福利一区福利二区| 国产无遮挡又黄又爽又色| 亚洲精品www久久久| 中文字幕在线视频网站| 欧美在线激情| 蜜臀av在线播放一区二区三区| 午夜黄色福利视频| 欧美一区二区三区婷婷月色 | 91精品国偷自产在线电影| 最新av免费在线观看| 亚洲精品国产第一综合99久久| 亚洲a视频在线| 91禁国产网站| 成人系列视频| 日韩精品――色哟哟| 午夜国产不卡在线观看视频| 中文在线字幕av| 久久精品国产v日韩v亚洲 | 精品日韩欧美在线| 国产精品一二三产区| 日韩av一级大片| 国产自产v一区二区三区c| www.youjizz.com亚洲| 亚洲视频视频在线| 99久久99九九99九九九| 成人性生活视频免费看| 日本一区二区免费在线观看视频| 国产精品国产三级国产aⅴ| 91av在线看| 久久免费大视频| 性久久久久久久久久久| 欧美性大战久久久久久久蜜臀 | 亚洲综合久久av| 欧美视频免费一区二区三区| 91日本视频在线| 国产亚洲精品v| 在线看的片片片免费| 亚洲激情 国产| 99视频有精品高清视频| 18禁男女爽爽爽午夜网站免费| 国产精品夫妻自拍| 亚洲色图另类小说| 91在线观看免费高清| 久久影院亚洲| 国产一级在线视频| 日韩视频在线免费| 综合伊思人在钱三区| 色欲欲www成人网站| 在线观看国产91|