欧美性猛交xxxx免费看_牛牛在线视频国产免费_天堂草原电视剧在线观看免费_国产粉嫩高清在线观看_国产欧美日本亚洲精品一5区

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

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

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

TS語言開發(fā)HarmonyOS應用:分布式計算器開發(fā)教程

海闊天空的專欄 ? 來源:HarmonyOS開發(fā)者 ? 作者:HarmonyOS開發(fā)者 ? 2022-05-23 16:37 ? 次閱讀

最近收到很多小伙伴反饋,想基于擴展的TS語言(eTS)進行HarmonyOS應用開發(fā),但是不知道代碼該從何處寫起,從0到1的過程讓新手們抓狂。本期我們將帶來“分布式計算器”的開發(fā),幫助大家了解聲明式開發(fā)范式的UI描述、組件化機制、UI狀態(tài)管理、渲染控制語法等核心機制和功能。下面我們直接進入正題。

一、整體介紹

分布式計算器可以進行簡單的數(shù)值計算,并支持遠程拉起另一個計算器FA,實現(xiàn)兩個FA進行協(xié)同計算。

如圖1所示,分布式計算器界面主要由“鍵盤”、“顯示”及“標題欄”三個模塊組成。其中,“鍵盤”“顯示”模塊負責響應用戶點擊并控制運算表達式及運算結(jié)果的顯示,實現(xiàn)了基礎的計算功能。“菜單欄”模塊為計算器頂部的菜單欄,是分布式計算功能的入口。

那么,如何實現(xiàn)分布式計算器各模塊的功能?下面我們將從組件化、聲明式描述和狀態(tài)管理三個維度來解析分布式計算器的實現(xiàn)。

圖片

圖1 計算器界面

1. 組件化

ArkUI開發(fā)框架定義了一些具有特殊含義的

組件管理裝飾器

,如圖2所示:

圖片

圖2 組件管理裝飾器

根據(jù)聲明式UI的組件化思想,我們可以將通過組件管理裝飾器將計算器界面上的各個模塊組件化為一個個獨立的UI單元。

2. 聲明式描述

通過ArkUI開發(fā)框架提供的一系列基礎組件,如Column、Text、Divider、Button等,以聲明方式進行組合和擴展來對各個模塊進行描述,包括參數(shù)構(gòu)造配置、屬性配置、事件配置以及子組件配置等,并通過基礎的數(shù)據(jù)綁定和事件處理機制實現(xiàn)各個模塊的邏輯交互。

3. 狀態(tài)管理

ArkUI開發(fā)框架定義了一些具有特殊含義的狀態(tài)管理裝飾器,如圖3所示:

圖片

圖3 狀態(tài)管理裝飾器

通過狀態(tài)管理裝飾器裝飾組件擁有的狀態(tài)屬性,當裝飾的變量更改時,組件會重新渲染更新UI界面。

以上就是實現(xiàn)分布式計算器的核心原理,下面我們將為大家?guī)矸植际接嬎闫鞯幕A計算功能與分布式功能的具體實現(xiàn)。

二、基礎計算功能的實現(xiàn)

上文中提到,分布式計算器的基礎計算功能由鍵盤模塊及顯示模塊實現(xiàn)。

1. 鍵盤模塊

鍵盤模塊響應了用戶的點擊,并實現(xiàn)了計算器的基本功能。下面我們將介紹鍵盤布局以及鍵盤功能的實現(xiàn)。

(1) 鍵盤布局

計算器界面上的鍵盤,其實是一張張圖片按照 4*5格式排列,如圖4所示:

圖片

圖4 鍵盤模塊

首先,我們需要將所有圖片保存至項目的media文件夾下,并初始化為ImageList,代碼如下:

poYBAGKLRiuANTtDAACygk54nkU546.png

然后,我們需要對鍵盤模塊進行組件化操作。這里我們通過@Component裝飾器讓鍵盤模塊成為一個獨立的組件。

最后,使用ArkUI開發(fā)框架提供的內(nèi)置組件及屬性方法進行聲明性描述。這里我們使用了Grid組件進行布局,并通過ForEach組件來迭代圖片數(shù)組實現(xiàn)循環(huán)渲染,同時還為每張圖片添加了ClickButton事件方法。代碼如下:

poYBAGKLRk-Ae1lkAAC8eUfmvWE814.png

(2) 功能實現(xiàn)

按鍵功能包含了“歸零”、“清除”、“計算”三個功能。

① 當用戶點擊C按鈕后,運算表達式與運算結(jié)果“歸零”,代碼如下:

pYYBAGKLRmuAIs7QAAA_-sAkIZU893.png

pYYBAGKLRoSAbpHXAACv2sV8wv4907.png

pYYBAGKLRpKAWw3SAACWJOCSO7A818.png

注:計算功能的實現(xiàn)依賴于JavaScript的math.js庫,使用前需通過npm install mathjs--save命令下載并安裝math.js庫。

2. 顯示模塊

顯示模塊實現(xiàn)了“

鍵入的運算表達式

”與“

運算結(jié)果

”的顯示,本質(zhì)上是Text文本,如圖5所示:

圖片

圖5顯示模塊

首先我們通過@Component裝飾器使該模塊具有組件化能力,然后在build方法里描述UI結(jié)構(gòu),最后使用@Link狀態(tài)裝飾器管理組件內(nèi)部的狀態(tài)數(shù)據(jù),當這些狀態(tài)數(shù)據(jù)被修改時,將會調(diào)用所在組件的build方法進行UI刷新。代碼如下:

poYBAGKLRq6AZ_ZVAADMkr6ZVAM373.png

至此,一個初具計算功能的計算器就實現(xiàn)了。下面我們將實現(xiàn)計算器的分布式功能。

三、分布式功能的實現(xiàn)

計算器的分布式功能以菜單欄模塊為入口,并基于分布式設備管理與分布式數(shù)據(jù)管理技術(shù)實現(xiàn)。

1. 菜單欄模塊

菜單欄

”模塊為計算器頂部菜單欄,是計算器分布式功能的入口。

圖片

圖6菜單欄模塊

如圖6所示,當用戶點擊圖標

圖片

時,執(zhí)行terminate()方法,退出計算器應用。當用戶點擊按鈕時,執(zhí)行showDialog()方法,界面上彈出的分布式設備列表彈窗,選擇設備后將獲取分布式數(shù)據(jù)管理的權(quán)限,最后實現(xiàn)遠端設備的拉起。代碼如下:

pYYBAGKLRs-ARAKOAADK_0mWay0014.png

2. 分布式設備管理

在分布式計算器應用中,分布式設備管理包含了分布式設備搜索、分布式設備列表彈窗、遠端設備拉起三部分。首先在分布式組網(wǎng)內(nèi)搜索設備,然后把設備展示到分布式設備列表彈窗中,最后根據(jù)用戶的選擇拉起遠端設備。

(1) 分布式設備搜索

通過SUBSCRIBE_ID搜索分布式組網(wǎng)內(nèi)的遠端設備,代碼如下:

pYYBAGKLRt6AHyUSAABhO-nqhps278.png

(2) 分布式設備列表彈窗

分布式設備列表彈窗實現(xiàn)了遠端設備的選擇,如圖7所示,用戶可以根據(jù)設備名稱選擇相應的設備進行協(xié)同計算。

圖片

圖7 分布式設備列表彈窗

這里我們使用@CustomDialog裝飾器來裝飾分布式設備列表彈窗,代碼如下:

poYBAGKLRwaALQjdAACtVwhrJ3o776.png

(3) 遠端設備拉起

通過startAbility(deviceId)方法拉起遠端設備的FA,代碼如下:

pYYBAGKLRxiAdwYDAABRn_WkLjA999.png

3. 分布式數(shù)據(jù)管理

分布式數(shù)據(jù)管理用于實現(xiàn)協(xié)同計算時數(shù)據(jù)在多端設備之間的相互同步。我們需要創(chuàng)建一個分布式數(shù)據(jù)庫來保存協(xié)同計算時數(shù)據(jù),并通過分布式數(shù)據(jù)通信進行同步。

(1) 管理分布式數(shù)據(jù)庫

創(chuàng)建一個KVManager對象實例,用于管理分布式數(shù)據(jù)庫對象。代碼如下:

poYBAGKLRzCACgYkAABu8l2--sY982.png

(2) 訂閱分布式數(shù)據(jù)變化

通過訂閱分布式數(shù)據(jù)庫所有(本地及遠端)數(shù)據(jù)變化實現(xiàn)數(shù)據(jù)協(xié)同,代碼如下:

poYBAGKLR0WACJ4qAACJfgJj0O8337.png

至此,具有分布式能力的計算器就實現(xiàn)了。期待廣大開發(fā)者能基于TS擴展的聲明式開發(fā)范式開發(fā)出更多有趣的應用。

來源:HarmonyOS開發(fā)者

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

    關(guān)注

    0

    文章

    28

    瀏覽量

    4515
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1982

    瀏覽量

    30534
收藏 人收藏

    評論

    相關(guān)推薦

    OpenHarmony開發(fā)案例:【分布式計算器

    使用分布式能力實現(xiàn)了一個簡單的計算器應用,可以進行簡單的數(shù)值計算,支持遠程拉起另一個設備的計算器應用,兩個計算器應用進行協(xié)同
    的頭像 發(fā)表于 04-11 15:24 ?1108次閱讀
    OpenHarmony<b class='flag-5'>開發(fā)</b>案例:【<b class='flag-5'>分布式</b><b class='flag-5'>計算器</b>】

    HarmonyOS開發(fā)實例:【分布式郵件】

    基于TS擴展的聲明開發(fā)范式編程語言編寫的一個分布式郵件系統(tǒng),可以由一臺設備拉起另一臺設備,每次改動郵件內(nèi)容,都會同步更新兩臺設備的信息
    的頭像 發(fā)表于 04-17 10:29 ?801次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發(fā)</b>實例:【<b class='flag-5'>分布式</b>郵件】

    HarmonyOS應用開發(fā)-分布式任務調(diào)度

    1. 介紹本篇CodeLab將實現(xiàn)的內(nèi)容HarmonyOS是面向全場景多終端的分布式操作系統(tǒng),使得應用程序的開發(fā)打破了智能終端互通的性能和數(shù)據(jù)壁壘,業(yè)務邏輯原子化開發(fā),適配多端。通過一
    發(fā)表于 09-18 09:21

    HarmonyOS應用開發(fā)-分布式設計

    設計理念HarmonyOS 是面向未來全場景智慧生活方式的分布式操作系統(tǒng)。對消費者而言,HarmonyOS 將生活場景中的各類終端進行能力整合,形成“One Super Device”,以實現(xiàn)
    發(fā)表于 09-22 17:11

    HarmonyOS分布式應用框架深入解讀

    設備、分布式的能力及應用,二者具有無限能力。從開發(fā)者角度看,HarmonyOS上基本的組件分為3+1,其中3代表三個Ability,分別是:PageAbility:負責用戶界面的顯示
    發(fā)表于 11-22 15:15

    HarmonyOS應用開發(fā)-關(guān)于TS語言的整體理解

    語法的解析能力,提供了跨語言調(diào)用支持,提供了TS語言高性能運行環(huán)境。 聲明UI后端引擎后端引擎提供了兼容不同開發(fā)范式的UI渲染管線,提供多
    發(fā)表于 11-30 11:03

    HDC2021技術(shù)分論壇:如何高效完成HarmonyOS分布式應用測試?

    作者:liuxun,HarmonyOS測試架構(gòu)師HarmonyOS是新一代的智能終端操作系統(tǒng),給開發(fā)者提供了設備發(fā)現(xiàn)、設備連接、跨設備調(diào)用等豐富的分布式API。隨著越來越多的
    發(fā)表于 12-13 14:55

    如何高效完成HarmonyOS分布式應用測試?

    作者:liuxun,HarmonyOS測試架構(gòu)師HarmonyOS是新一代的智能終端操作系統(tǒng),給開發(fā)者提供了設備發(fā)現(xiàn)、設備連接、跨設備調(diào)用等豐富的分布式API。隨著越來越多的
    發(fā)表于 12-13 18:07

    滿滿干貨!手把手教你實現(xiàn)基于eTS的分布式計算器

    最近收到很多小伙伴反饋,想基于擴展的TS語言(eTS)進行HarmonyOS應用開發(fā),但是不知道代碼該從何處寫起,從0到1的過程讓新手們抓狂。 本期我們將帶來“
    發(fā)表于 05-23 18:34

    HarmonyOS應用開發(fā)-EducationSystem分布式親子早教系統(tǒng)體驗

    HarmonyOS應用程序開發(fā),多屏協(xié)作交互和分布式跨設備傳輸?shù)慕?jīng)驗。 ? 從項目創(chuàng)建、代碼編寫到編譯、構(gòu)造、部署和操作。二、效果圖:完整代碼地址:https://gitee.com/jltfcloudcn/jump_to/tr
    發(fā)表于 07-25 10:23

    HarmonyOS應用開發(fā)-分布式語音攝像頭體驗

    一、組件說明使用HarmonyOS分布式文件系統(tǒng)和AI語音識別功能開發(fā)了一個分布式語音攝像頭。使用此相機應用程序,同一分布式網(wǎng)絡下的不同設備
    發(fā)表于 08-24 15:06

    HarmonyOS測試技術(shù)與實戰(zhàn)-HarmonyOS分布式應用特征與挑戰(zhàn)

     HDC 2021華為開發(fā)者大會HarmonyOS測試技術(shù)與實戰(zhàn)-HarmonyOS分布式應用特征與挑戰(zhàn)
    的頭像 發(fā)表于 10-23 14:41 ?1726次閱讀
    <b class='flag-5'>HarmonyOS</b>測試技術(shù)與實戰(zhàn)-<b class='flag-5'>HarmonyOS</b><b class='flag-5'>分布式</b>應用特征與挑戰(zhàn)

    HarmonyOS測試技術(shù)與實戰(zhàn)-分布式應用測試解決方案

    HDC 2021華為開發(fā)者大會HarmonyOS測試技術(shù)與實戰(zhàn)-HarmonyOS分布式應用測試解決方案
    的頭像 發(fā)表于 10-23 14:48 ?1635次閱讀
    <b class='flag-5'>HarmonyOS</b>測試技術(shù)與實戰(zhàn)-<b class='flag-5'>分布式</b>應用測試解決方案

    HarmonyOS分布式應用評分工具定位于幫助開發(fā)者本地快速測試

    HarmonyOS是新一代的智能終端操作系統(tǒng),給開發(fā)者提供了設備發(fā)現(xiàn)、設備連接、跨設備調(diào)用等豐富的分布式API。隨著越來越多的開發(fā)者投入到Harmo
    的頭像 發(fā)表于 12-17 13:50 ?1491次閱讀

    HarmonyOS分布式應用上架問題分析

    HarmonyOS是新一代的智能終端操作系統(tǒng),給開發(fā)者提供了設備發(fā)現(xiàn)、設備連接、跨設備調(diào)用等豐富的分布式API。隨著越來越多的開發(fā)者投入到Harmo
    的頭像 發(fā)表于 12-24 17:56 ?1947次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>分布式</b>應用上架問題分析