0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

開發(fā)案例分享:萬能卡片也能用來玩游戲

電子發(fā)燒友開源社區(qū) ? 來源:未知 ? 2023-12-15 16:35 ? 次閱讀
# 開發(fā)者說 #

【開發(fā)者說】欄目是為HarmonyOS開發(fā)者提供的展示和分享平臺,在這里,大家可以發(fā)表自己的技術(shù)洞察和見解,也可以展示自己的開發(fā)心得和成果。

前言

作為一名開發(fā)愛好者,從大了講,我學習并進行HarmonyOS相關(guān)開發(fā)是為了能為鴻蒙生態(tài)建設盡一份綿薄之力,從小了講,就是為了自己的興趣。而萬能卡片是一個讓我非常感興趣的東西。

很多時候我跟別人解釋什么是萬能卡片,都會這么說:"萬能卡片能實現(xiàn)讓你在不用打開app的前提下,在桌面上就能使用到相關(guān)服務"。有一天,我的朋友跟我說,既然可以體驗到各種服務,那么能直接在桌面上玩游戲嗎?

通過對萬能卡片相關(guān)文檔的閱讀,我認為想要實現(xiàn)一些簡單的游戲應該沒有問題,思考再三,我決定做一個井字棋小游戲,希望能給各位開發(fā)者提供些開發(fā)思路。

實現(xiàn)效果如下:

wKgaomV8EOyAYFOlACBGlL2rc0k613.gif可以看到,在桌面上有一個2x2的小卡片,通過兩名玩家輪流下棋的方式,進行井字棋的博弈,結(jié)局分為玩家1勝利、玩家2勝利或者平局,看似簡單,但也實現(xiàn)了朋友提出來的"在桌面上玩游戲"的要求。

基本知識

想要學習這個項目的開發(fā),首先我們要掌握以下幾個知識:

1. HUAWEI DevEco Studio是開發(fā)工具,是華為基于IDEA開源版本打造的開發(fā)平臺,支持頁面預覽、多端模擬等功能;

2. ArkTS是目前主推的開發(fā)語言,簡潔的語法規(guī)則極大的減少了學習成本;

3. 元服務是華為提出的一種新的概念,首先一個特點就是不用下載,即開即用;其次,元服務在手機上的表現(xiàn)形式,主要是萬能卡片,通過與萬能卡片的交互實現(xiàn)一些功能,也可以通過卡片作為類似于app的頁面入口實現(xiàn)更多的功能;最后,既然是以萬能卡片為入口的,其形式就具有多樣化的特點,可以是2x2,也可以是1x2、2x4或者4x4。

項目創(chuàng)建

1. 建立項目

選擇"Atomic Service"即建立一個元服務項目,點擊"Next"。

wKgaomV8EOyAVDyNAAGCUiCagys985.png

2. 項目目錄

這里有幾個重要的文件,首先是EntryAbility.ts,這個文件對應的是UIAbility,通俗的理解就是,當用戶想要通過與萬能卡片的交互打開一個類似app頁面的時候,那么打開的頁面就可以看做是一個UIAbility;接著是EntryFromAbility.ts,這個是卡片的Ability,可以做卡片的數(shù)據(jù)更新,或者與UIAbility相關(guān)的交互等;Index.ets就是默認打開的頁面了;而WidgetCard.ets則是卡片的頁面;如果想要設置元服務的標題,可以在AppScope/resources/base/element/string.json中修改value的值。wKgaomV8EOyAQ1qQAAEOjrVvfKY183.png

3. 預覽器

展開Previewer,預覽器中可以查看頁面效果,其中Default尺寸與大部分手機的實際效果是相同的。可以方便的查看自己的UI代碼寫出來是什么效果,也可以測試交互代碼,非常方便。

wKgaomV8EO2ALZ_kAAGJ2czOhA4843.png

項目開發(fā)

以下操作均是在WidgetCard.ets中完成:

1. 繪制棋盤

棋盤的繪制分為三個部分:

首先是背景圖,直接在Column()上進行設置背景,代碼為:

.backgroundImage($r('app.media.back'))
.backgroundImageSize(ImageSize.Cover)

(左右滑動查看更多)

接著通過循環(huán)渲染,利用Flex布局來繪制格子,這里用到了兩個知識點:

(1)自定義組件

這里的"gezi"就是一個自定義組件,傳入idx,num這兩個參數(shù),再綁定上一個click事件。

(2)循環(huán)渲染

這里需要在棋盤里顯示9個"gezi"組件,最簡單的辦法是寫上9遍基本同樣的代碼,但是這樣既不便于維護,也不美觀,因此可以使用循環(huán)渲染的方法。

Flex({wrap:FlexWrap.Wrap}){
  ForEach(this.qipan,(item,idx)=>{
    gezi({
      idx:idx,
      num:item,
      click:()=>{
        if(!this.canplay)return;
        let n = this.qipan[idx];
        if(n > 0)return;
        this.qipan[idx] = this.shunxv;
        this.shunxv = this.shunxv == 1 ? 2 : 1;
        //檢查
        this._Check();
      }
    })
  })
}.width(35*3)
.height(35*3)

(左右滑動查看更多)

然后創(chuàng)建下方的兩個小圖標,"刷新"用來重置棋盤,而"信息"用來點擊進入小游戲的說明頁。這里對于頁面的跳轉(zhuǎn),使用的是postCardAction方法。

最后再繪制一個結(jié)果顯示頁面,使用條件渲染來控制是否顯示,由于需要覆蓋整個頁面,因此采用了position+zindex的寫法。


	
if(this.resshow){
  //這里繪制一個結(jié)果提示頁面
  Column(){
    Text(this.res).fontSize(20).fontColor('white')
  }
  .backgroundColor('rgba(0,0,0,0.3)')
  .height('100%')
  .width('100%')
  .position({x:0,y:0})
  .zIndex(1)
  .alignItems(HorizontalAlign.Center)
  .justifyContent(FlexAlign.Center)
  .onClick(()=>{
    this._Init();
  })
}

(左右滑動查看更多)

最后效果如下:

wKgaomV8EO2ADVb0AAHjsU6SQIw395.png

2. 項目邏輯

井字棋的基本原理非常簡單,就是在橫、豎或者斜線上,同一類棋子排成三個即為勝利,而且整體只有9個格子,所以我們可以直接創(chuàng)建一個一維數(shù)組代表棋盤:

@State qipan : Array<number> =
  [0,0,0,
   0,0,0,
0,0,0]

(左右滑動查看更多)

0代表這個格子沒有落子,1代表是"X",2代表是"O",當玩家每次落子后,這個數(shù)組中相應的數(shù)字就會改變,同時渲染棋盤。

作為一個簡單的小游戲,其勝利的情況是有限的幾種,可以直接將其羅列出來:

constwin=[[0,1,2],[3,4,5],[6,7,8],[0,3,6],[1,4,7],[2,5,8],[0,4,8],[2,4,6]];

(左右滑動查看更多)

簡單解釋一下,比如第一個[0,1,2],指的就是,當棋盤數(shù)組的第0位、第1位和第2位,這三個數(shù)字相同時,說明有一個玩家勝出了。

每次落子后執(zhí)行_Check方法,對勝利的每一種情況進行循環(huán),檢查當前棋盤是否符合其中的任意一種勝利條件,當然還有一個條件,那就是要把0排除在勝利條件外,因為0代表的是沒有落子。如果9個格子都填滿了,卻沒有觸發(fā)勝利條件的話,則視為平局。

總結(jié)

萬能卡片的潛力實際上是非常巨大的,目前市面上我發(fā)現(xiàn)大部分的卡片主要用來進行信息的展示,還需要在"交互"或者"可玩性"上繼續(xù)挖掘,希望這篇文章能給大家?guī)硪稽c啟發(fā),期待出現(xiàn)更多好玩的萬能卡片。


更多熱點文章閱讀
  • 大佬分享!基于OpenHarmony操作系統(tǒng)無人機
  • DevEco Studio 3.1 Release | 動態(tài)共享包開發(fā),編譯更快,包更小
  • Cocos攜手樂元素,《開心消消樂》成功移植OpenHarmony
  • 開源樣例!基于小凌派RK2206的工地檢測平臺設計
  • DevEco Device Tool 3.1 Release新版本發(fā)布


原文標題:開發(fā)案例分享:萬能卡片也能用來玩游戲

文章出處:【微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


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

    關(guān)注

    33

    文章

    557

    瀏覽量

    33318
  • 開源社區(qū)
    +關(guān)注

    關(guān)注

    0

    文章

    95

    瀏覽量

    576

原文標題:開發(fā)案例分享:萬能卡片也能用來玩游戲

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    效率大升!AI賦鴻蒙萬能卡片開發(fā)

    萬能卡片,作為鴻蒙生態(tài)應用和元服務的重要展示形式,憑借將關(guān)鍵信息和核心操作前置,實現(xiàn)服務直達、減少跳轉(zhuǎn)層級的體驗效果,備受用戶和開發(fā)者青睞。但傳統(tǒng)卡片的設計和編碼流程相對繁瑣,影響了
    的頭像 發(fā)表于 01-13 13:44 ?439次閱讀
    效率大升!AI賦<b class='flag-5'>能</b>鴻蒙<b class='flag-5'>萬能</b><b class='flag-5'>卡片</b><b class='flag-5'>開發(fā)</b>

    萬能轉(zhuǎn)換開關(guān)的作用有哪些

    萬能轉(zhuǎn)換開關(guān)是一種廣泛應用于工業(yè)自動化、電力系統(tǒng)、機械設備等領域的電氣元件。它具有多種功能和優(yōu)點,能夠?qū)崿F(xiàn)對電路的控制、保護和轉(zhuǎn)換。 電路控制功能 萬能轉(zhuǎn)換開關(guān)最基本的作用是對電路進行控制。它可
    的頭像 發(fā)表于 08-20 10:18 ?2387次閱讀

    萬能轉(zhuǎn)換開關(guān)的定位結(jié)構(gòu)一般采用哪些

    直接影響到開關(guān)的穩(wěn)定性、可靠性和使用壽命。 一、萬能轉(zhuǎn)換開關(guān)定位結(jié)構(gòu)的類型 1.1 機械式定位結(jié)構(gòu) 機械式定位結(jié)構(gòu)是萬能轉(zhuǎn)換開關(guān)中最常見的一種定位方式,它主要依靠機械結(jié)構(gòu)的相互作用來實現(xiàn)開關(guān)的定位。機械式定位結(jié)構(gòu)主要
    的頭像 發(fā)表于 08-20 10:12 ?4846次閱讀

    萬能轉(zhuǎn)換開關(guān)是什么的主令電器

    萬能轉(zhuǎn)換開關(guān),作為一種高度靈活多變的主令電器,在電力工程及工程技術(shù)領域扮演著重要角色。其英文名稱為CAM switch,即Highly Versatile Change-Over Switch
    的頭像 發(fā)表于 08-20 10:11 ?2500次閱讀

    萬能斷路器參數(shù)設置的基本原則

    萬能斷路器是一種廣泛應用于電力系統(tǒng)、工業(yè)自動化和建筑電氣等領域的保護和控制設備。它具有過載保護、短路保護、欠壓保護等多種功能,能夠有效地保護電氣設備和線路的安全運行。為了確保萬能斷路器的正常工作
    的頭像 發(fā)表于 08-14 15:50 ?1501次閱讀

    萬能斷路器跳閘后如何復位

    萬能斷路器是一種廣泛應用于電力系統(tǒng)中的保護裝置,其主要作用是在電路發(fā)生故障時,能夠迅速切斷電路,以保護電氣設備和人身安全。然而,在實際使用過程中,萬能斷路器可能會出現(xiàn)跳閘現(xiàn)象,這時候就需要進行復位
    的頭像 發(fā)表于 07-31 15:24 ?3012次閱讀

    萬能斷路器合不上閘的原因

    以下是萬能斷路器合不上閘的原因的主要內(nèi)容: 萬能斷路器的基本原理和功能 萬能斷路器是一種用于保護電力系統(tǒng)的設備,可以自動切斷故障電路,以防止設備損壞和事故的發(fā)生。 萬能斷路器的主要功能
    的頭像 發(fā)表于 07-31 15:21 ?3066次閱讀

    萬能斷路器參數(shù)如何設置

    萬能斷路器是一種廣泛應用于電力系統(tǒng)、工業(yè)自動化和建筑電氣領域的電氣設備,其主要功能是在電路中起到過載、短路、欠壓等保護作用。正確設置萬能斷路器參數(shù)對于確保設備安全運行和提高系統(tǒng)可靠性具有重要意義
    的頭像 發(fā)表于 07-31 15:19 ?3090次閱讀

    簡述萬能電橋測量電容的步驟

    萬能電橋是一種測量電感和電容的儀器,具有測量范圍廣、精度高、操作簡便等特點。在測量電容時,萬能電橋可以準確地測量出電容的值,為電子電路設計和維修提供了重要的參考數(shù)據(jù)。下面介紹萬能電橋測量電容的步驟
    的頭像 發(fā)表于 07-26 09:58 ?1497次閱讀

    python函數(shù)的萬能參數(shù)

    我們通過一個簡單的事例來展示一下函數(shù)的萬能參數(shù),我們先寫一個最簡單的函數(shù)。
    的頭像 發(fā)表于 07-17 14:56 ?485次閱讀
    python函數(shù)的<b class='flag-5'>萬能</b>參數(shù)

    AG32的“萬能管腳”

    推薦新設計了,也就是說原廠停產(chǎn)這款芯片已經(jīng)進入倒計時了??蛻袈犝f我們的MCU是“萬能管腳”的,所以想試一試看能否替換。AG32的確是目前MCU產(chǎn)品中最接近于“萬能
    的頭像 發(fā)表于 07-09 10:00 ?78次閱讀
    AG32的“<b class='flag-5'>萬能</b>管腳”

    【新品體驗】核桃派(WalnutPi)ZeroW開發(fā)板免費試用

    核桃派(WalnutPi)ZeroW設計、研發(fā)和制造均來源于中國,其定位是一款高性價比而且功能齊全的卡片電腦(SBC),尺寸兼容樹莓派。是一款性能非常強大的Linux開發(fā)板,你可以使用它上網(wǎng)、玩游戲、學習編程和創(chuàng)造自己的電子產(chǎn)品
    發(fā)表于 07-05 15:36

    萬能表如何測量電瓶

    電瓶作為汽車、摩托車等交通工具的重要能源儲存裝置,其性能的好壞直接影響到車輛的正常運行。因此,定期檢查電瓶的狀態(tài),確保其電量充足、性能穩(wěn)定,是每位車主都應重視的事項。在眾多的電瓶檢測工具中,萬能
    的頭像 發(fā)表于 05-20 17:02 ?2062次閱讀

    萬能表和搖表有什么區(qū)別?

    萬能表(用表或多用電表)和搖表(兆歐表)是兩種不同類型的電氣測量工具,它們在電氣檢測中發(fā)揮著各自獨特的作用。
    的頭像 發(fā)表于 05-11 11:27 ?3126次閱讀

    玩游戲選天璣!聯(lián)發(fā)科天璣游戲技術(shù)推動游戲生態(tài)高速發(fā)展

    等生態(tài)合作伙伴,共同研討移動游戲領域的變革趨勢,并為解決當前移動游戲面臨的挑戰(zhàn)提供了星速引擎自適應軟件開發(fā)套件和硬件光線追蹤技術(shù)解決方案,不斷賦于高速擴張的天璣
    的頭像 發(fā)表于 05-07 14:21 ?703次閱讀
    <b class='flag-5'>玩游戲</b>選天璣!聯(lián)發(fā)科天璣<b class='flag-5'>游戲</b>技術(shù)推動<b class='flag-5'>游戲</b>生態(tài)高速發(fā)展

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術(shù)信息
    • 參加活動獲取豐厚的禮品