自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

HarmonyOS時鐘服務卡片開發(fā)指南

開發(fā) OpenHarmony
文章由鴻蒙社區(qū)產出,想要了解更多內容請前往:51CTO和華為官方戰(zhàn)略合作共建的鴻蒙技術社區(qū)https://harmonyos.51cto.com

[[406622]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區(qū)

https://harmonyos.51cto.com

 服務卡片(以下簡稱“卡片”)是FA(Feature Ability)的一種界面展示形式,將FA(Feature Ability)的重要信息或操作前置到卡片,以達到服務直達,減少體驗層級目的。

卡片常用于嵌入到其他應用(當前只支持系統(tǒng)應用)中作為其界面的一部分顯示,并支持拉起頁面,發(fā)送消息等基礎的交互功能。

本期Codelab,我們就來為大家介紹如何在HarmonyOS上開發(fā)一個時鐘類服務卡片應用,該卡片開發(fā)使用Java開發(fā)語言,包含2×2、2×4兩種布局的顯示形態(tài),我們先來看看它的顯示效果。

[[406623]]

下面我們將集中于卡片應用的創(chuàng)建、更新和刪除,卡片數(shù)據(jù)庫(用于存儲卡片信息)的創(chuàng)建和使用以及卡片數(shù)據(jù)服務的使用和更新。

在開始敲代碼之前,開發(fā)者們需要先下載安裝Huawei DevEco Studio,可參照官網(wǎng)的指南進行操作:

● Huawei DevEco Studio安裝指南:

https://developer.harmonyos.com/cn/docs/documentation/docguides/software_install0000001053582415

本Codelab主要在entry\src\main\java\目錄下完成配置聲明、頁面布局、功能邏輯代碼實現(xiàn),整個工程的代碼結構如下:

【Codelab】時鐘服務卡片開發(fā)指南-鴻蒙HarmonyOS技術社區(qū)

● database文件夾

開發(fā)者需自行創(chuàng)建的文件夾,包含兩個java文件——Form和FormDatabase。其中Form為卡片對象,用于存儲卡片id,卡片名稱以及卡片規(guī)格。FormDatabase為卡片數(shù)據(jù)庫對象,用于創(chuàng)建卡片數(shù)據(jù)庫。

● slice文件夾

僅包含ClockCardSlice文件,為應用主頁面。

● utils文件夾

開發(fā)者需自行創(chuàng)建的文件夾,用于存放各類封裝好的工具,在本Codelab中,包含ComponentProviderUtils、DatabaseUtils、DateUtils和LogUtils。其中,ComponentProviderUtils提供獲取ComponentProvider對象的方法,用于更新卡片;DatabaseUtils提供對數(shù)據(jù)庫相關操作的方法;DateUtils提供日期相關操作的方法;LogUtils封裝日志工具類。

● MainAbility

主程序入口,由DevEco Studio生成,用于重寫創(chuàng)建、刪除卡片等方法。

● MyApplication

DevEco Studio生成,無需做任何變更。

● TimerAbility

一種Service Ability,需要開發(fā)者需自行創(chuàng)建,用于時鐘更新。

● layout文件夾

頁面布局文件夾,由于時鐘卡片Codelab涉及兩個尺寸:2×2和2×4,因此需要新建兩個.xml文件用于頁面布局。

● config.json

配置文件,用于卡片和Service Ability的聲明。

了解完工程代碼結構,下面讓我們來對重點步驟一一講解。

一、配置文件

在卡片應用開始開發(fā)前,我們需要在其配置文件config.json中進行以下幾項聲明,使系統(tǒng)能夠識別該應用為一款卡片應用,并使之與系統(tǒng)進行綁定。

在卡片所在的"abilities"中需要配置“formsEnabled": true和"visible": true,使之能被識別為卡片。同時需要配置forms模塊的細節(jié),代碼如下:

  1. "abilities": [ 
  2.   { 
  3.    .... 
  4.     "formsEnabled"true,//表示該Ability支持服務卡片顯示 
  5.     "visible"true
  6.     "forms": [  
  7.       {  
  8.         "landscapeLayouts": [  
  9.         "$layout:form_image_with_info_date_card_2_2",  
  10.         "$layout:form_image_with_info_date_card_2_4"  
  11.         ], //表示卡片外觀規(guī)格對應的橫向布局文件,僅當卡片類型為Java卡片時,需要配置該標簽 
  12.         "isDefault"true, //該卡片為默認卡片 
  13.         "scheduledUpdateTime""10:30",  
  14.         "defaultDimension""2*2", //卡片的默認外觀規(guī)格,這里是2*2 
  15.         "name""DateCard", //卡片的類名 
  16.         "description""This is a service widget", //卡片的描述 
  17.         "colorMode""auto",  
  18.         "type""Java", //表示卡片的類型,這是一個java卡片 
  19.         "supportDimensions": [  
  20.           "2*2",  
  21.           "2*4"  
  22.         ], //表示卡片支持的外觀規(guī)格,這里是2*2和2*4 
  23.         "portraitLayouts": [  
  24.           "$layout:form_image_with_info_date_card_2_2",  
  25.           "$layout:form_image_with_info_date_card_2_4"  
  26.         ], //表示卡片外觀規(guī)格對應的豎向布局文件,僅當卡片類型為Java卡片時,需要配置該標簽 
  27.         "updateEnabled"true, //表示支持周期性刷新,可以在定時刷新 
  28.         "updateDuration": 1, //表示卡片定時刷新的更新周期,單位為30分鐘,這里為30分鐘刷新一次 
  29.         "formVisibleNotify"true  
  30.         }  
  31.       ] 

有關forms模塊相關屬性說明,開發(fā)者可自行參見官網(wǎng)資料。

● Java卡片開發(fā)指導

https://developer.harmonyos.com/cn/docs/documentation/docguides/abilityservicewidgetproviderjava0000001104082220

二、卡片布局

本篇Codelab為卡片應用設計了2×2和2×4兩種布局風格,效果如下圖:

【Codelab】時鐘服務卡片開發(fā)指南-鴻蒙HarmonyOS技術社區(qū)
【Codelab】時鐘服務卡片開發(fā)指南-鴻蒙HarmonyOS技術社區(qū)

其中,2×2布局分為四行,展示的內容從上到下分別為日期、時間說明內容、時間具體信息、星期,整體由DependentLayout布局內嵌套四個DirectionalLayout構成,每個DirectionalLayout內均使用Text組件進行展示,部分代碼示例如下:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <DependentLayout 
  3.     xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  4.     ohos:height="match_parent" 
  5.     ohos:width="match_parent" 
  6.     ohos:background_element="#6A9F99" 
  7.     ohos:remote="true"
  8. <!--DirectionalLayout布局-->  
  9.     <DirectionalLayout 
  10.         ohos:height="match_content" 
  11.         ohos:width="match_parent" 
  12.         ohos:orientation="vertical"
  13. <!--日期Text組件-->          
  14.         <Text...> 
  15.     </DirectionalLayout> 
  16. <!--DirectionalLayout布局-->  
  17.     <DirectionalLayout 
  18.         ohos:id="$+id:title" 
  19.         ohos:height="match_content" 
  20.         ohos:width="match_parent" 
  21.         ohos:alignment="horizontal_center" 
  22.         ohos:orientation="horizontal" 
  23.         ohos:top_margin="35fp"
  24. <!--時間說明內容(HOUR、MIN、SEC)Text組件-->  
  25.         <Text...> 
  26.         <Text...> 
  27.         <Text...> 
  28.     </DirectionalLayout> 
  29. <!--DirectionalLayout布局-->  
  30.     <DirectionalLayout 
  31.         ohos:id="$+id:time" 
  32.         ohos:height="match_content" 
  33.         ohos:width="match_parent" 
  34.         ohos:alignment="horizontal_center" 
  35.         ohos:below="$id:title" 
  36.         ohos:orientation="horizontal" 
  37.         ohos:top_margin="0.5fp"
  38. <!--時間具體信息Text組件-->  
  39.         <Text...> 
  40.         <Text...> 
  41.         <Text...> 
  42.         <Text...> 
  43.         <Text...> 
  44.     </DirectionalLayout> 
  45.  <!--DirectionalLayout布局-->  
  46.     <DirectionalLayout 
  47.         ohos:height="match_content" 
  48.         ohos:width="match_parent" 
  49.         ohos:alignment="center" 
  50.         ohos:below="$id:time" 
  51.         ohos:margin="20fp" 
  52.         ohos:orientation="horizontal"
  53. <!--星期Text組件-->  
  54.         <Text...> 
  55.         <Text...> 
  56.         <Text...> 
  57.         <Text...> 
  58.         <Text...> 
  59.         <Text...> 
  60.         <Text...> 
  61.     </DirectionalLayout> 
  62. </DependentLayout> 

2×4布局分為三行,將日期與星期合為一行,時間說明內容、時間具體信息各單列一行,整體由DependentLayout布局嵌套一個DependentLayout和兩個DirectionalLayout構成。

其中DependentLayout布局中由一個Text組件和一個DirectionalLayout組成,DirectionalLayout中又嵌套七個Text組件。其余兩個DirectionalLayout內均使用Text組件進行展示,部分代碼示例如下:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <DependentLayout 
  3.     xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  4.     ohos:height="match_parent" 
  5.     ohos:width="match_parent" 
  6.     ohos:background_element="#6A9F99" 
  7.     ohos:remote="true"
  8. <!--DependentLayout布局--> 
  9.     <DependentLayout 
  10.         ohos:height="match_content" 
  11.         ohos:width="match_parent" 
  12.         ohos:orientation="horizontal"
  13. <!--日期Text組件-->    
  14.         <Text...> 
  15. <!--DirectionalLayout布局-->  
  16.         <DirectionalLayout 
  17.             ohos:height="match_content" 
  18.             ohos:width="match_content" 
  19.             ohos:align_parent_right="true" 
  20.             ohos:orientation="horizontal" 
  21.             ohos:top_margin="10fp"
  22. <!--星期Text組件-->              
  23.             <Text...> 
  24.             <Text...> 
  25.             <Text...> 
  26.             <Text...> 
  27.             <Text...> 
  28.             <Text...> 
  29.             <Text...> 
  30.         </DirectionalLayout> 
  31.     </DependentLayout> 
  32. <!--DirectionalLayout布局-->      
  33.     <DirectionalLayout 
  34.         ohos:id="$+id:title" 
  35.         ohos:height="match_content" 
  36.         ohos:width="match_parent" 
  37.         ohos:alignment="horizontal_center" 
  38.         ohos:orientation="horizontal" 
  39.         ohos:top_margin="35fp"
  40. <!--時間說明內容(HOUR、MIN、SEC)Text組件-->   
  41.         <Text...> 
  42.         <Text...> 
  43.         <Text...> 
  44.     </DirectionalLayout> 
  45. <!--DirectionalLayout布局-->   
  46.     <DirectionalLayout 
  47.         ohos:id="$+id:time" 
  48.         ohos:height="match_content" 
  49.         ohos:width="match_parent" 
  50.         ohos:alignment="horizontal_center" 
  51.         ohos:below="$id:title" 
  52.         ohos:orientation="horizontal"
  53. <!--時間具體信息Text組件-->  
  54.         <Text...> 
  55.         <Text...> 
  56.         <Text...> 
  57.         <Text...> 
  58.         <Text...> 
  59.     </DirectionalLayout> 
  60. </DependentLayout> 

三、卡片數(shù)據(jù)庫及卡片數(shù)據(jù)服務的創(chuàng)建

卡片數(shù)據(jù)庫的創(chuàng)建

本篇Codelab使用對象關系映射數(shù)據(jù)庫來對卡片ID,卡片名字等信息進行存儲。因此,我們需要創(chuàng)建一個數(shù)據(jù)庫(FormDatabase)和一張表(Form)。

其中,對象關系映射 (ORM) 數(shù)據(jù)庫類對應于關系數(shù)據(jù)庫,在本Codelab中即FormDatabase.java,用于存儲“Form”表,版本號為 “1”。

在使用 ORM 數(shù)據(jù)庫之前,需要創(chuàng)建一個繼承自OrmDatabase的數(shù)據(jù)庫類,并使用 @Database 對其進行注釋。示例代碼如下:

  1. @Database
  2.         entities = {Form.class}, 
  3.         version = 1) 
  4. public abstract class FormDatabase extends OrmDatabase { } 

關于OrmDatabase相關開發(fā)信息,開發(fā)者可以自行參考官網(wǎng)資料。

● OrmDatabase

https://developer.harmonyos.com/cn/docs/documentation/docreferences/ormdatabase0000001054838766

此外,我們定義一個對象關系映射 (ORM) 數(shù)據(jù)庫中的實體類Form.java,對應數(shù)據(jù)庫內的表名為“form”,包含了卡片id(formId),卡片名稱(formName) 和卡片規(guī)格(dimension)三個字段。在ORM數(shù)據(jù)庫中操作實體之前,需要創(chuàng)建一個繼承自OrmObject的實體類,并用@Entity注解。示例代碼如下:

  1. @Entity(tableName = "form"
  2. public class Form extends OrmObject { 
  3.     @PrimaryKey() 
  4.     private Long formId; 
  5.     private String formName; 
  6.     private Integer dimension; 
  7.  
  8.     public Form(Long formId, String formName, Integer dimension) { 
  9.         this.formId = formId;//卡片id 
  10.         this.formName = formName;//卡片名稱 
  11.         this.dimension = dimension;//卡片規(guī)格 
  12.     } 
  13.  
  14.     public Form() { } 
  15.  
  16.     public Integer getDimension() { 
  17.         return dimension; 
  18.     } 
  19.  
  20.     public void setDimension(Integer dimension) { 
  21.         this.dimension = dimension; 
  22.     } 
  23.  
  24.     public Long getFormId() { 
  25.         return formId; 
  26.     } 
  27.  
  28.     public void setFormId(Long formId) { 
  29.         this.formId = formId; 
  30.     } 
  31.  
  32.     public String getFormName() { 
  33.         return formName; 
  34.     } 
  35.  
  36.     public void setFormName(String formName) { 
  37.         this.formName = formName; 
  38.     } 

關于OrmObject相關開發(fā)信息,開發(fā)者可以自行參考官網(wǎng)資料。

● OrmObject

https://developer.harmonyos.com/cn/docs/documentation/docreferences/ormobject0000001054120141

卡片數(shù)據(jù)服務的創(chuàng)建

由于我們開發(fā)的時鐘服務卡片需要每隔一秒進行刷新,為了方便處理時鐘卡片刷新的定時任務,我們需要在目錄下右鍵new>Ability>Empty Service Ability,創(chuàng)建了一個名為TimerAbility的Service Ability,作為卡片更新定時器,以每秒一次的頻率更新:

  1. @Override 
  2.     public void onStart(Intent intent) { 
  3.         HiLog.info(LABEL_LOG, "TimerAbility::onStart"); 
  4.         connect = helper.getOrmContext("FormDatabase""FormDatabase.db", FormDatabase.class); 
  5.         startTimer(); 
  6.         super.onStart(intent); 
  7.     } 
  8.     // 卡片更新定時器,每秒更新一次 
  9.     private void startTimer() { 
  10.         Timer timer = new Timer(); 
  11.         timer.schedule( 
  12.                 new TimerTask() { 
  13.                     @Override 
  14.                     public void run() { 
  15.                         updateForms(); 
  16.                     } 
  17.                 }, 
  18.                 0, 
  19.                 SEND_PERIOD); 
  20.     } 

同時,TimerAbility還承擔著卡片更新的功能,我們將在下面詳細介紹。

四、時鐘卡片應用的創(chuàng)建、更新及刪除

在正式進入時鐘FA卡片的創(chuàng)建、更新及刪除的開發(fā)之前,我們先來了解關于卡片開發(fā)的一些基本概念。

服務卡片整體框架主要包含三部分:卡片使用方、卡片管理服務和卡片提供方。

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

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

卡片提供方: 提供卡片顯示內容的HarmonyOS服務/HarmonyOS應用,控制卡片的顯示內容、控件布局以及控件點擊事件。開發(fā)者開發(fā)卡片即為卡片提供方。

說明

卡片使用方和提供方不要求常駐運行,在需要添加/刪除/請求更新卡片時,卡片管理服務會拉起卡片提供方獲取卡片信息。

卡片創(chuàng)建

當卡片使用方請求獲取卡片時,卡片提供方會被拉起并調用onCreateForm回調函數(shù),intent中會帶有卡片ID,卡片名稱和卡片外觀規(guī)格信息,分別通過AbilitySlice.PARAM_FORM_IDENTITY_KEY、AbilitySlice.PARAM_FORM_NAME_KEY和AbilitySlice.PARAM_FORM_DIMENSION_KEY獲取,并根據(jù)卡片的名稱以及外觀規(guī)格獲取對應的xml布局并構造卡片對象,完成卡片信息的創(chuàng)建。

在MainAbility中有如下示例代碼:

  1. @Override  
  2. protected ProviderFormInfo onCreateForm(Intent intent) {  
  3.     if (intent == null) {  
  4.         return new ProviderFormInfo();  
  5.     }  
  6.      // 獲取卡片ID  
  7.     formId = INVALID_FORM_ID;  
  8.     if (intent.hasParameter(AbilitySlice.PARAM_FORM_IDENTITY_KEY)) {  
  9.         formId = intent.getLongParam(AbilitySlice.PARAM_FORM_IDENTITY_KEY, INVALID_FORM_ID);  
  10.     } else {  
  11.         return new ProviderFormInfo();  
  12.     }  
  13.     // 獲取卡片名稱  
  14.     String formName = EMPTY_STRING;  
  15.     if (intent.hasParameter(AbilitySlice.PARAM_FORM_NAME_KEY)) {  
  16.         formName = intent.getStringParam(AbilitySlice.PARAM_FORM_NAME_KEY);  
  17.     }  
  18.     // 獲取卡片規(guī)格  
  19.     int dimension = DEFAULT_DIMENSION_2X2;  
  20.     if (intent.hasParameter(AbilitySlice.PARAM_FORM_DIMENSION_KEY)) {  
  21.         dimension = intent.getIntParam(AbilitySlice.PARAM_FORM_DIMENSION_KEY, DEFAULT_DIMENSION_2X2);  
  22.     }  
  23.     int layoutId = ResourceTable.Layout_form_image_with_info_date_card_2_2;  
  24.     if (dimension == DEFAULT_DIMENSION_2X4) {  
  25.         layoutId = ResourceTable.Layout_form_image_with_info_date_card_2_4;  
  26.     }  
  27.     formInfo = new ProviderFormInfo(layoutId, this);  
  28.     // 存儲卡片信息  
  29.     Form form = new Form(formId, formName, dimension);  
  30.     ComponentProvider componentProvider = ComponentProviderUtils.getComponentProvider(form, this);  
  31.     formInfo.mergeActions(componentProvider);  
  32.     if (connect == null) {  
  33.         connect =  
  34.                 helper.getOrmContext("FormDatabase""FormDatabase.db", FormDatabase.class);  
  35.     }  
  36.     try {  
  37.         DatabaseUtils.insertForm(form, connect);  
  38.     } catch (Exception e) {  
  39.         DatabaseUtils.deleteFormData(form.getFormId(), connect);  
  40.     }  
  41.     return formInfo;  

卡片的更新

服務卡片刷新機制分為兩種,第一種是定時/定點更新,即在config.json中配置了定時/定點更新之后,卡片管理服務會定期拉起服務卡片刷新數(shù)據(jù)。第二種是主動更新,即開發(fā)者根據(jù)需要主動調用updateForm方法更新卡片。在本Codelab中,我們選擇的是第二種方式。

我們在之前創(chuàng)建的TimerAbility.java中調用updateForm方法,從數(shù)據(jù)表Form中獲取卡片信息,更新時分秒:

  1. private void updateForms() {  
  2.     // 從數(shù)據(jù)庫中獲取卡片信息  
  3.     OrmPredicates ormPredicates = new OrmPredicates(Form.class);  
  4.     List<Form> formList = connect.query(ormPredicates);  
  5.     // 更新時分秒  
  6.     if (formList.size() > 0) {  
  7.   for (Form form : formList) {  
  8.        // 遍歷卡片列表更新卡片  
  9.       ComponentProvider componentProvider = ComponentProviderUtils.getComponentProvider(form, this);  
  10.       try {  
  11.     Long updateFormId = form.getFormId();  
  12.     updateForm(updateFormId, componentProvider);  
  13.       } catch (FormException e) {  
  14.         // 刪除不存在的卡片  
  15.         DatabaseUtils.deleteFormData(form.getFormId(), connect);  
  16.         HiLog.error(LABEL_LOG, "onUpdateForm updateForm error");  
  17.       }  
  18.    }  
  19.      }  

同時,組件同步展示時間更新。我們封裝ComponentProviderUtils這個類,在卡片更新時候,通過調用updateForm方法,傳入?yún)?shù)formId和componentProvider,以達到日期、時間和星期實時更新的效果,部分代碼和效果如下:

【Codelab】時鐘服務卡片開發(fā)指南-鴻蒙HarmonyOS技術社區(qū)
  1. public static ComponentProvider getComponentProvider(Form form, Context context) {  
  2.     int layoutId = ResourceTable.Layout_form_image_with_info_date_card_2_2;  
  3.     if (form.getDimension() == DIM_VERSION) {  
  4.   layoutId = ResourceTable.Layout_form_image_with_info_date_card_2_4;  
  5.     }  
  6.     ComponentProvider componentProvider = new ComponentProvider(layoutId, context);  
  7.     setComponentProviderValue(componentProvider);  
  8.     return componentProvider;  
  9. }  
  10. // 為時鐘各個組件賦值  
  11. private static void setComponentProviderValue(ComponentProvider componentProvider) {  
  12.     Calendar now = Calendar.getInstance();  
  13.     int hour = now.get(Calendar.HOUR_OF_DAY);  
  14.     int min = now.get(Calendar.MINUTE);  
  15.     int second = now.get(Calendar.SECOND);  
  16.     String hourString = int2String(hour);  
  17.     String minString = int2String(min);  
  18.     String secondString = int2String(second);  
  19.     componentProvider.setText(ResourceTable.Id_date, DateUtils.getCurrentDate("yyyy-MM-dd"));  
  20.     componentProvider.setText(ResourceTable.Id_hour, hourString);  
  21.     componentProvider.setText(ResourceTable.Id_min, minString);  
  22.     componentProvider.setText(ResourceTable.Id_sec, secondString);  
  23.  
  24.     // 獲取當前星期  
  25.     int weekDayId = getWeekDayId();  
  26.     componentProvider.setTextColor(weekDayId, nowWeekColor);  
  27.     // 將前一天的星期改回原色  
  28.     int lastWeekId = getLastWeekDayId();  
  29.     componentProvider.setTextColor(lastWeekId, primaryWeekColor);  

卡片刪除

當卡片被刪除時,需要重寫onDeleteForm方法,我們將在MainAbility中根據(jù)卡片id刪除卡片實例數(shù)據(jù):

  1. @Override  
  2. protected void onDeleteForm(long formId) {  
  3.     super.onDeleteForm(formId);  
  4.     // 刪除數(shù)據(jù)庫中的卡片信息  
  5.     DatabaseUtils.deleteFormData(formId, connect); 

至此,我們完成了時鐘卡片應用的開發(fā),構建了一個2×2和2×4的卡片樣式。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區(qū)

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區(qū)
相關推薦

2021-06-24 14:41:16

鴻蒙HarmonyOS應用

2021-02-24 15:22:47

鴻蒙HarmonyOS應用開發(fā)

2021-03-01 09:48:24

鴻蒙HarmonyOS應用開發(fā)

2022-08-02 08:01:09

開發(fā)插件Chrome前端技術

2011-07-25 16:21:22

Sencha touc

2021-01-13 09:40:31

鴻蒙HarmonyOS開發(fā)

2021-02-04 13:06:38

鴻蒙HarmonyOS應用開發(fā)

2021-04-16 09:28:18

鴻蒙HarmonyOS應用

2021-08-23 10:12:41

鴻蒙HarmonyOS應用

2009-06-24 16:30:21

JSF組件模型

2011-06-09 18:24:36

QT Wince

2012-03-26 09:27:40

谷歌安卓開發(fā)谷歌安卓

2023-05-15 18:44:07

前端開發(fā)

2021-06-28 14:48:03

鴻蒙HarmonyOS應用

2021-01-18 09:52:20

鴻蒙HarmonyOS開發(fā)

2021-02-04 09:45:19

鴻蒙HarmonyOS應用開發(fā)

2021-02-26 14:15:27

鴻蒙HarmonyOS應用開發(fā)

2021-01-12 12:04:40

鴻蒙HarmonyOS應用開發(fā)

2021-01-21 13:21:18

鴻蒙HarmonyOSPhotoview組件

2021-01-20 09:54:56

鴻蒙HarmonyOS開發(fā)
點贊
收藏

51CTO技術棧公眾號