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

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

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

OpenHarmony DaYu200開發(fā)板示例 鴻蒙智聯(lián)汽車【1.0】

ArkUI詳解 ? 來源:鴻蒙實驗室 ? 作者:鴻蒙實驗室 ? 2022-07-13 09:22 ? 次閱讀

應(yīng)用場景:

智慧出行。

智能汽車是集環(huán)境感知、規(guī)劃決策、多等級輔助駕駛等功能于一體的智能網(wǎng)聯(lián)綜合系統(tǒng),它集中運用了計算機、現(xiàn)代傳感、信息融合、通訊、人工智能及自動控制等技術(shù),是典型的高新技術(shù)綜合體。簡單的說,智能汽車的出現(xiàn)將逐步放松車、手、眼,讓開車,用車變得簡單。這樣的產(chǎn)品對有本兒不敢上路的人來說或許是大大的福音。

在北方冬天有點冷,這個時候,去車?yán)?,溫度很低,給人一種不舒服的感覺,那么有沒有一種可能,就是可以通過手機App,實現(xiàn)對車內(nèi)的一些情況的監(jiān)測,答案是有的,今天做的這個App,就是這樣一個App。

我要實現(xiàn)的功能主要有

用戶可以解鎖任何車門,

檢查電池狀態(tài),

控制空調(diào)溫度,

檢查輪胎的氣壓。

在開始之前大家可以先預(yù)覽一下我完成之后的效果。如下圖所示:

智聯(lián)汽車演示_

是不是很炫酷呢?

搭建OpenHarmony環(huán)境

完成本篇Codelab我們首先要完成開發(fā)環(huán)境的搭建,本示例以DaYu200開發(fā)板為例,參照以下步驟進行:

獲取OpenHarmony系統(tǒng)版本:標(biāo)準(zhǔn)系統(tǒng)解決方案(二進制)

以3.0版本為例:

img

搭建燒錄環(huán)境

完成DevEco Device Tool的安裝

完成Dayu200開發(fā)板的燒錄

搭建開發(fā)環(huán)境

開始前請參考工具準(zhǔn)備 ,完成DevEco Studio的安裝和開發(fā)環(huán)境配置。

開發(fā)環(huán)境配置完成后,請參考使用工程向?qū)?創(chuàng)建工程(模板選擇“Empty Ability”),選擇eTS語言開發(fā)。

工程創(chuàng)建完成后,選擇使用真機進行調(diào)測 。

相關(guān)概念

容器組件

Column

Row

Stack

基礎(chǔ)組件

Text

Button

Image

Navigation

通用

邊框設(shè)置

尺寸設(shè)置

點擊控制

布局約束

背景設(shè)置

點擊事件

TS語法糖

好的接下來我將詳細講解如何制作

開發(fā)教學(xué)

創(chuàng)建好的 eTS工程目錄

新建工程的ETS目錄如下圖所示。

img

各個文件夾和文件的作用:

index.ets:用于描述UI布局、樣式、事件交互和頁面邏輯。

app.ets:用于全局應(yīng)用邏輯和應(yīng)用生命周期管理。

pages:用于存放所有組件頁面。

resources:用于存放資源配置文件。

接下來開始正文。

我們的主要操作都是在在pages目錄中,然后我將用不到10分鐘的時間,帶大家實現(xiàn)這個功能。

拆解

image-20220706083825022

根據(jù)設(shè)計圖,我們可以分為內(nèi)容展示區(qū)和菜單。

針對這一點,我們可以用Navigation組件作為Page頁面的根容器,通過屬性設(shè)置來展示頁面的標(biāo)題、工具欄、菜單。

Navigation

() {

Column

({

space

:

20

}) {

if

(

this

.

index

==

0

)

DoorLook

()

else

if

(

this

.

index

==

1

)

Battery

()

else

if

(

this

.

index

==

2

)

Temp

()

else

if

(

this

.

index

==

3

)

Tyre

()

}

.

backgroundColor

(

Color

.

Black

)

.

justifyContent

(

FlexAlign

.

SpaceAround

)

.

alignItems

(

HorizontalAlign

.

Center

)

.

justifyContent

(

FlexAlign

.

Center

)

.

size

({

width

:

'100%'

,

height

:

'100%'

})

} .

size

({

width

:

'100%'

,

height

:

'100%'

})

.

toolBar

(

this

.

toolbarWidget

())

.

hideToolBar

(

this

.

hideToolBar

)

.

hideTitleBar

(

this

.

hideTitleBar

)

具體布局

具體布局設(shè)計到一些細節(jié)的地方,例如間隔,邊框,當(dāng)前組件尺寸設(shè)置等一些特殊情況,基本上就是嵌套,一層一層去實現(xiàn)。

代碼結(jié)構(gòu)

image-20220706084830625

編碼

Index.ets

import

Tyre

from

'./tyre_page'

;

import

Temp

from

'./temp_page'

;

import

Battery

from

'./battery_page'

;

import

DoorLook

from

'./door_lock_page'

;

@

Entry

@

Component

struct

ComponentTest

{

@

State

index

:

number

=

0

;

// 選項卡下標(biāo),默認為第一個

@

State

hideToolBar

:

boolean

=

false

;

@

State

hideTitleBar

:

boolean

=

true

;

private

imageArray

:

string

[]

=

[

'app.media.Lock'

,

'app.media.Charge'

,

'app.media.Temp'

,

'app.media.Tyre'

,];

// 數(shù)據(jù)源

?

@

Builder

toolbarWidget

() {

// 通過builder自定義toolbar

Row

() {

Column

() {

Image

(

this

.

index

==

0

?

$r

(

'app.media.lock'

):

$r

(

'app.media.lock0'

) )

.

size

({

width

:

36

,

height

:

36

}).

margin

({

bottom

:

4

,

top

:

12

})

}

.

alignItems

(

HorizontalAlign

.

Center

)

.

height

(

'100%'

)

.

layoutWeight

(

1

)

.

onClick

(()

=>

{

this

.

index

=

0

;

})

Column

() {

Image

(

this

.

index

==

1

?

$r

(

'app.media.battery'

):

$r

(

"app.media.battery0"

))

.

size

({

width

:

36

,

height

:

36

}).

margin

({

bottom

:

4

,

top

:

12

})

?

}

.

alignItems

(

HorizontalAlign

.

Center

)

.

height

(

'100%'

)

.

layoutWeight

(

1

)

.

onClick

(()

=>

{

this

.

index

=

1

;

})

Column

() {

Image

(

this

.

index

==

2

?

$r

(

'app.media.yytemp'

):

$r

(

'app.media.yytem0'

))

.

size

({

width

:

36

,

height

:

36

}).

margin

({

bottom

:

4

,

top

:

12

})

?

}

.

alignItems

(

HorizontalAlign

.

Center

)

.

height

(

'100%'

)

.

layoutWeight

(

1

)

.

onClick

(()

=>

{

this

.

index

=

2

;

})

Column

() {

Image

(

this

.

index

==

3

?

$r

(

'app.media.tyre'

):

$r

(

'app.media.tyre0'

))

.

size

({

width

:

36

,

height

:

36

}).

margin

({

bottom

:

4

,

top

:

12

})

?

}

.

alignItems

(

HorizontalAlign

.

Center

)

.

height

(

'100%'

)

.

layoutWeight

(

1

)

.

onClick

(()

=>

{

this

.

index

=

3

;

})

}.

backgroundColor

(

Color

.

Black

)

.

width

(

'100%'

)

.

height

(

66

)

}

build

() {

Navigation

() {

Column

({

space

:

20

}) {

//根據(jù)索引展示對應(yīng)內(nèi)容?

if

(

this

.

index

==

0

)

DoorLook

()

else

if

(

this

.

index

==

1

)

Battery

()

else

if

(

this

.

index

==

2

)

Temp

()

else

if

(

this

.

index

==

3

)

Tyre

()

}

.

backgroundColor

(

Color

.

Black

)

.

justifyContent

(

FlexAlign

.

SpaceAround

)

.

alignItems

(

HorizontalAlign

.

Center

)

.

justifyContent

(

FlexAlign

.

Center

)

.

size

({

width

:

'100%'

,

height

:

'100%'

})

}

.

size

({

width

:

'100%'

,

height

:

'100%'

})

.

title

(

"跟著堅果學(xué)OpenHarmony"

)

.

toolBar

(

this

.

toolbarWidget

())

//自定義底部菜單欄

.

hideToolBar

(

this

.

hideToolBar

)

.

hideTitleBar

(

this

.

hideTitleBar

)

.

menus

([

{

value

:

"關(guān)"

,

icon

:

'common/images/door_lock.svg'

,

action

: ()

=>

{

console

.

log

(

"工具欄"

)

}

},

{

value

:

"開"

,

icon

:

'common/images/door_unlock.svg'

,

action

: ()

=>

{

}

}

])

}

}

效果演示:

車鎖頁

@

Entry

@

Component

export

default

struct

DoorLook

{

//車鎖頁

@

State

isRightDoorLock

:

boolean

=

false

;

@

State

isLeftDoorLock

:

boolean

=

false

;

@

State

isBonnetLock

:

boolean

=

false

;

@

State

isTrunkLock

:

boolean

=

false

;

?

build

() {

?

Column

() {

Stack

() {

Image

(

$r

(

"app.media.Car"

))

.

width

(

"100%"

)

.

height

(

"100%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

margin

({

left

:

20

})

Image

(

$r

(

"app.media.door_lock"

))

.

width

(

60

).

height

(

60

).

position

({

x

:

340

,

y

:

50

})

.

onClick

(()

=>

{

})

Image

(

$r

(

"app.media.door_unlock"

)).

width

(

60

).

height

(

60

).

position

({

x

:

50

,

y

:

600

})

Image

(

$r

(

"app.media.door_unlock"

)).

width

(

60

).

height

(

60

).

position

({

x

:

640

,

y

:

600

})

Image

(

$r

(

"app.media.door_unlock"

)).

width

(

60

).

height

(

60

).

position

({

x

:

340

,

y

:

920

})

?

}

?

.

backgroundColor

(

Color

.

Black

)

?

?

.

width

(

"100%"

)

.

height

(

"100%"

)

?

}

?

?

}

}

?

效果演示:

image-20220706085446034

電池頁

@

Entry

@

Component

export

default

struct

Battery

{

//電池頁

build

() {

?

Column

() {

Stack

() {

Image

(

$r

(

"app.media.Car"

))

.

width

(

"100%"

)

.

height

(

"80%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

margin

({

left

:

20

,

top

:

150

,

bottom

:

300

})

?

Text

(

"220 mi"

).

fontColor

(

Color

.

White

).

fontWeight

(

FontWeight

.

Bold

).

fontSize

(

79

).

position

({

x

:

260

,

y

:

20

})

Text

(

"62 %"

).

fontColor

(

Color

.

White

).

fontWeight

(

FontWeight

.

Bold

).

fontSize

(

60

).

position

({

x

:

320

,

y

:

90

})

Text

(

"22 mi /hr"

).

fontColor

(

Color

.

White

).

fontWeight

(

FontWeight

.

Bold

).

fontSize

(

45

).

position

({

x

:

20

,

y

:

1000

})

Text

(

"232 v"

).

fontColor

(

Color

.

White

).

fontWeight

(

FontWeight

.

Bold

).

fontSize

(

45

).

position

({

x

:

550

,

y

:

1000

})

}

?

.

backgroundColor

(

Color

.

Black

)

?

?

.

width

(

"100%"

)

.

height

(

"100%"

)

?

}

?

?

}

}

?

效果演示:

image-20220706085508024

空調(diào)頁

@

Entry

@

Component

export

default

struct

Temp

{

//空調(diào)頁

build

() {

Column

() {

Stack

() {

Image

(

$r

(

"app.media.Car"

))

.

width

(

"100%"

)

.

height

(

"100%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

position

({

x

:

268

,

y

:

90

})

.

margin

({

left

:

20

})

Image

(

$r

(

"app.media.Hot_glow_4"

))

.

width

(

"90%"

)

.

height

(

"90%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

position

({

x

:

220

,

y

:

90

})

.

margin

({

left

:

20

})

Text

(

"29"

+

"\u2103"

,).

fontSize

(

90

).

fontColor

(

Color

.

Orange

).

position

({

x

:

90

,

y

:

400

})

Image

(

$r

(

"app.media.arrow_drop_up"

))

.

width

(

60

)

.

height

(

60

)

.

position

({

x

:

120

,

y

:

360

})

Image

(

$r

(

"app.media.arrow_drop_down"

))

.

width

(

60

)

.

height

(

60

)

.

position

({

x

:

120

,

y

:

480

})

Image

(

$r

(

"app.media.cool"

)).

width

(

60

).

height

(

60

).

position

({

x

:

20

,

y

:

40

})

Image

(

$r

(

"app.media.heating"

))

.

width

(

60

)

.

height

(

60

)

.

position

({

x

:

80

,

y

:

90

})

.

borderRadius

(

7

)

.

margin

({

right

:

40

})

Column

() {

Text

(

"當(dāng)前溫度"

).

fontSize

(

32

).

fontColor

(

Color

.

White

).

margin

({

bottom

:

20

})

Row

({

space

:

30

}) {

Column

() {

Text

(

"里面"

).

fontSize

(

32

).

fontColor

(

Color

.

Orange

)

Text

(

"20"

+

"\u2103"

,).

fontSize

(

32

).

fontColor

(

Color

.

White

)

}

Column

() {

Text

(

"外邊"

).

fontSize

(

32

).

fontColor

(

Color

.

Yellow

)

Text

(

"35"

+

"\u2103"

,).

fontSize

(

32

).

fontColor

(

Color

.

White

)

}

}

}.

position

({

x

:

20

,

y

:

800

})

}

.

backgroundColor

(

Color

.

Black

)

.

offset

({

y

:

-

20

})

.

width

(

"100%"

)

.

height

(

"100%"

)

}

}

}

?

效果演示:

image-20220706085527772

輪胎頁

import

{

TyrePsiCard

}

from

'./tyre_psi_card'

?

@

Entry

@

Component

export

default

struct

Tyre

{

//輪胎頁

build

() {

?

Column

() {

Stack

() {

Image

(

$r

(

"app.media.Car"

))

.

width

(

"100%"

)

.

height

(

"80%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

margin

({

left

:

20

})

Image

(

$r

(

"app.media.FL_Tyre"

))

.

width

(

"10%"

)

.

height

(

"10%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

position

({

x

:

180

,

y

:

700

})

Image

(

$r

(

"app.media.FL_Tyre"

))

.

width

(

"10%"

)

.

height

(

"10%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

position

({

x

:

500

,

y

:

700

})

Image

(

$r

(

"app.media.FL_Tyre"

))

.

width

(

"10%"

)

.

height

(

"10%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

position

({

x

:

500

,

y

:

260

})

Image

(

$r

(

"app.media.FL_Tyre"

))

.

width

(

"10%"

)

.

height

(

"10%"

)

.

objectFit

(

ImageFit

.

Contain

)

.

position

({

x

:

180

,

y

:

260

})

TyrePsiCard

({

x

:

60

,

y

:

60

,

boardColor

:

Color

.

Blue

})

TyrePsiCard

({

x

:

380

,

y

:

60

,

boardColor

:

Color

.

Blue

})

TyrePsiCard

({

x

:

60

,

y

:

500

,

boardColor

:

Color

.

Blue

,

isBottomTwoTyre

:

false

})

TyrePsiCard

({

x

:

380

,

y

:

500

,

isBottomTwoTyre

:

false

})

}

.

backgroundColor

(

Color

.

Black

)

.

width

(

"100%"

)

.

height

(

"100%"

)

?

}

?

?

}

}

?

效果演示:

image-20220706085547727

輪胎參數(shù)

/**

* 輪胎詳細信息

*/

@

Entry

@

Component

export

struct

TyrePsiCard

{

private

text

:

string

=

''

private

x

:

number

=

0

private

y

:

number

=

0

private

boardColor

:

Color

=

Color

.

Red

private

isBottomTwoTyre

:

boolean

=

true

;

?

build

() {

Column

() {

if

(

this

.

isBottomTwoTyre

) {

Text

(

"23.6psi"

,).

fontSize

(

60

)

.

fontColor

(

Color

.

White

).

margin

({

right

:

60

})

Text

(

"56.0\u2103"

).

fontSize

(

36

)

.

fontColor

(

Color

.

Orange

).

margin

({

bottom

:

70

})

Text

(

"Low"

).

fontSize

(

60

)

.

fontColor

(

Color

.

White

)

Text

(

"Pressure"

).

fontSize

(

36

)

.

fontColor

(

Color

.

White

)

}

else

{

Text

(

"Low"

).

fontSize

(

60

).

margin

({

right

:

60

})

.

fontColor

(

Color

.

White

)

Text

(

"Pressure"

).

fontSize

(

36

)

.

fontColor

(

Color

.

White

).

margin

({

bottom

:

70

})

Text

(

"23.6psi"

,).

fontSize

(

60

)

.

fontColor

(

Color

.

White

)

Text

(

"56.0\u2103"

).

fontSize

(

36

)

.

fontColor

(

Color

.

Orange

)

}

?

?

}

.

border

({

width

:

3

,

color

:

this

.

boardColor

})

.

width

(

280

)

.

justifyContent

(

FlexAlign

.

Start

)

.

alignItems

(

HorizontalAlign

.

Start

)

// .padding({ left: 10, bottom: 20, top: 20 })

.

position

({

x

:

this

.

x

,

y

:

this

.

y

})

?

}

}

效果演示:

image-20220706085603380

恭喜你

在本文中,通過實現(xiàn)智聯(lián)汽車App示例,我主要為大家講解了如下ArkUI(基于TS擴展的類Web開發(fā)范式)組件

容器組件

Column

Row

Stack

基礎(chǔ)組件

Text

TextInput

Button

Image

Navigation

通用

邊框設(shè)置

尺寸設(shè)置

點擊控制

布局約束

背景設(shè)置

點擊事件

TS語法糖

希望通過本教程,各位開發(fā)者可以對以上基礎(chǔ)組件具有更深刻的認識。

后面的計劃:

一鍵啟動

硬件交互

動畫交互

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

    關(guān)注

    25

    文章

    5093

    瀏覽量

    97802
  • 智能汽車
    +關(guān)注

    關(guān)注

    30

    文章

    2877

    瀏覽量

    107404
  • 智慧出行
    +關(guān)注

    關(guān)注

    0

    文章

    107

    瀏覽量

    7566
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1980

    瀏覽量

    30328
  • OpenHarmony
    +關(guān)注

    關(guān)注

    25

    文章

    3731

    瀏覽量

    16431
  • 鴻蒙智聯(lián)
    +關(guān)注

    關(guān)注

    0

    文章

    29

    瀏覽量

    502
收藏 人收藏

    評論

    相關(guān)推薦

    如何實現(xiàn)DAYU200開發(fā)板使能Panfrost驅(qū)動并且支持OpenHarmony

    如何實現(xiàn)DAYU200開發(fā)板使能Panfrost驅(qū)動并且支持OpenHarmony呢?
    發(fā)表于 03-02 10:26

    基于潤和DAYU200開發(fā)套件的OpenHarmony分布式音樂播放器

    :參考DevEco Studio(OpenHarmony)使用指南搭建OpenHarmony應(yīng)用開發(fā)環(huán)境、并導(dǎo)入本工程進行編譯、運行。運行結(jié)果截圖:【分布式流轉(zhuǎn)體驗】硬件準(zhǔn)備:準(zhǔn)備兩臺潤和DA
    發(fā)表于 03-14 09:07

    【每日精選】開源鴻蒙系統(tǒng)DAYU200教程及Tina Wi-Fi模組移植

    ] 支持開源鴻蒙系統(tǒng) DAYU200 鏡像燒錄教程【問答】請問下HiHope_DAYU200 如何搭建編譯開發(fā)環(huán)境?[經(jīng)驗]作品分享-基于RT-Thread系統(tǒng)和N32G457
    發(fā)表于 03-15 15:32

    OpenHarmony 3.1 Release初體驗 潤和DAYU200開發(fā)套件

    固件下載手里剛好有一塊DAYU200開發(fā)板,官方剛好有發(fā)布編譯的固件,下載鏈接:https://gitee.com/openharmony/docs/blob/master/zh-cn
    發(fā)表于 03-31 18:10

    潤和DAYU200領(lǐng)跑OpenHarmony富設(shè)備產(chǎn)業(yè)化!

    等)提供性能優(yōu)越、穩(wěn)定可靠的智能硬件底座,在國產(chǎn)化替代方面具有標(biāo)桿意義。潤和大禹系列HH-SCDAYU200是潤和軟件推出的在社區(qū)內(nèi)首款支持OpenHarmony富設(shè)備的開發(fā)板,基于瑞芯微64位處
    發(fā)表于 04-21 20:06

    【潤和軟件DAYU200開發(fā)板體驗】潤和軟件DAYU200開發(fā)板開箱篇

    開發(fā)板靚圖: 首先談?wù)劃櫤蛙浖?b class='flag-5'>DAYU名字由來,DAYU 即是“大禹”,大禹治水精神是中華民族精神的源頭和象征。潤和軟件新款OpenHarmony高性能
    發(fā)表于 09-21 20:25

    【潤和軟件DAYU200開發(fā)板體驗】終于Helloworld?。?/a>

    hello world!是開發(fā)者跟開發(fā)板的第一個交互,今天在DAYU200上實現(xiàn)了。用了差不多兩天的學(xué)習(xí),入門的時間還算好吧。如何實現(xiàn),很多的教程了,我這菜鳥就不做講解,大家可以按我下面的教程慢慢
    發(fā)表于 09-23 21:54

    【潤和軟件DAYU200開發(fā)板體驗】移植speexdsp到OpenHarmony標(biāo)準(zhǔn)系統(tǒng)功能演示

    該視頻已經(jīng)同步上傳至硬聲app,賬號名稱離北況歸移植speexdsp到OpenHarmony標(biāo)準(zhǔn)系統(tǒng)系列文章:【潤和軟件DAYU200開發(fā)板體驗】移植speexdsp到OpenHarmony
    發(fā)表于 11-06 22:35

    OpenHarmony 潤和DAYU200開發(fā)板,全新未開封(出)

    潤和DAYU200開發(fā)板,全新未使用,多買了一塊,現(xiàn)在想出,有朋友要嗎
    發(fā)表于 09-04 15:41

    OpenHarmony Dev-Board-SIG專場:DAYU200開源計劃—代碼上Master需要的材料

    OpenHarmony Dev-Board-SIG專場:DAYU200開源計劃—代碼上Master需要的材料
    的頭像 發(fā)表于 12-28 14:14 ?1578次閱讀
    <b class='flag-5'>OpenHarmony</b> Dev-Board-SIG專場:<b class='flag-5'>DAYU200</b>開源計劃—代碼上Master需要的材料

    DAYU200開發(fā)版升級openHarmony3.1 release版本

    今天收到了來自潤和的DAYU200開發(fā)板,我們在開機之后,查看關(guān)于手機,這一欄,發(fā)現(xiàn)openharmony的版本是3.1的beta版,于是我們先做個升級,然后進行更多的體驗,
    的頭像 發(fā)表于 04-16 09:37 ?2126次閱讀
    <b class='flag-5'>DAYU200</b><b class='flag-5'>開發(fā)</b>版升級<b class='flag-5'>openHarmony</b>3.1 release版本

    潤和軟件開發(fā)板DAYU200 支持富設(shè)備開發(fā) OpenHarmony開發(fā)者都選它

    ? 智能硬件開放生態(tài)已經(jīng)進入富設(shè)備產(chǎn)業(yè)化的時代,作為OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的先驅(qū)者,潤和軟件推出了首款支持OpenHarmony富設(shè)備的開發(fā)板DAYU200。
    的頭像 發(fā)表于 10-09 17:48 ?3538次閱讀

    【潤和軟件DAYU200開發(fā)板體驗】潤和軟件DAYU200開發(fā)板開箱篇

    創(chuàng)新為內(nèi)涵的大禹治水精神,寓意著DAYU秉承OpenHarmony“以開發(fā)者為本”的開源治理宗旨和積極擔(dān)當(dāng)國產(chǎn)化歷史使命的責(zé)任定位。 ? ?? 潤和軟件DAYU200
    的頭像 發(fā)表于 10-12 11:38 ?4825次閱讀
    【潤和軟件<b class='flag-5'>DAYU200</b><b class='flag-5'>開發(fā)板</b>體驗】潤和軟件<b class='flag-5'>DAYU200</b><b class='flag-5'>開發(fā)板</b>開箱篇

    喜大普奔!DAYU200能打電話了—OpenHarmony 3.1新特性!

    碼:淘寶生態(tài)市場DAYU200開發(fā)套件潤和大禹系列HH-SCDAYU200是潤和軟件推出的社區(qū)內(nèi)首款支持OpenHarmony富設(shè)備的開發(fā)板
    的頭像 發(fā)表于 04-22 11:43 ?1162次閱讀
    喜大普奔!<b class='flag-5'>DAYU200</b>能打電話了—<b class='flag-5'>OpenHarmony</b> 3.1新特性!

    潤和軟件DAYU200OpenHarmony賦能之旅

    2021年,潤和軟件推出了OpenHarmony高性能設(shè)備平臺大禹系列,其中DAYU200作為首款支持OpenHarmony富設(shè)備的開發(fā)板,是廣大
    的頭像 發(fā)表于 11-18 09:49 ?1577次閱讀
    潤和軟件<b class='flag-5'>DAYU200</b>的<b class='flag-5'>OpenHarmony</b>賦能之旅