国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

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

電子發燒友開源社區 ? 來源:未知 ? 2023-12-15 16:35 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

# 開發者說 #

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

前言

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

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

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

實現效果如下:

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

基本知識

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

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

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

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

項目創建

1. 建立項目

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

wKgaomV8EOyAVDyNAAGCUiCagys985.png

2. 項目目錄

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

3. 預覽器

展開Previewer,預覽器中可以查看頁面效果,其中Default尺寸與大部分手機的實際效果是相同的??梢苑奖愕牟榭醋约旱腢I代碼寫出來是什么效果,也可以測試交互代碼,非常方便。

wKgaomV8EO2ALZ_kAAGJ2czOhA4843.png

項目開發

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

1. 繪制棋盤

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

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

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

(左右滑動查看更多)

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

(1)自定義組件

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

(2)循環渲染

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

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)

(左右滑動查看更多)

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

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


	
if(this.resshow){
  //這里繪制一個結果提示頁面
  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個格子,所以我們可以直接創建一個一維數組代表棋盤:

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

(左右滑動查看更多)

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

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

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],指的就是,當棋盤數組的第0位、第1位和第2位,這三個數字相同時,說明有一個玩家勝出了。

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

總結

萬能卡片的潛力實際上是非常巨大的,目前市面上我發現大部分的卡片主要用來進行信息的展示,還需要在"交互"或者"可玩性"上繼續挖掘,希望這篇文章能給大家帶來一點啟發,期待出現更多好玩的萬能卡片。


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


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

文章出處:【微信公眾號:電子發燒友開源社區】歡迎添加關注!文章轉載請注明出處。


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

    關注

    33

    文章

    591

    瀏覽量

    34132
  • 開源社區
    +關注

    關注

    1

    文章

    95

    瀏覽量

    798

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

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發燒友開源社區】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    LabVIEW 變體:萬能數據容器的藝術

    的使用方法 常規使用是這樣的: ![圖片](./LabVIEW 變體:萬能數據容器的藝術_files/640(3)) 讓我們的程序函數(方法)能夠“泛化”。 典型應用有如下兩個: 這個我前面分析
    發表于 01-05 11:06

    新品 | Chain Blank Chain Mount,Chain系列萬能板 結構拓展節點

    節點。節點正面提供了一塊18x18mm的PCB萬能板,其內部預先焊接好了兩個互聯的HY2.0-4P接口,可直接串接到M5StackChain系列設備中且不影響設備原有功能。
    的頭像 發表于 12-26 17:28 ?1582次閱讀
    新品 | Chain Blank   Chain Mount,Chain系列<b class='flag-5'>萬能</b>板 結構拓展節點

    游戲卡頓元兇竟然是 Draw Call!

    本文轉自:字符無限科技玩游戲時遇到畫面掉幀、操作延遲,大概率和一個叫DrawCall的指標有關。它是游戲渲染的核心環節,也是性能優化繞不開的坎,哪怕是Unity、UE引擎的資深開發者,
    的頭像 發表于 11-04 10:51 ?661次閱讀
    <b class='flag-5'>游戲</b>卡頓元兇竟然是 Draw Call!

    HarmonyOSAI編程萬能卡片生成(二)

    工程保存完成后,工程中會新增如下卡片相關文件: 自定義配置邏輯代碼 邏輯代碼包含實現卡片數據交互和卡片事件兩類。 卡片數據交互:觸發卡片頁面
    發表于 09-09 16:10

    HarmonyOSAI編程萬能卡片生成(一)

    基于AI大模型理解開發者的卡片需求信息,通過對話式的交互智能生成HarmonyOS萬能卡片工程。 使用約束 建議從以下維度描述卡片需求: 當
    發表于 09-08 17:09

    國產!全志T113-i 雙核Cortex-A7@1.2GHz 工業開發板—視頻開發案

    本文主要介紹基于創龍科技TLT113-EVM評估板的視頻開發案例,適用開發環境如下。
    的頭像 發表于 08-26 14:35 ?1092次閱讀
    國產!全志T113-i 雙核Cortex-A7@1.2GHz 工業<b class='flag-5'>開發</b>板—視頻<b class='flag-5'>開發案</b>例

    HarmonyOS AI輔助編程工具(CodeGenie)卡片生成

    基于AI大模型理解開發者的卡片需求信息,通過對話式的交互智能生成HarmonyOS萬能卡片工程。 一、 使用約束 建議從以下維度描述卡片需求
    發表于 08-12 11:04

    國產!全志T113-i 雙核Cortex-A7@1.2GHz 工業開發板—物聯網模塊開發案例(上)

    本文檔主要介紹基于TLT113-EVM評估板的物聯網模塊開發案例。
    的頭像 發表于 08-07 14:47 ?948次閱讀
    國產!全志T113-i 雙核Cortex-A7@1.2GHz 工業<b class='flag-5'>開發</b>板—物聯網模塊<b class='flag-5'>開發案</b>例(上)

    國產!全志T113-i 雙核Cortex-A7@1.2GHz 工業開發板—LVGL應用開發案

    本文主要演示基于TLT113-EVM評估板的LVGL官方案例以及應用開發案
    的頭像 發表于 07-29 10:06 ?1060次閱讀
    國產!全志T113-i  雙核Cortex-A7@1.2GHz 工業<b class='flag-5'>開發</b>板—LVGL應用<b class='flag-5'>開發案</b>例

    創龍 瑞芯微 RK3562 國產 2GHz 四核A53 工業開發板—NPU開發案

    本文主要介紹基于創龍科技TL3562-EVM評估板的NPU開發案例,適用開發環境如下。
    的頭像 發表于 07-16 11:46 ?790次閱讀
    創龍 瑞芯微 RK3562 國產 2GHz 四核A53 工業<b class='flag-5'>開發</b>板—NPU<b class='flag-5'>開發案</b>例

    CodeGenie 工具功能匯總

    一、萬能卡片生成(Service Widget) CodeGenie 基于 AI 大模型,支持通過自然語言描述生成 HarmonyOS 萬能卡片工程,覆蓋 UI 布局、邏輯代碼及資源文
    的頭像 發表于 06-26 08:49 ?616次閱讀

    DevEco CodeGenie 鴻蒙AI 輔助編程初次使用

    上下文自動補全。 萬能卡片生成 :輔助創建 HarmonyOS 萬能卡片,提升開發效率。 二、插件獲取與安裝指南 獲取方式 訪問華為
    的頭像 發表于 06-26 08:48 ?923次閱讀

    FA模型卡片和Stage模型卡片切換

    卡片切換 卡片切換主要包含如下三部分: 卡片頁面布局:FA模型卡片和Stage模型卡片的布局都采用類web范式
    發表于 06-06 08:10

    鴻蒙5開發寶藏案例分享---一多開發實例(游戲

    顯示剩余時間) 好友動態瀑布流(滑動查看玩家相冊) 更離譜的是有個團隊基于這個案例,三天就做出了《賽博菜園》的偷菜提醒卡片,現在日活漲了300%! 五、避坑指南:文檔的正確打開方式 在
    發表于 06-03 18:22

    突破工業接口壁壘!ARK(方舟微)DMZ42C10S讓PLC\\\"萬能適配\\\"成為現實!

    突破工業接口壁壘!ARK(方舟微)DMZ42C10S讓PLC\"萬能適配\"成為現實!
    發表于 03-27 15:20