在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

如果中國空間站用上了鴻蒙系統會怎么樣?

OpenHarmony技術社區 ? 來源:鴻蒙技術社區 ? 作者:卡哇伊大喵 ? 2021-06-25 16:49 ? 次閱讀

6 月 17 日,神舟十二號發射圓滿成功。據了解,中國航天使用的是我國自主研發的麒麟操作系統,“天問一號”成功著陸火星使用的就是該系統。不少網友誤認為是華為操作系統,而華為用是鴻蒙系統和麒麟芯片,與航天用的麒麟系統根本沒什么關系。

那么假如中國空間站用上了鴻蒙系統會怎么樣呢?下面手把手教大家開發中國空間站專屬太陽能板鴻蒙小卡片!

01

項目背景

鴻蒙在手機 Beta3 中新增了桌面卡片,我也是在第一時間體驗了一下新浪新聞鴻蒙版的新聞小卡片,覺得非常有意思。

并且我覺得可以用在物聯網項目的污水液位計的液位展示中,可以實現碰一碰獲取液位計數據展示在小卡片中。

HarmonyOS 推出的服務卡片,是 FA(Feature Ability)的界面展現形式,將 FA 的重要信息或者操作前置到卡片上,以達到服務直達的目的。

02

服務卡片的 UI 設計

①尺寸選擇

鴻蒙的服務卡片尺寸分別為:微(1×2)、?。?2×2 )、中( 2×4 )、大(4×4)4 種尺寸。

污水液位計卡片展示數據比較少,所以我選了 2×2 的小卡片,和 2×4 的小卡片。

2*2 的小卡片主要是展示的是單個液位計的數據,而 2×4 的小卡片展示的是多個液位計的數據的總體展示。

②內容構成

服務卡片由多種設計元素組合而成,以下 7 種常見信息元素可以作為內容選擇:圖標、數據、文本、按鈕、圖片、宮格、列表。

污水液位計卡片我覺得主要展示的是當前的液位和液位計的歷史曲線,所以我這個污水液位計卡片由數據、文本、曲線圖、列表和按鈕組成。

③污水液位計卡片原型設計

采用水平垂直居中的布局,因為重要的數據是當前液位,所以當前液位采用 18px 的黑色字體,點擊查看詳情用是 #53A7F3 顏色的 15px 字,曲線使用 #53A7F3 顏色更顯科技感。

03

基本概念

①卡片使用方

顯示卡片內容的宿主應用,控制卡片在宿主中展示的位置。

②卡片管理服務

用于管理系統中所添加卡片的常駐代理服務,包括卡片對象的管理與使用,以及卡片周期性刷新等。

③卡片提供方

提供卡片顯示內容的 HarmonyOS 應用或原子化服務,控制卡片的顯示內容、控件布局以及控件點擊事件。

04

運作機制

卡片管理服務包含以下模塊:

周期性刷新:在卡片添加后,根據卡片的刷新策略啟動定時任務周期性觸發卡片的刷新。

卡片緩存管理:在卡片添加到卡片管理服務后,對卡片的視圖信息進行緩存,以便下次獲取卡片時可以直接返回緩存數據,降低時延。

卡片生命周期管理:對于卡片切換到后臺或者被遮擋時,暫??ㄆ乃⑿?;以及卡片的升級/卸載場景下對卡片數據的更新和清理。

卡片使用方對象管理:對卡片使用方的 RPC 對象進行管理,用于使用方請求進行校驗以及對卡片更新后的回調處理。

通信適配層:負責與卡片使用方和提供方進行 RPC 通信。

卡片提供方包含以下模塊:

①卡片服務:由卡片提供方開發者實現,開發者實現 onCreateForm、onUpdateForm 和 onDeleteForm 處理創建卡片、更新卡片以及刪除卡片等請求,提供相應的卡片服務。

卡片提供方實例管理模塊:由卡片提供方開發者實現,負責對卡片管理服務分配的卡片實例進行持久化管理。

②通信適配層:由 HarmonyOS SDK 提供,負責與卡片管理服務通信,用于將卡片的更新數據主動推送到卡片管理服務。

05

服務卡片開發環境搭建和開發

①開發環境

一臺升級了鴻蒙 2.0 的手機/登錄華為開發者賬號使用遠程模擬器。

下載安裝 DevEco Studio 2.1 Release,DevEco下載安裝教程

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/installation_process-0000001071425528

因為本文的重點是卡片,deveco 安裝教程和真機調試請看下面我的教程:

https://blog.csdn.net/qq_33259323/article/details/112405157

②新建 HarmonyOS 手機項目

API 選擇 5,show in service senter 打勾

③卡片基礎配置

然后打開配置文件 src/main/config.json,配置你所需要的卡片樣式,詳細配置請看:

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/basic-config-file-elements-0000000000034463#ZH-CN_TOPIC_0000001064016070__table8276925145611

我這邊選擇的是 2*2 的小卡片,其他的都是默認所以只需要改一下名字和描述,注意文件夾名字要和 name 對應,如果不對應就是白卡片。

④卡片基礎界面編寫代碼

編寫 hml,通過 {{}} 綁定 index.json 里面的數據:

《div class=“container”》

《div class=“title”》

《text class=“text_title”》1#液位計: 《/text》

《text class=“text_title”》{{temperature}}《/text》

《text class=“text_title”》 m《/text》

《/div》

《stack class=“chart_region”》

《chart class=“chart_data” type=“line” options=“{{lineOps}}” datasets=“{{lineData}}”》《/chart》

《/stack》

《text class=“text_nav”》點擊查看詳情《/text》

《/div》

編寫 CSS:

.container {

flex-direction: column;

justify-content: center;

align-items: center;

}

.title{

width: 100%;

height: 30px;

justify-content: center;

}

.text_title {

font-size: 15px;

}

.chart_region{

height: 90px;

}

.chart_data{

}

.text_nav {

font-size: 15px;

color: #53A7F3;

}

編寫 JSON:

{

“data”: {

“level”: “12”,

“lineData”: [

{

“strokeColor”: “#7fccde”,

“fillColor”: “#7fccde”,

“data”: [0,10,20,12,13,10,40,10,5,9,14,18,20,30,10,20,10,17],

“gradient”: true

}

],

“lineOps”: {

“xAxis”: {

“min”: 0,

“max”: 15,

“display”: false

},

“yAxis”: {

“min”: 0,

“max”: 24,

“display”: false

},

“series”: {

“lineStyle”: {

“width”: “1px”,

“smooth”: true

},

“headPoint”: {

“shape”: “circle”,

“size”: 10,

“strokeWidth”: 3,

“fillColor”: “#ffffff”,

“strokeColor”: “#7fccde”,

“display”: true

}

}

}

}

}

可以先使用預覽器看一下界面,或者直接運行。雙擊打開 index.hml,然后點擊右側的預覽器

06

服務卡片基本開發教程

①增加點擊跳轉查看詳情頁面

在 hml 增加點擊事件:

《text class=“text_nav” onclick=“routerEvent”》點擊查看詳情《/text》

創建需要跳轉的 Ability(CardFormAbility):

編寫 index.json 文件,其中 routerEvent 就是在 hml 中的 onclick 屬性值,action 為 router,abilityName 為需要跳轉到的 ability 名字。

編寫跳轉測試頁面:

package com.example.phone.ability;

import ohos.ace.ability.AceAbility;

import ohos.aafwk.content.Intent;

public class CardFormAbility extends AceAbility {

@Override

public void onStart(Intent intent) {

setInstanceName(“CardForm”);

super.onStart(intent);

}

@Override

public void onStop() {

super.onStop();

}

}

②增加簡單的長按編輯頁面

創建卡片編輯 Ability(LevelCardConfigAbility),點擊 File→New→Ability→Page Ability(JS)。

在 LevelCardConfigAbility.onstart 中添加 setInstanceName(“LevelCardConfig”);

package com.example.phone.ability;

import ohos.ace.ability.AceAbility;

import ohos.aafwk.content.Intent;

public class LevelCardConfigAbility extends AceAbility {

@Override

public void onStart(Intent intent) {

setInstanceName(“LevelCardConfig”);

super.onStart(intent);

}

@Override

public void onStop() {

super.onStop();

}

}

在 hml 中添加示例代碼:

在配置文件中增加屬性:formConfigAbility。

“formConfigAbility”: “ability://com.example.phone.ability.LevelCardConfigAbility”

污水液位計卡片編輯頁面詳細開發請看下面。

③數據手動刷新

1. 在卡片編輯小卡片添加手動刷新事件

index.hml:

0e63ce2c-d43b-11eb-9e57-12bb97331649.png

index.json:

0e70d2b6-d43b-11eb-9e57-12bb97331649.png

2. 創建 CardFormAbility(如果之前已經創建過了就不用創建了)

在 src/main/config.json 中,如果你的小卡片是寫在 MainAbility 里面的,就不需要創建這個 CardFormAbility,我是為了方便分開來,把卡片配置寫在 CardFormAbility 中。

0e82dc22-d43b-11eb-9e57-12bb97331649.png

因為是演示代碼,所以請求后臺服務器獲得數據的代碼放在 onTriggerFormEvent 中:

package com.example.phone.ability;

import ohos.aafwk.ability.FormBindingData;

import ohos.aafwk.ability.FormException;

import ohos.ace.ability.AceAbility;

import ohos.aafwk.content.Intent;

import ohos.hiviewdfx.HiLogLabel;

import ohos.utils.zson.ZSONObject;

public class CardFormAbility extends AceAbility {

private static final HiLogLabel LABEL_LOG = new HiLogLabel(3, 0xD001100, “CardFormAbility”);

@Override

public void onStart(Intent intent) {

setInstanceName(“CardForm”);

super.onStart(intent);

}

@Override

public void onStop() {

super.onStop();

}

@Override

protected void onTriggerFormEvent(long formId, String message) {

// 解析收到的數據

ZSONObject messageJSON = ZSONObject.stringToZSON(message);

if(messageJSON.get(“message”).equals(“updata”)){ // 更新數據

ZSONObject zsonObject = new ZSONObject();

// 請求后臺服務器獲得數據

zsonObject.put(“level”, “100”);

FormBindingData formBindingData = new FormBindingData(zsonObject);

try {

// 更新數據

if (!updateForm(formId, formBindingData)) {

}

} catch (FormException e) {

e.printStackTrace();

}

}

super.onTriggerFormEvent(formId, message);

}

}

這樣點擊 index.hml 中的標題,就可以更新數據了。

07

服務卡片進階開發教程

①數據定時刷新

使用鴻蒙自帶的定時刷新:數據定時刷新需要在 src/main/config.json 配置文件中配置,是否開啟定時刷新和定時刷新的時間:

“updateEnabled”: true,

“updateDuration”: 1

編寫 CardFormAbility,重寫 onUpdateForm 方法:

@Overrideprotected void onUpdateForm(long formId) {

super.onUpdateForm(formId);

ZSONObject zsonObject = new ZSONObject();

zsonObject.put(“level”, “1.123”);

FormBindingData formBindingData = new FormBindingData(zsonObject);

// 調用updateForm接口去更新對應的卡片,僅更新入參中攜帶的數據信息,其他信息保持不變

try {

if (!updateForm(formId, formBindingData)) {

// err process

}

} catch (FormException e) {

e.printStackTrace();

}

}

自定義刷新策略,請往下看。

②編輯頁面開發&編輯更新卡片邏輯開發

頁面開發

index.hml:

《div class=“container”》

《text class=“title”》

選擇液位計

《/text》

《list class=“todo-wraper”》

《list-item for=“{{todolist}}” class=“todo-item” @click=“choose({{$item.id}}})”》

《text class=“todo-title”》{{$item.title}}《/text》

《/list-item》

《/list》

《/div》

index.css:

.container {

flex-direction: column;

justify-content: center;

align-items: center;

}

.title {

font-size: 40px;

color: #000000;

opacity: 0.9;

}

.todo-wraper {

width: 454px;

height: 300px;

margin-top: 20px;

}

.todo-item {

width: 454px;

height: 80px;

flex-direction: column;

}

.todo-title {

width: 454px;

height: 40px;

text-align: center;

}

index.js:

import prompt from ‘@system.prompt’;

const ABILITY_TYPE_EXTERNAL = 0;

const ACTION_SYNC = 0;

const CHOOSE_LEVEL = 1001;

// 給CardServiceAbility發送選擇的IDexport const CardFormAbility = {

choose: async function(id){

var action = {};

action.bundleName = ‘com.example.phone’;

action.abilityName = ‘com.example.phone.ability.CardServiceAbility’;

action.messageCode = CHOOSE_LEVEL;

action.data = id;

action.abilityType = ABILITY_TYPE_EXTERNAL;

action.syncOption = ACTION_SYNC;

var result = await FeatureAbility.callAbility(action);

var ret = JSON.parse(result);

if (ret.code == 0) {

} else {

}

}

}

export default {

data: {

title: “”,

todolist: [{

title: ‘1#液位計’,

id: 1

}, {

title: ‘2#液位計’,

id: 2

},{

title: ‘3#液位計’,

id: 3

}],

},

onInit() {

this.title = this.$t(‘strings.world’);

},

choose(id) {

CardFormAbility.choose(id);

}

}

編寫 LevelCardConfigAbility 來保存卡片 ID:

package com.example.phone.ability;

import ohos.aafwk.ability.AbilitySlice;

import ohos.aafwk.content.IntentParams;

import ohos.ace.ability.AceAbility;

import ohos.aafwk.content.Intent;

public class LevelCardConfigAbility extends AceAbility {

public static Long cardId;

@Override

public void onStart(Intent intent) {

setInstanceName(“LevelCard”);

// 獲取卡片ID并進行保存

IntentParams params = intent.getParams();

cardId = (long) params.getParam(AbilitySlice.PARAM_FORM_IDENTITY_KEY);

super.onStart(intent);

}

@Override

public void onStop() {

super.onStop();

}

}

創建 CardServiceAbility 來獲取配置頁面的配置信息并且更新卡片:

package com.example.phone.ability;

import ohos.aafwk.ability.Ability;

import ohos.aafwk.ability.AbilitySlice;

import ohos.aafwk.ability.FormBindingData;

import ohos.aafwk.ability.FormException;

import ohos.aafwk.content.Intent;

import ohos.aafwk.content.IntentParams;

import ohos.app.Context;

import ohos.rpc.*;

import ohos.hiviewdfx.HiLog;

import ohos.hiviewdfx.HiLogLabel;

import ohos.utils.zson.ZSONObject;

public class CardServiceAbility extends Ability {

private static final HiLogLabel LABEL_LOG = new HiLogLabel(3, 0xD001100, “Demo”);

private CardServiceAbility.CardServiceRemote cardServiceRemote;

private static final int CHOOSE_LEVEL = 1001;

@Override

public void onStart(Intent intent) {

HiLog.error(LABEL_LOG, “CardServiceAbility::onStart”);

cardServiceRemote = new CardServiceRemote();

super.onStart(intent);

}

@Override

protected IRemoteObject onConnect(Intent intent) {

super.onConnect(intent);

return cardServiceRemote.asObject();

}

@Override

public void onDisconnect(Intent intent) {

}

class CardServiceRemote extends RemoteObject implements IRemoteBroker {

public CardServiceRemote() {

super(“CardServiceRemote”);

}

@Override

public boolean onRemoteRequest(int code, MessageParcel data, MessageParcel reply, MessageOption option) throws RemoteException {

switch (code) {

case CHOOSE_LEVEL:{

String zsonStr = data.readString();

ZSONObject zsonObject = new ZSONObject();

zsonObject.put(“name”, zsonStr+“#液位計:”);

FormBindingData formBindingData = new FormBindingData(zsonObject);

try {

if (!updateForm(LevelCardConfigAbility.cardId, formBindingData)) {

// err process

}

} catch (FormException e) {

e.printStackTrace();

}

break;

}

default: {

reply.writeString(“service not defined”);

return false;

}

}

return true;

}

@Override

public IRemoteObject asObject() {

return this;

}

}

}

③自定義刷新策略

關系型數據庫加入包:在對應的 entry 的 build.gradle 中添加包。

dependencies {

implementation fileTree(dir: ‘libs’, include: [‘*.jar’, ‘*.har’])

testCompile ‘junit4.12’

compile files(ORM_ANNOTATIONS_JAVA, ORM_ANNOTATIONS_PROCESSOR_JAVA, JAVAPOET_JAVA)

annotationProcessor files(ORM_ANNOTATIONS_JAVA, ORM_ANNOTATIONS_PROCESSOR_JAVA, JAVAPOET_JAVA)

}

在 gradle.properties 中添加 gradle 全局變量:

JAVAPOET_JAVA=C:/Users/XX/AppData/Local/Huawei/Sdk/java/2.1.1.21/build-tools/lib/javapoet_java.jar

ORM_ANNOTATIONS_PROCESSOR_JAVA=C:/Users/XX/AppData/Local/Huawei/Sdk/java/2.1.1.21/build-tools/lib/orm_annotations_processor_java.jar

ORM_ANNOTATIONS_JAVA=C:/Users/XX/AppData/Local/Huawei/Sdk/java/2.1.1.21/build-tools/lib/orm_annotations_java.jar

重新構建:創建數據庫類和表類。

數據庫類:例如,定義了一個數據庫類 LevelStore.java,數據庫包含了“Level”表,版本號為“1”。

數據庫類的 getVersion 方法和 getHelper 方法不需要實現,直接將數據庫類設為虛類即可。

package com.example.phone.store;

import com.example.phone.store.from.Level;

import ohos.data.orm.OrmDatabase;

import ohos.data.orm.annotation.Database;

@Database(entities = {Level.class}, version = 1)public abstract class LevelStore extends OrmDatabase {

}

創建表類:

package com.example.phone.store.from;

import ohos.data.orm.OrmObject;

import ohos.data.orm.annotation.Entity;

import ohos.data.orm.annotation.PrimaryKey;

@Entity(tableName = “level”)public class Level extends OrmObject {

public Long getId() {

return id;

}

public void setId(Long id) {

this.id = id;

}

public String getName() {

return name;

}

public Level() {

}

public Level(Long id, String name) {

this.id = id;

this.name = name;

}

@Override

public String toString() {

return “LevelCard{” +

“id=” + id +

“, name=‘” + name + ’‘’ +

‘}’;

}

public void setName(String name) {

this.name = name;

}

@PrimaryKey(autoGenerate = true)

private Long id;

private String name;

}

卡片數據將存在數據庫并定時刷新:

private static OrmContext ormContext = null;

private DatabaseHelper helper = new DatabaseHelper(this);

@Override

protected ProviderFormInfo onCreateForm(Intent intent) {

IntentParams params = intent.getParams();

if (params == null) {

return null;

}

// 卡片ID

Long formId = (long) params.getParam(AbilitySlice.PARAM_FORM_IDENTITY_KEY);

// 卡片名稱

String formName = (String) params.getParam(AbilitySlice.PARAM_FORM_NAME_KEY);

// 卡片規格信息

int specificationId = (int) params.getParam(AbilitySlice.PARAM_FORM_DIMENSION_KEY);

System.out.println( “創建卡片: ” + formId + “ ” + formName + “ ” + specificationId);

if(ormContext == null){

createDataBase(getContext());

}

// 存儲數據

Level newLevel = new Level(formId, formName);

boolean isSuccessed = ormContext.insert(newLevel);

isSuccessed = ormContext.flush();

}

public void createDataBase(Context context){

// 創建數據庫

ormContext = helper.getOrmContext(“LevelStore”, “LevelStore.db”, LevelStore.class);

// 啟動定時刷新程序

startTimer();

}

private void startTimer(){

Timer timer = new Timer();

timer.schedule(new TimerTask() {

@Override

public void run() {

// 查詢數據庫獲取數據

OrmPredicates query = ormContext.where(Level.class);

List《Level》 levelCard = ormContext.query(query);

ZSONObject zsonObject = new ZSONObject();

try {

for (Level l:levelCard){

Long formId = l.getId();

// 設置數據

double randomLevel = Math.random()*10;

DecimalFormat randomLevelDf = new DecimalFormat( “0.00”);

zsonObject.put(“level”, randomLevelDf.format(randomLevel));

FormBindingData formBindingData = new FormBindingData(zsonObject);

if (!updateForm(formId, formBindingData)) {

deleteLevelCard(formId);

}

}

} catch (FormException e) {

e.printStackTrace();

}

}

},5,700L);

}

責任編輯:haq

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

    關注

    216

    文章

    34437

    瀏覽量

    251754
  • 鴻蒙系統
    +關注

    關注

    183

    文章

    2634

    瀏覽量

    66348
  • HarmonyOS
    +關注

    關注

    79

    文章

    1975

    瀏覽量

    30202

原文標題:假如中國空間站用上鴻蒙系統...

文章出處:【微信號:gh_834c4b3d87fe,微信公眾號:OpenHarmony技術社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    日本將發射首顆木質外殼衛星,預計9月抵達空間站

    該微型衛星預計今年9月由美國佛羅里達州肯尼迪航天中心發射升空,前往國際空間站,并于次月從日本“希望號”實驗艙投放至太空中。
    的頭像 發表于 05-30 15:48 ?467次閱讀

    鴻蒙開發就業前景到底怎么?

    ,如智能汽車、物聯網等。因此,從行業發展趨勢來看,鴻蒙系統的發展前景非常廣闊,學習鴻蒙開發將有更多的就業機會和發展空間。 綜上所述, 學習鴻蒙
    發表于 05-09 17:37

    鴻蒙的1萬個理由,北京中關村現大幅鴻蒙海報

    五一假期以來,北京中關村附近多個地鐵、公交站出現大幅鴻蒙海報。據統計,不止中關村,北京杭州兩地清華、北大、浙江大學等多所高校附近也掛上了巨幅鴻蒙海報。 學
    發表于 05-08 20:31

    騰訊突然宣布,微信鴻蒙版要來了!

    應用,僅支持鴻蒙內核和系統的應用,被稱為 “純血鴻蒙”而備受關注, 這意味著, 真正的國產手機操作系統要來了 ,而且影響力驚人, 一上線就是僅次于 Android 和 iOS 之后的全
    發表于 04-30 19:34

    國際空間站鎳氫電池碎片墜屋,美宇航局正調查

    該意外發生在海濱城市那不勒斯,房主人名叫亞歷杭德羅·奧特羅(Alejandro Otero)。該事件發生于3月8日,奧特羅猜測此物體與國際空間站有關。據悉,2021年3月,國際空間站廢棄了一個裝載約2630千克鎳氫電池的托盤。
    的頭像 發表于 04-16 11:03 ?563次閱讀

    鴻蒙系統三防平板怎么

    效防止碰撞和摔落對設備造成的損害,大大延長了使用壽命。其次,鴻蒙系統三防平板搭載了高性能的處理器和大容量存儲空間,為用戶提供了流暢的操作體驗和豐富的應用場景。無論是處理復雜的圖形計算、運行大型應用軟件
    發表于 04-12 14:26

    B完成鴻蒙原生應用Beta版研發

    此外,用戶還可在該平臺上即時參與一鍵三連、發表彈幕和評論等多元化的社區活動。B官方承諾,接下來進一步優化視頻消費及社交互動功能,并在鴻蒙系統自帶的智能、安全和連接功能基礎上,帶給大
    的頭像 發表于 03-29 16:20 ?717次閱讀

    SpaceX 發射龍飛船為國際空間站送去新科研設備和物資

    約在發射后八分鐘,獵鷹九號順利降落在SLC-40的指定著陸區域,本次發射使用的一級助推器B1080已有過六次發射紀錄。CRS-30貨運龍飛船與火箭上級分離僅耗費不到12分鐘,其將飛行大約兩天后,計劃于3月23日與國際空間站接軌。
    的頭像 發表于 03-22 10:40 ?985次閱讀

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

    鴻蒙的出現,標志著中國科技的崛起。HarmonyOS就是我們說的華為鴻蒙系統,截止到2023年8月4日已有超過7億臺設備搭載了鴻蒙OS
    發表于 02-28 10:29

    那些杠鴻蒙的現在怎么了?

    別杠,要杠就是你對。 一個純血鴻蒙就已經打了那些杠精的嘴,以前是套殼Android,大家紛紛噴鴻蒙。現在鴻蒙已經全棧自研,并且已經展開各大企業生態合作。不管什么獨立系統,都是一定要走一
    發表于 02-16 22:03

    華為鴻蒙系統怎么 華為鴻蒙系統和安卓系統的區別

    華為鴻蒙系統是華為公司自主研發的全場景分布式操作系統,于2019年8月首次發布。鴻蒙系統不同于傳統的操作
    的頭像 發表于 02-02 14:54 ?1746次閱讀

    鴻蒙不再兼容安卓,那么鴻蒙開發者是否大增?

    鴻蒙技術,享受藍海紅利。 鴻蒙的技術技能體系是怎么的?其實鴻蒙的板塊內容也是居多的,可以用一張鴻蒙的開發者學習路線概括,如下: 從圖中可以看到鴻蒙
    發表于 01-31 22:17

    電源設計如果只看電壓跌落,不看電流密度怎么?

    電源設計如果只看電壓跌落,不看電流密度怎么? 電源設計是一項非常重要的工程設計任務,它的目標是為各種設備和系統提供穩定可靠的電力供應。在電源設計中,我們通常需要同時考慮電壓跌落和電
    的頭像 發表于 01-22 15:49 ?775次閱讀

    天舟七號貨運飛船成功對接空間站,攜帶厭氧古菌探索外星生命

    據央視新聞,中國科學院微生物研究所研究員東秀珠、清華大學地球系統科學系教授劉竹透露,這種細菌的食物非常簡單,他們打算在空間站的輻射條件、微重力環境及適宜溫度等條件下設立一個極端環境,以測驗該細菌能否在此環境中生存。
    的頭像 發表于 01-18 10:24 ?674次閱讀

    為什么很多人不看好鴻蒙?輕舟已過萬重山

    其實這個爭議存在很久了。但是到2023年9月份開始,華為秋季發布會上宣布了“鴻蒙不再兼容Android”當時就已經炸開了鍋。這個消息讓很多不看好鴻蒙的人都閉上了嘴。我們作為國人應該支持自己的操作
    發表于 01-15 22:44
    主站蜘蛛池模板: 免费观看老外特级毛片| 福利视频亚洲| 91大神在线观看视频| 一级全免费视频播放| 免费看三级黄色片| 婷婷丁香色综合狠狠色| 九九精品久久久久久噜噜| 国产一级特黄aa大片爽爽| 天天槽任我槽免费| 亚洲欧美视频在线观看| 日韩xx00| 天天操天天干天天| 欧美色图狠狠干| 亚洲人成网站在线在线| 四虎国产精品永久在线| 欧美色视频网| 天天操天天拍| 久久精品国产免费高清| 三级免费黄录像| 国产色婷婷精品综合在线观看| 国内黄色精品| 性69交片免费看| 97精品在线| 69日本xxxxxxxxx18| 人人看人人澡| 97理论片| 69xxx日本| 免费一级在线观看| 久久人人干| 亚洲91色| 日本最新免费网站| 人人精品| 亚洲人成电影综合网站色| 成 人在线观看视频网站| 日日操夜夜骑| 中文字幕一二三区| 欧美人与动性行为网站免费| 免费福利影院| 天天综合色一区二区三区| 韩国三级床戏合集| 免费看大美女大黄大色|