色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

HarmonyOS ArkUI 3.0框架試玩初體驗(yàn)

OpenHarmony技術(shù)社區(qū) ? 來(lái)源:鴻蒙技術(shù)社區(qū) ? 作者:木棉花HOS ? 2021-11-01 14:53 ? 次閱讀

HarmonyOS ArkUI 3.0正式到來(lái),今天就給大家分享一下我的 HarmonyOS ArkUI 3.0 框架試玩初體驗(yàn),以合成 1024 的開(kāi)發(fā)實(shí)戰(zhàn),帶大家感受一下 HarmonyOS ArkUI 3.0 的極簡(jiǎn)開(kāi)發(fā)。

創(chuàng)建一個(gè)空白的工程

①安裝和配置 DevEco Studio

DevEco Studio 下載
https://developer.harmonyos.com/cn/develop/deveco-studio#download

DevEco Studio 安裝:

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/software_install-0000001053582415

②創(chuàng)建一個(gè) Empty Ability 應(yīng)用

DevEco Studio 下載安裝成功后,打開(kāi) DevEco Studio,點(diǎn)擊左上角的 File,點(diǎn)擊 New,再選擇 New Project,選擇 Empty Ability 選項(xiàng),點(diǎn)擊 Next 按鈕。

將文件命名為 MyETSApplication(文件名不能出現(xiàn)中文或者特殊字符,否則將無(wú)法成功創(chuàng)建項(xiàng)目文件),Project Type 勾選 Application,選擇保存路徑。

Language 勾選 eTS,選擇 API7,設(shè)備勾選 Phone,最后點(diǎn)擊 Finish 按鈕。

③準(zhǔn)備工作

在 entry>src>main>config.json 文件中最下方"launchType": "standard"的后面添加以下代碼,這樣就可以實(shí)現(xiàn)去掉應(yīng)用上方的標(biāo)簽欄了。

config.json 最下方部分代碼:
"metaData":{
"customizeData":[
{
"name":"hwc-theme",
"value":"androidhwext:style/Theme.Emui.Light.NoTitleBar",
"extra":""
}
]
}

實(shí)現(xiàn)界面布局

①保存圖片

將 logo 圖片保存到 entry>src>main>resources>base>media 文件中。

②新一代的聲明式 UI 開(kāi)發(fā)范式

具體而言,ArkUI 3.0 中的新一代聲明式 UI 開(kāi)發(fā)范式,主要特征如下:

(1)基于 TypeScript 擴(kuò)展的聲明式 UI 描述語(yǔ)法,提供了類自然語(yǔ)言的UI描述和組合。

(2)開(kāi)箱即用的多態(tài)組件。多態(tài)是指 UI 描述是統(tǒng)一的,UI 呈現(xiàn)在不同類型設(shè)備上會(huì)有所不同。比如 Button 組件在手機(jī)和手表會(huì)有不同的樣式和交互方式。

(3)多維度的狀態(tài)管理機(jī)制,支持靈活的數(shù)據(jù)驅(qū)動(dòng)的 UI 變更。

裝飾器:用來(lái)裝飾類、結(jié)構(gòu)體、方法以及變量,賦予其特殊的含義,如上述示例中 @Entry、@Component、@State 都是裝飾器。

@Component 表示這是個(gè)自定義組件;@Entry 則表示這是個(gè)入口組件;@State 表示組件中的狀態(tài)變量,這個(gè)狀態(tài)變化會(huì)引起 UI 變更。

自定義組件:可復(fù)用的 UI 單元,可組合其它組件,如上述被 @Component 裝飾的 struct Hello。

UI 描述:聲明式的方式來(lái)描述UI的結(jié)構(gòu),如上述 build() 方法內(nèi)部的代碼塊。

內(nèi)置組件:框架中默認(rèn)內(nèi)置的基礎(chǔ)和布局組件,可直接被開(kāi)發(fā)者調(diào)用,比如示例中的 Column、Text、Divider、Button。

事件方法:用于添加組件對(duì)事件的響應(yīng)邏輯,統(tǒng)一通過(guò)事件方法進(jìn)行設(shè)置,如跟隨在 Button 后面的 onClick()。

屬性方法:用于組件屬性的配置,統(tǒng)一通過(guò)屬性方法進(jìn)行設(shè)置,如 fontSize()、width()、height()、color() 等,可通過(guò)鏈?zhǔn)秸{(diào)用的方式設(shè)置多項(xiàng)屬性。

③實(shí)現(xiàn)界面

這一次程序用到的裝飾器分別有@Entry 、@Component、@State和@Link 。

裝飾器@Entry 裝飾的自定義組件用作頁(yè)面的默認(rèn)入口組件,加載頁(yè)面時(shí),將首先創(chuàng)建并呈現(xiàn) @Entry 裝飾的自定義組件。

要注意的是:在單個(gè)源文件中,最多可以使用 @Entry 裝飾一個(gè)自定義組件。

裝飾器@Component 裝飾的 struct 表示該結(jié)構(gòu)體具有組件化能力,能夠成為一個(gè)獨(dú)立的組件,這種類型的組件也稱為自定義組件。該組件可以組合其他組件,它通過(guò)實(shí)現(xiàn) build 方法來(lái)描述 UI 結(jié)構(gòu)。 組件生命周期包括:
  • aboutToAppear:函數(shù)在創(chuàng)建自定義組件的新實(shí)例后,在執(zhí)行其build函數(shù)之前執(zhí)行。允許在 aboutToAppear 函數(shù)中改變狀態(tài)變量,這些更改將在后續(xù)執(zhí)行build函數(shù)中生效。

  • aboutToDisappear:函數(shù)在自定義組件析構(gòu)消耗之前執(zhí)行。不允許在 aboutToDisappear 函數(shù)中改變狀態(tài)變量,特別是 @Link 變量的修改可能會(huì)導(dǎo)致應(yīng)用程序行為不穩(wěn)定。

  • onPageShow:當(dāng)此頁(yè)面顯示時(shí)觸發(fā)一次。包括路由過(guò)程、應(yīng)用進(jìn)入前后臺(tái)等場(chǎng)景,僅 @Entry 修飾的自定義組件生效。

  • onPageHide:當(dāng)此頁(yè)面消失時(shí)觸發(fā)一次。包括路由過(guò)程、應(yīng)用進(jìn)入前后臺(tái)等場(chǎng)景,僅 @Entry 修飾的自定義組件生效。

  • onBackPress:當(dāng)用戶點(diǎn)擊返回按鈕時(shí)觸發(fā),,僅 @Entry 修飾的自定義組件生效。

裝飾器@State 裝飾的變量是組件內(nèi)部的狀態(tài)數(shù)據(jù),當(dāng)這些狀態(tài)數(shù)據(jù)被修改時(shí),將會(huì)調(diào)用所在組件的 build 方法進(jìn)行 UI 刷新。

要注意的是,標(biāo)記為 @State 的屬性不能直接在組件外部修改,必須為所有 @State 變量分配初始值。

裝飾器@Link 裝飾的變量可以和父組件的 @State 變量建立雙向數(shù)據(jù)綁定。要注意的是,@Link 變量不能在組件內(nèi)部進(jìn)行初始化,在創(chuàng)建組件的新實(shí)例時(shí),必須使用命名參數(shù)初始化所有 @Link 變量。

@Link 變量可以使用 @State 變量或 @Link 變量的引用進(jìn)行初始化。@State 變量可以通過(guò)’$'操作符創(chuàng)建引用。

index.ets:先定義一個(gè)方格的背景顏色字典 colors,用以繪制不同數(shù)字的背景顏色,和一個(gè)全局變量 number,用以 ForEach 的鍵值生成。

varnumber=1
constcolors={
"0":"#CDC1B4",
"2":"#EEE4DA",
"4":"#ECE0C6",
"8":"#F2B179",
"16":"#F59563",
"32":"#F67C5F",
"64":"#F65E3B",
"128":"#EDCF72",
"256":"#EDCC61",
"512":"#99CC00",
"1024":"#83AF9B",
"2048":"#0099CC",
"4096":"#0099CC",
"8192":"#0099CC"
}

對(duì)于 4x4 的方格,如果要一個(gè)一個(gè)繪制,那么就需要重復(fù)繪制 16 個(gè) Text 組件,而且這些 Text 組件除了文本之外,其他屬性值都是一樣的,這樣極其繁瑣且沒(méi)有必要,體現(xiàn)不了 HarmonyOS ArkUI 3.0 的極簡(jiǎn)開(kāi)發(fā)。

我們可以把 4x4 的方格以每一行定義成一個(gè)組件,每一行每一行地繪制,這樣能夠極大的減少代碼量。

對(duì)于每一行組件,傳統(tǒng)的方式是重復(fù)繪制 4 個(gè) Text 組件,而且這些 Text 組件除了文本之外,其他屬性值都是一樣的,同樣極其繁瑣且沒(méi)有必要。

我們可以采用 ForEach 循環(huán)渲染來(lái)繪制:

第一個(gè)參數(shù)必須是數(shù)組:允許空數(shù)組,空數(shù)組場(chǎng)景下不會(huì)創(chuàng)建子組件。同時(shí)允許設(shè)置返回值為數(shù)組類型的函數(shù)。

例如 arr.slice(1, 3),設(shè)置的函數(shù)不得改變包括數(shù)組本身在內(nèi)的任何狀態(tài)變量,如 Array.splice、Array.sort 或 Array.reverse 這些原地修改數(shù)組的函數(shù)。

第二個(gè)參數(shù)用于生成子組件的 lambda 函數(shù)。它為給定數(shù)組項(xiàng)生成一個(gè)或多個(gè)子組件。單個(gè)組件和子組件列表必須括在大括號(hào)“{…}”中。

可選的第三個(gè)參數(shù)是用于鍵值生成的匿名函數(shù)。它為給定數(shù)組項(xiàng)生成唯一且穩(wěn)定的鍵值。

當(dāng)子項(xiàng)在數(shù)組中的位置更改時(shí),子項(xiàng)的鍵值不得更改,當(dāng)數(shù)組中的子項(xiàng)被新項(xiàng)替換時(shí),被替換項(xiàng)的鍵值和新項(xiàng)的鍵值必須不同。

鍵值生成器的功能是可選的。但是,出于性能原因,強(qiáng)烈建議提供,這使開(kāi)發(fā)框架能夠更好地識(shí)別數(shù)組更改。

如單擊進(jìn)行數(shù)組反向時(shí),如果沒(méi)有提供鍵值生成器,則 ForEach 中的所有節(jié)點(diǎn)都將重建。

使用裝飾器 @Component,自定義一個(gè)每一行的組件,用裝飾器 @Link 定義一個(gè)數(shù)組 grids。

在 build() 里面添加彈性布局 Flex,使用循環(huán)渲染 ForEach 來(lái)繪制組件 Text。

對(duì)于每一個(gè) Text 組件,文本判斷是否為 0,如果值為 0,則不顯示,背景顏色采用剛才定義好的背景顏色字典 colors 對(duì)應(yīng)的背景顏色。

文本顏色判斷其值是否為 2 或 4,如果為 2 或 4,則采用顏色 #645B52,否則采用背景顏色白色。

@Component
structsetText{
@Linkgrids:number[]

build(){
Flex({justifyContent:FlexAlign.Center,alignItems:ItemAlign.Center,direction:FlexDirection.Row}){
ForEach(this.grids,
(item:number)=>Text(item==0?'':item.toString())
.width(70)
.height(70)
.textAlign(TextAlign.Center)
.fontSize(30)
.margin({left:5,top:5,right:5,bottom:5})
.backgroundColor(colors[item.toString()])
.fontColor((item==2||item==4)?'#645B52':'#FFFFFF'),
(item:number)=>(number++)+item.toString())
}
}
}

同理,使用裝飾器 @Component,自定義一個(gè)按鈕 Button 組件,用以繪制上下左右四個(gè)按鈕。

@Component
structsetButton{
privatedirtext:string
privatedir:string
@LinkGrids:number[][]
@Linkgrid1:number[]
@Linkgrid2:number[]
@Linkgrid3:number[]
@Linkgrid4:number[]

build(){
Button(this.dirtext)
.width(60)
.height(60)
.fontSize(30)
.fontWeight(FontWeight.Bold)
.align(Alignment.Center)
.backgroundColor('#974B31')
.fontColor('#FFFFFF')
.margin({left:5,top:3,right:5,bottom:3})
}
}

在裝飾器 @Entry 裝飾的結(jié)構(gòu)體的 build() 中,將原來(lái)的代碼全部刪掉。

使用裝飾器 @State 定義一個(gè)二維數(shù)組和四個(gè)一維數(shù)組,添加垂直布局 Column,寬和高都為 100%,背景顏色為白色。

在其中添加 Image 組件,引用剛才保存好的 logo 圖片,再添加一個(gè)寬和高都是 320,背景顏色為 #BBADA0 的垂直布局 Column,在其添加四個(gè)剛才定義好的行組件 setText。

在外圍的垂直布局 Column 中再添加四個(gè)剛才定義好的按鈕組件 setButton,其中中間兩個(gè)按鈕組件位于彈性布局 Flex 中,最后添加一個(gè) Button 組件,文本內(nèi)容為“重新開(kāi)始”。
@Entry
@Component
structIndex{
@Stategrids:number[][]=[[0,0,0,0],
[0,2,0,0],
[0,0,2,0],
[0,0,0,0]]
@Stategrid1:number[]=[this.grids[0][0],this.grids[0][1],this.grids[0][2],this.grids[0][3]]
@Stategrid2:number[]=[this.grids[1][0],this.grids[1][1],this.grids[1][2],this.grids[1][3]]
@Stategrid3:number[]=[this.grids[2][0],this.grids[2][1],this.grids[2][2],this.grids[2][3]]
@Stategrid4:number[]=[this.grids[3][0],this.grids[3][1],this.grids[3][2],this.grids[3][3]]

build(){
Column(){
Image($r('app.media.logo1024')).width('100%').height(140).align(Alignment.Center)
Column(){
setText({grids:$grid1})
setText({grids:$grid2})
setText({grids:$grid3})
setText({grids:$grid4})
}
.width(320)
.height(320)
.backgroundColor("#BBADA0")
setButton({dirtext:'↑',dir:'up',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
Flex({justifyContent:FlexAlign.Center,alignItems:ItemAlign.Center,direction:FlexDirection.Row}){
setButton({dirtext:'←',dir:'left',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
setButton({dirtext:'→',dir:'right',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
}
setButton({dirtext:'↓',dir:'down',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
Button('重新開(kāi)始')
.width(180)
.height(50)
.fontSize(30)
.align(Alignment.Center)
.backgroundColor('#974B31')
.fontColor('#FFFFFF')
.margin({left:5,top:3,right:5,bottom:3})
}
.width('100%')
.height('100%')
.backgroundColor("#FFFFFF")
.alignItems(HorizontalAlign.Center)
}
}

編寫(xiě)邏輯代碼

index.ets:在結(jié)構(gòu)體 setButton 中添加四個(gè)函數(shù)。
  • addTwoOrFourToGrids():用以隨機(jī)生成一個(gè)新的方格數(shù)字,數(shù)字為2或4。

  • swipeGrids(direction):用以實(shí)現(xiàn)方格的重新生成。

  • changeGrids(direction):用以實(shí)現(xiàn)方格的上下左右移動(dòng)。

  • changeString():用以將二維數(shù)組分成四個(gè)一維數(shù)組。

最后在 Button 組件的屬性里添加一個(gè)點(diǎn)擊事件,依次調(diào)用函數(shù) swipeGrids(direction)、addTwoOrFourToGrids() 和 changeString()。

@Component
structsetButton{
privatedirtext:string
privatedir:string
@LinkGrids:number[][]
@Linkgrid1:number[]
@Linkgrid2:number[]
@Linkgrid3:number[]
@Linkgrid4:number[]

addTwoOrFourToGrids(){
letarray=[];
for(letrow=0;row4;row++)
for(letcolumn=0;column4;column++)
if(this.Grids[row][column]==0)
array.push([row,column]);

letrandomIndes=Math.floor(Math.random()*array.length);
letrow=array[randomIndes][0];
letcolumn=array[randomIndes][1];
if(Math.random()0.8){
this.Grids[row][column]=2;
}else{
this.Grids[row][column]=4;
}
}

swipeGrids(direction){
letnewGrids=this.changeGrids(direction);
if(newGrids.toString()!=this.Grids.toString()){
this.Grids=newGrids;
}
}

changeGrids(direction){
letnewGrids=[[0,0,0,0],
[0,0,0,0],
[0,0,0,0],
[0,0,0,0]];

if(direction=='left'||direction=='right'){
letstep=1;
if(direction=='right'){
step=-1;//step作為循環(huán)時(shí)數(shù)組下標(biāo)改變的方向
}
for(letrow=0;row4;row++){//每一層
letarray=[];

letcolumn=0;//如果為left則從0開(kāi)始right從3開(kāi)始,
if(direction=='right'){
column=3;
}
for(leti=0;i4;i++){
if(this.Grids[row][column]!=0){//把所有非零元依次放入數(shù)組中
array.push(this.Grids[row][column]);
}
column+=step;//當(dāng)direction為left時(shí)則從0向3遞增,為right時(shí)則從3向0遞減
}
for(leti=0;i1;i++){//訪問(wèn)當(dāng)前元素及他的下一個(gè)元素,所有循環(huán)次數(shù)為length-1
if(array[i]==array[i+1]){//判斷是否可合并,
array[i]+=array[i+1];//合并,
array[i+1]=0;//合并后參與合并的第二個(gè)元素消失
i++;
}
}

column=0;
if(direction=='right'){
column=3;
}

for(constelemofarray){
if(elem!=0){//跳過(guò)array里的空元素
newGrids[row][column]=elem;//把合并后的狀態(tài)賦給新數(shù)組grids,
column+=step;
}
}
}
}elseif(direction=='up'||direction=='down'){//同理
letstep=1;
if(direction=='down'){
step=-1;
}

for(letcolumn=0;column4;column++){
letarray=[];

letrow=0;
if(direction=='down'){
row=3;
}
for(leti=0;i4;i++){
if(this.Grids[row][column]!=0){
array.push(this.Grids[row][column]);
}
row+=step;
}
for(leti=0;i1;i++){
if(array[i]==array[i+1]){
array[i]+=array[i+1];
array[i+1]=0;
i++;
}
}
row=0;
if(direction=='down'){
row=3;
}
for(constelemofarray){
if(elem!=0){
newGrids[row][column]=elem;
row+=step;
}
}
}
}
returnnewGrids;
}

changeString(){
this.grid1=[this.Grids[0][0],this.Grids[0][1],this.Grids[0][2],this.Grids[0][3]]
this.grid2=[this.Grids[1][0],this.Grids[1][1],this.Grids[1][2],this.Grids[1][3]]
this.grid3=[this.Grids[2][0],this.Grids[2][1],this.Grids[2][2],this.Grids[2][3]]
this.grid4=[this.Grids[3][0],this.Grids[3][1],this.Grids[3][2],this.Grids[3][3]]
}

build(){
Button(this.dirtext)
.width(60)
.height(60)
.fontSize(30)
.fontWeight(FontWeight.Bold)
.align(Alignment.Center)
.backgroundColor('#974B31')
.fontColor('#FFFFFF')
.margin({left:5,top:3,right:5,bottom:3})
.onClick((event:ClickEvent)=>{
this.swipeGrids(this.dir)
this.addTwoOrFourToGrids()
this.changeString()
})
}
}

在結(jié)構(gòu)體 index 中文本內(nèi)容為“重新開(kāi)始”的按鈕添加一個(gè)點(diǎn)擊事件,用以重新初始化數(shù)據(jù)。

@Entry
@Component
structIndex{
@Stategrids:number[][]=[[0,0,0,0],
[0,2,0,0],
[0,0,2,0],
[0,0,0,0]]
@Stategrid1:number[]=[this.grids[0][0],this.grids[0][1],this.grids[0][2],this.grids[0][3]]
@Stategrid2:number[]=[this.grids[1][0],this.grids[1][1],this.grids[1][2],this.grids[1][3]]
@Stategrid3:number[]=[this.grids[2][0],this.grids[2][1],this.grids[2][2],this.grids[2][3]]
@Stategrid4:number[]=[this.grids[3][0],this.grids[3][1],this.grids[3][2],this.grids[3][3]]

build(){
Column(){
Image($r('app.media.logo1024')).width('100%').height(140).align(Alignment.Center)
Column(){
setText({grids:$grid1})
setText({grids:$grid2})
setText({grids:$grid3})
setText({grids:$grid4})
}
.width(320)
.height(320)
.backgroundColor("#BBADA0")
setButton({dirtext:'↑',dir:'up',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
Flex({justifyContent:FlexAlign.Center,alignItems:ItemAlign.Center,direction:FlexDirection.Row}){
setButton({dirtext:'←',dir:'left',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
setButton({dirtext:'→',dir:'right',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
}
setButton({dirtext:'↓',dir:'down',Grids:$grids,grid1:$grid1,grid2:$grid2,grid3:$grid3,grid4:$grid4})
Button('重新開(kāi)始')
.width(180)
.height(50)
.fontSize(30)
.align(Alignment.Center)
.backgroundColor('#974B31')
.fontColor('#FFFFFF')
.margin({left:5,top:3,right:5,bottom:3})
.onClick((event:ClickEvent)=>{
this.grids=[[0,0,0,0],
[0,2,0,0],
[0,0,2,0],
[0,0,0,0]]

this.grid1=[this.grids[0][0],this.grids[0][1],this.grids[0][2],this.grids[0][3]]
this.grid2=[this.grids[1][0],this.grids[1][1],this.grids[1][2],this.grids[1][3]]
this.grid3=[this.grids[2][0],this.grids[2][1],this.grids[2][2],this.grids[2][3]]
this.grid4=[this.grids[3][0],this.grids[3][1],this.grids[3][2],this.grids[3][3]]
})
}
.width('100%')
.height('100%')
.backgroundColor("#FFFFFF")
.alignItems(HorizontalAlign.Center)
}
}

寫(xiě)在最后

HarmonyOS ArkUI 3.0 框架還有很多內(nèi)容在本次程序中沒(méi)有涉及到,例如頁(yè)面跳轉(zhuǎn)、數(shù)據(jù)管理、分布式數(shù)據(jù)庫(kù)、分布式流轉(zhuǎn)、分布式協(xié)同等等,我會(huì)在以后的文章中陸陸續(xù)續(xù)分享我的實(shí)戰(zhàn)操作,希望能與各位一起學(xué)習(xí)相互交流!

責(zé)任編輯:haq
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6856

    瀏覽量

    123435
  • 鴻蒙系統(tǒng)
    +關(guān)注

    關(guān)注

    183

    文章

    2636

    瀏覽量

    66451
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1980

    瀏覽量

    30287

原文標(biāo)題:HarmonyOS ArkUI 3.0試玩初體驗(yàn)!

文章出處:【微信號(hào):gh_834c4b3d87fe,微信公眾號(hào):OpenHarmony技術(shù)社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    HarmonyOS開(kāi)發(fā)指導(dǎo)類文檔更新速遞(上)

    伴隨著HarmonyOS 5.0.0 Release版本的發(fā)布,HarmonyOS官網(wǎng)文檔也帶來(lái)了不少上新內(nèi)容。本期HarmonyOS NEXT開(kāi)發(fā)者資料直通車將從文檔更新角度為開(kāi)發(fā)者推薦應(yīng)用
    的頭像 發(fā)表于 12-30 09:50 ?104次閱讀
    <b class='flag-5'>HarmonyOS</b>開(kāi)發(fā)指導(dǎo)類文檔更新速遞(上)

    HarmonyOS NEXT Developer Beta1中的Kit

    HarmonyOS NEXT Developer Preview1(API 11)版本開(kāi)始,HarmonyOS SDK以Kit維度提供豐富、完備的開(kāi)放能力,涵蓋應(yīng)用框架、系統(tǒng)、媒體、圖形、應(yīng)用服務(wù)
    發(fā)表于 06-26 10:47

    鴻蒙開(kāi)發(fā)ArkUI-X基礎(chǔ)知識(shí):【ArkUI代碼工程及構(gòu)建介紹】

    ArkUI作為OpenHarmony的默認(rèn)開(kāi)發(fā)框架,在本項(xiàng)目(ArkUI-X)中需要做到一套代碼同時(shí)支持多平臺(tái)構(gòu)建,所以會(huì)采取共倉(cāng)開(kāi)發(fā)的方式,部分倉(cāng)直接指向OpenHarmony相關(guān)開(kāi)源倉(cāng)。
    的頭像 發(fā)表于 05-25 16:45 ?2117次閱讀
    鴻蒙開(kāi)發(fā)<b class='flag-5'>ArkUI</b>-X基礎(chǔ)知識(shí):【<b class='flag-5'>ArkUI</b>代碼工程及構(gòu)建介紹】

    鴻蒙開(kāi)發(fā)ArkUI-X基礎(chǔ)知識(shí):【ArkUI跨平臺(tái)設(shè)計(jì)總體說(shuō)明】

    本文檔描述ArkUI開(kāi)發(fā)框架跨平臺(tái)運(yùn)行能力相關(guān)的總體技術(shù)方案。
    的頭像 發(fā)表于 05-24 15:41 ?1582次閱讀
    鴻蒙開(kāi)發(fā)<b class='flag-5'>ArkUI</b>-X基礎(chǔ)知識(shí):【<b class='flag-5'>ArkUI</b>跨平臺(tái)設(shè)計(jì)總體說(shuō)明】

    鴻蒙ArkUI-X框架開(kāi)發(fā):【開(kāi)發(fā)準(zhǔn)備】

    本文檔適用于ArkUI-X框架開(kāi)發(fā)的初學(xué)者。通過(guò)環(huán)境搭建、代碼下載、代碼編譯、API擴(kuò)展和使用,快速了解跨平臺(tái)項(xiàng)目開(kāi)發(fā)流程。
    的頭像 發(fā)表于 05-23 21:02 ?487次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X<b class='flag-5'>框架</b>開(kāi)發(fā):【開(kāi)發(fā)準(zhǔn)備】

    鴻蒙ArkUI-X跨語(yǔ)言調(diào)用說(shuō)明:【平臺(tái)橋接(@arkui-x.bridge)】

    平臺(tái)橋接用于客戶端(ArkUI)和平臺(tái)(Android或iOS)之間傳遞消息,即用于ArkUI與平臺(tái)雙向數(shù)據(jù)傳遞、ArkUI側(cè)調(diào)用平臺(tái)的方法、平臺(tái)調(diào)用ArkUI側(cè)的方法。
    的頭像 發(fā)表于 05-21 15:09 ?767次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨語(yǔ)言調(diào)用說(shuō)明:【平臺(tái)橋接(@<b class='flag-5'>arkui</b>-x.bridge)】

    鴻蒙ArkUI-X跨平臺(tái)開(kāi)發(fā):【SDK目錄結(jié)構(gòu)介紹】

    本文檔配套ArkUI-X,將OpenHarmony ArkUI開(kāi)發(fā)框架擴(kuò)展到不同的OS平臺(tái),比如Android和iOS平臺(tái),讓開(kāi)發(fā)者基于ArkUI,可復(fù)用大部分的應(yīng)用代碼(UI以及主要
    的頭像 發(fā)表于 05-20 16:28 ?831次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨平臺(tái)開(kāi)發(fā):【SDK目錄結(jié)構(gòu)介紹】

    鴻蒙ArkUI-X跨平臺(tái)技術(shù):【開(kāi)發(fā)初體驗(yàn)

    在DevEco Studio中導(dǎo)入ArkUI-X Sample,快速創(chuàng)建跨平臺(tái)工程。
    的頭像 發(fā)表于 05-17 15:54 ?688次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨平臺(tái)技術(shù):【開(kāi)發(fā)<b class='flag-5'>初體驗(yàn)</b>】

    鴻蒙跨平臺(tái)框架:【ArkUi-X】創(chuàng)建工程

    鴻蒙推出了鴻ArkUi-X 框架所以就寫(xiě)個(gè)文章分享一下
    的頭像 發(fā)表于 05-13 17:48 ?997次閱讀
    鴻蒙跨平臺(tái)<b class='flag-5'>框架</b>:【<b class='flag-5'>ArkUi</b>-X】創(chuàng)建工程

    鴻蒙ArkUI:【從代碼到UI顯示的整體渲染流程】

    方舟開(kāi)發(fā)框架(簡(jiǎn)稱ArkUI)是鴻蒙開(kāi)發(fā)的UI框架,提供如下兩種開(kāi)發(fā)范式,我們 **只學(xué)聲明式開(kāi)發(fā)范式**
    的頭像 發(fā)表于 05-13 16:06 ?961次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>:【從代碼到UI顯示的整體渲染流程】

    鴻蒙開(kāi)發(fā)學(xué)習(xí):初探【ArkUI-X】

    **簡(jiǎn)單來(lái)說(shuō),ArkTS + ArkUI-X 對(duì)標(biāo)的框架為 flutter,一次代碼,編譯為 native 全平臺(tái)運(yùn)行**
    的頭像 發(fā)表于 05-13 15:58 ?1061次閱讀
    鴻蒙開(kāi)發(fā)學(xué)習(xí):初探【<b class='flag-5'>ArkUI</b>-X】

    HarmonyOS開(kāi)發(fā)案例:【常用組件與布局】

    HarmonyOS ArkUI提供了豐富多樣的UI組件,您可以使用這些組件輕松地編寫(xiě)出更加豐富、漂亮的界面。
    的頭像 發(fā)表于 05-09 18:20 ?1245次閱讀
    <b class='flag-5'>HarmonyOS</b>開(kāi)發(fā)案例:【常用組件與布局】

    鴻蒙ArkUI開(kāi)發(fā)學(xué)習(xí):【渲染控制語(yǔ)法】

    ArkUI開(kāi)發(fā)框架是一套構(gòu)建 HarmonyOS / OpenHarmony 應(yīng)用界面的聲明式UI開(kāi)發(fā)框架,它支持程序使用?`if/else`?條件渲染,?`ForEach`?循環(huán)渲染
    的頭像 發(fā)表于 04-09 16:40 ?1020次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>開(kāi)發(fā)學(xué)習(xí):【渲染控制語(yǔ)法】

    2024款鴻蒙OS 最新HarmonyOS Next_HarmonyOS4.0系列教程分享

    Next_HarmonyOS4.0系列教程由業(yè)內(nèi)大神錄制于2024年,包括:HarmonyOS ArkTs、ArkUI、ArkTs Api、ArkTs Native、OpenHarmony
    發(fā)表于 02-28 10:29

    跨Android、iOS、鴻蒙多平臺(tái)框架ArkUI-X

    ArkUI是一套構(gòu)建分布式應(yīng)用界面的聲明式UI開(kāi)發(fā)框架。它使用極簡(jiǎn)的UI信息語(yǔ)法、豐富的UI組件、以及實(shí)時(shí)界面預(yù)覽工具,幫助您提升移動(dòng)應(yīng)用界面開(kāi)發(fā)效率30%。您只需使用一套ArkTS API,就能
    的頭像 發(fā)表于 01-31 14:52 ?1823次閱讀
    跨Android、iOS、鴻蒙多平臺(tái)<b class='flag-5'>框架</b><b class='flag-5'>ArkUI</b>-X
    主站蜘蛛池模板: 好大好爽CAO死我了BL| 在线观看成人免费视频| 亚洲欧美中文字幕高清在线| 耻辱の奴隷淑女中文字幕| 免费精品美女久久久久久久久久| 小SAO货叫大声点妓女| 国产成人高清视频| 色悠悠电影网| 国产高清视频青青青在线| 入禽太深免费高清在线观看5| 99久久久免费精品免费| 男人天堂2018亚洲男人天堂| [高清无码] 波多野结衣| 亚洲精品人成电影网| 国产精品久人妻精品| 天天爽夜夜爽8888视频精品| 123成人站| 免费无码又爽又黄又刺激网站| 97碰成视频免费| 欧美亚洲国产免费高清视频 | 亚洲伊人网站| 禁漫H天堂免费A漫| 九九热最新视频| 电影内射视频免费观看| 中文字幕久精品视频在线观看| 日产精品久久久久久久蜜殿| 好男人在线视频| 成 人 网 站毛片| 这里只有精品网| 偷拍自怕亚洲在线第7页| 男女交性视频无遮挡全过程 | 偷偷要色偷偷| 怡春院欧美一区二区三区免费| 久久这里只有精品国产精品99| 97久久精品视频| 日韩高清毛片| 国产内射AV徐夜夜| 婬香婬色天天视频| 强姧伦久久久久久久久| 国产精品久久久久无码AV色戒| 亚洲日韩成人|