精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

裸体在线国模精品偷拍| 波多野结衣在线播放一区| 亚洲一区欧美一区| 久久99九九| 伊人网中文字幕| 欧美/亚洲一区| 亚洲人成在线播放| 亚洲欧美天堂在线| heyzo一区| 欧美国产在线观看| 国产精品一区二区不卡视频| 国产又粗又猛又黄视频| 午夜久久影院| 在线亚洲欧美视频| 国产裸体视频网站| 韩日精品一区| 亚洲国产另类精品专区| 色播亚洲视频在线观看| 亚洲精品视频网| 日韩成人精品在线| 国内精品久久影院| 男人晚上看的视频| 九九热爱视频精品视频| 精品国产一区二区三区忘忧草| 日日摸天天爽天天爽视频| 欧美成人一二三区| 免费视频亚洲| 精品国产91久久久久久久妲己| 999精彩视频| 亚洲精品日产| 亚洲图片一区二区| 欧美一级免费在线观看| 黄色美女网站在线观看| 国产成人精品免费| 91精品视频在线播放| 尤物视频免费观看| 亚洲永久网站| 久久久久成人网| 麻豆天美蜜桃91| 日韩精品中文字幕第1页| 亚洲精品自拍视频| 久久久久成人精品无码中文字幕| 欧美日本三级| 欧美一区二区私人影院日本| 亚洲无吗一区二区三区| 欧美xx视频| 狠狠做深爱婷婷久久综合一区 | 中文字幕第一区| 久久国产精品 国产精品| 成人无码一区二区三区| 国内成人自拍视频| 91丝袜美腿美女视频网站| 自拍偷拍福利视频| 日本va欧美va欧美va精品| 日韩av电影免费观看高清| 国产超碰人人爽人人做人人爱| 野花国产精品入口| 2018日韩中文字幕| 亚洲精品视频在线观看免费视频| 亚洲网址在线| 欧美一级在线亚洲天堂| 日本在线播放视频| 国产精品呻吟| 国产精品久久一区| 在线观看毛片av| 国产综合色在线视频区| 亚洲最大av网| 亚洲免费国产视频| 99久久综合精品| 热舞福利精品大尺度视频| 国产在线视频网站| 中文字幕永久在线不卡| 国内外成人激情免费视频| 色呦呦在线观看视频| 亚洲国产一区二区三区| 欧美视频在线播放一区| 免费亚洲电影| 欧美精品一卡两卡| 黄色特一级视频| 色呦呦在线视频| 欧美丝袜一区二区| 一区二区免费av| 日韩精品视频中文字幕| 亚洲第一网站免费视频| 高潮毛片无遮挡| 欧美国产一级| 久久久久久网址| 亚洲天堂av片| 久久99日本精品| 国产精品二区二区三区| 国产在线视频福利| 亚洲精品一二三区| 国产日产欧美视频| 四虎影视国产精品| 亚洲国产精品大全| 美女av免费看| 激情欧美日韩| 国产精品麻豆va在线播放| 国内老熟妇对白hdxxxx| 久久一二三国产| 在线观看成人免费| 欧美成人精品一区二区男人小说| 91精品国产综合久久精品图片| 美女黄色一级视频| 我不卡神马影院| 456国产精品| 国产成人三级一区二区在线观看一| 91在线免费播放| 99久re热视频精品98| 中文字幕不卡三区视频| 91精品国产色综合久久ai换脸| 97人妻天天摸天天爽天天| 欧美激情偷拍自拍| 国产aⅴ夜夜欢一区二区三区 | 久久精品国产77777蜜臀| 国产精品香蕉视屏| a视频在线播放| 欧美性感一类影片在线播放| 亚洲高清无码久久| 你懂的亚洲视频| 国产精品久久久久久久午夜| 丰满岳乱妇国产精品一区| 国产精品久久久久久户外露出 | 精品国产91亚洲一区二区三区婷婷 | 亚洲欧美中文字幕| 四虎成人精品永久免费av| 麻豆免费看一区二区三区| 久久久精彩视频| 免费网站在线观看人| 777欧美精品| 日韩精品你懂的| 国产精品一区二区三区美女| 一区二区三区四区五区在线| 亚洲综合无码一区二区| 香蕉视频禁止18| 美女少妇全过程你懂的久久| 久久久久亚洲精品| 精品人妻一区二区三区蜜桃| 国产精品第13页| 一区二区三区入口| av中字幕久久| 国产精品www色诱视频| 欧美日韩在线中文字幕| 图片区小说区国产精品视频| 男的插女的下面视频| 国产精品美女久久久久人| 色偷偷91综合久久噜噜| 亚洲怡红院av| 国产精品美女www爽爽爽| 亚洲黄色a v| 欧美精品一区二区三区精品| 国产精品久久久| www在线播放| 欧美偷拍一区二区| 国产一区二区三区视频播放| 久久成人av少妇免费| 亚洲国产精品毛片| 日韩三区四区| 欧美成人免费小视频| 亚洲成a人片在线| 亚洲午夜久久久久久久久电影网| 美女黄色一级视频| 男人的天堂亚洲| 色姑娘综合网| 99精品女人在线观看免费视频| 另类图片亚洲另类| 亚洲av无码专区在线| 亚洲高清免费一级二级三级| 91丨porny丨对白| 噜噜噜91成人网| 午夜老司机精品| 国产精品免费精品自在线观看| 欧美丰满片xxx777| 偷拍25位美女撒尿视频在线观看| 色系网站成人免费| 日韩一卡二卡在线观看| 国产精品一级黄| 日日橹狠狠爱欧美超碰| 日韩电影在线视频| 不卡一卡2卡3卡4卡精品在| 爱啪啪综合导航| 一本色道久久88综合亚洲精品ⅰ | www.在线视频| 亚洲成人av片| 色老头一区二区| 一区二区视频免费在线观看| 国产夫妻性爱视频| 久久99在线观看| 97国产在线播放| 久久在线播放| 国产视频在线观看一区| 久久久人成影片一区二区三区在哪下载 | 91一区二区| 国产日韩亚洲精品| 国内自拍亚洲| 午夜精品久久久久久久久久久久久 | 国产视频丨精品|在线观看| www.五月婷婷.com| 亚洲国产aⅴ天堂久久| 亚洲天堂最新地址| 成人免费看视频| 黄色片视频在线| 亚洲国产国产亚洲一二三| 午夜欧美性电影| 日韩精选在线| 91成人在线看| 色豆豆成人网| 97精品视频在线观看| 麻豆最新免费在线视频| 亚洲欧美制服综合另类| 99久久99久久久精品棕色圆| 欧美在线观看你懂的| 国产在线拍揄自揄拍| 国产一区二区美女| 日本福利视频在线| 综合国产在线| 亚洲成人自拍| 免费国产自久久久久三四区久久| 成人av中文| 国产精品美女久久久久| 国产精品午夜一区二区欲梦| 在线天堂中文资源最新版| 久久精品一偷一偷国产| 春暖花开成人亚洲区| 日韩精品久久久久久福利| 亚洲AV无码精品色毛片浪潮| 欧美日韩久久不卡| 亚洲国产成人精品女人久久| 精品福利在线视频| 久久久久成人精品无码| 亚洲免费观看高清完整| 亚洲综合图片一区| 日本一区二区三区国色天香| 午夜理伦三级做爰电影| 97精品国产97久久久久久久久久久久 | 日韩欧美激情在线| 国产视频一区二区三| 欧美日韩精品欧美日韩精品| 无码一区二区三区在线观看| 粉嫩老牛aⅴ一区二区三区| 日本熟女一区二区| 一区二区三区免费网站| 波多野结衣亚洲色图| 自拍视频在线观看一区二区| 国产大屁股喷水视频在线观看| 国产欧美精品区一区二区三区| 国产三级视频网站| 26uuu欧美| 免费在线观看污| 国产亚洲人成网站| 一区二区精品免费| 欧美国产精品v| 久久久久久成人网| 中文字幕中文在线不卡住| 日本一级片免费| 亚洲美女屁股眼交3| 青娱乐免费在线视频| 亚洲码国产岛国毛片在线| 国产97免费视频| 一区二区三区精品视频在线| 精品一区在线视频| 天天色综合天天| 国产成人无码专区| 欧美视频第二页| 国产精品视频在线观看免费| 欧美一区二区三区播放老司机| www.狠狠干| 亚洲国产精品中文| 成人午夜在线观看视频| www.国产精品一二区| 制服丝袜在线播放| 午夜精品久久久久久久久久久久 | 国产乱理伦片a级在线观看| 亚洲午夜久久久影院| 麻豆网站在线| 国内精品400部情侣激情| 成人性生交大片免费网站| 国产精品一区久久久| 视频在线观看免费影院欧美meiju| 国产伦一区二区三区色一情| 精品在线91| 永久免费在线看片视频| 国模 一区 二区 三区| 虎白女粉嫩尤物福利视频| 久久精品久久久精品美女| 日本黄色大片在线观看| 91美女视频网站| 黄色一级大片在线免费观看| 亚洲va中文字幕| 中国女人真人一级毛片| 日韩欧美久久久| av资源在线观看免费高清| 九九热视频这里只有精品| 中文av在线全新| 91香蕉亚洲精品| 综合干狼人综合首页| 狠狠干视频网站| 日韩精品午夜视频| 岛国精品一区二区三区| 国产免费观看久久| 日本一区二区三区四区五区 | 欧美午夜aaaaaa免费视频| 粉嫩一区二区三区性色av| 成人在线手机视频| 午夜精品爽啪视频| 91麻豆成人精品国产| 日韩精品在线影院| 在线heyzo| 国产美女精品视频| 久久不见久久见免费视频7| 妞干网在线播放| 久久精品国产亚洲高清剧情介绍| 国产精品久久久久久亚洲av| 中文字幕一区视频| 亚洲男人天堂网址| 亚洲激情视频网站| 日韩欧美一起| 91精品久久久久久久久不口人| 你懂的视频欧美| 99久久国产综合精品五月天喷水| 狠狠色丁香九九婷婷综合五月| 性欧美精品中出| 午夜婷婷国产麻豆精品| www.97超碰| 久久国产精品久久精品| 精品视频在线一区二区在线| 久久久水蜜桃| 一本色道久久综合亚洲精品高清| 日本女人性视频| 18成人在线观看| 中文字幕精品无码亚| 亚洲天堂免费视频| 竹内纱里奈兽皇系列在线观看| 国产成人精品日本亚洲11| 综合一区在线| 性久久久久久久久久久久久久| 国产精品午夜电影| 中国a一片一级一片| 亚洲网站在线播放| 偷拍精品精品一区二区三区| 欧美激情论坛| 免费精品视频| 国产人妻大战黑人20p| 欧美视频在线免费| 欧美91精品久久久久国产性生爱| 78色国产精品| 岳的好大精品一区二区三区| 国产免费一区二区三区视频| 99精品偷自拍| 天海翼一区二区| 亚洲精品国产精品久久清纯直播 | lutube成人福利在线观看| 国产精品国产福利国产秒拍 | 好吊色在线视频| 亚洲三级黄色在线观看| 欧美一区 二区 三区| 亚洲高清视频一区二区| 久久www免费人成看片高清| 国产精品久久久免费看| 欧美一区二区三区在线观看| 操你啦视频在线| 福利视频久久| 国产手机视频一区二区| 国产熟女一区二区| 欧美日韩亚洲国产综合| 欧洲黄色一区| 国产精品综合久久久久久| 国产欧美日韩综合一区在线播放 | 8050国产精品久久久久久| 亚洲小说图片| 欧美一级特黄a| 亚洲精品成人在线| 五月婷婷在线播放| 国产精品久久一区| 欧美+日本+国产+在线a∨观看| 97人妻精品一区二区三区免费| 色婷婷av一区| av免费在线免费观看| 九九热久久66| 麻豆91精品91久久久的内涵| 久久中文字幕无码| 亚洲石原莉奈一区二区在线观看| 四虎地址8848精品| 黄色一级片播放| 国产精品日产欧美久久久久| 午夜精品久久久久久久99热黄桃 | 亚洲社区在线观看| 国产精品久久免费视频 | 国产性猛交普通话对白| 亚洲美女激情视频| 成人综合日日夜夜| 国产极品在线视频| 亚洲人成影院在线观看| 熟妇高潮一区二区高潮| 国产精品视频免费在线观看| 国产综合自拍| 亚洲天堂av中文字幕| 亚洲精品久久久久久久久| 国内精品视频| 97公开免费视频|