偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)

開發(fā) 前端 OpenHarmony
服務(wù)卡片的征文活動也已經(jīng)接近尾聲,在這段時間里,論壇里有許多優(yōu)秀的服務(wù)卡片作品和相關(guān)的文章涌現(xiàn)。我拜讀了專欄中幾乎所有的服務(wù)卡片的開發(fā)分享文章,從每一篇文章中提取并汲取精華,整合到本文中。

[[418958]]

想了解更多內(nèi)容,請訪問:

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

https://harmonyos.51cto.com

前言

服務(wù)卡片的征文活動也已經(jīng)接近尾聲,在這段時間里,論壇里有許多優(yōu)秀的服務(wù)卡片作品和相關(guān)的文章涌現(xiàn)。我拜讀了專欄中幾乎所有的服務(wù)卡片的開發(fā)分享文章,從每一篇文章中提取并汲取精華,整合到本文中。一些較為顯然的介紹性的內(nèi)容在本文中將會被省略(如卡片有多少種尺寸之類),但是一些即使在很多文章都已經(jīng)說明過的,而我又認(rèn)為比較重要的內(nèi)容,我仍然會再次記錄下來(例如卡片的框架)。另外,作為學(xué)習(xí)筆記,我會記錄下一些我在學(xué)習(xí)種遇到的新的名詞的概念,這些概念可能是大家已經(jīng)熟知的,這部分大家可以直接忽略;文章的內(nèi)容整合自論壇種的眾多文章,所以大家可能會在本文中看到自己文章的影子。

服務(wù)卡片的框架

服務(wù)卡片整體框架主要包含三部分:卡片使用方、卡片管理服務(wù)和卡片提供方。其概念分別如下:

● 卡片使用方:顯示卡片內(nèi)容的宿主應(yīng)用,控制卡片在宿主中展示的位置,如桌面、服務(wù)中心、搜索等。

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

● 卡片提供方:提供卡片顯示內(nèi)容的HarmonyOS應(yīng)用或原子化服務(wù),控制卡片的顯示內(nèi)容、控件布局以及控件點擊事件。

卡片的運行框架有如下示意圖:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

簡明版示意圖

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

詳細(xì)版示意圖

卡片的常用功能

Java卡片與JS卡片功能的對比圖

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

MainAbility的自動生成函數(shù)解析

在新建服務(wù)卡片的時候,在MainAbility類中將會生成一些回調(diào)方法,具體方法及其回調(diào)條件如下圖,在后面的具體的卡片操作中,也會再次聲明所調(diào)用的回調(diào)方法。

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

在onCreatForm(Intent)方法中,卡片提供方被拉起后intent會攜帶卡片相關(guān)信息,具體如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

服務(wù)卡片生命周期回調(diào)函數(shù)時序如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

配置卡片編輯功能

有些服務(wù)卡片需要具備可編輯能力,如天氣App需要編輯所在城市。具體實現(xiàn)方法如下:在config.json中,對某一個form的配置增加formConfigAbility的屬性配置,可實現(xiàn)編輯功能。formConfigAbility的值是一個url格式的Ability名稱。若不配置formConfigAbility,則不顯示編輯菜單。示例代碼如下:(摘抄自[一文看懂HarmonyOS服務(wù)卡片運行原理和開發(fā)方法])(https://harmonyos.oss-cn-beijing.aliyuncs.com/images/202106/830a107135e5fa06fa1714ebaa9fa523833da2.jpg?x-oss-process=image/resize,w_1080,h_478)

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

卡片的定點/定時刷新:將回調(diào)updateForm()方法

運作機制示意圖如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

注意:定時刷新和定點刷新都配置的情況下,定時刷新優(yōu)先。

JS卡片的定點更新步驟:

1.關(guān)閉定時更新:updateDuration”修改為0,以關(guān)閉定時刷新(config.json文件中)

2.設(shè)定“scheduledUpdateTime”的時刻

3.在具體的xxxxlmpl中重寫updateFormData()方法

4.把需要刷新的數(shù)據(jù)存入一個ZSONObject實例中

5.將這個實例封裝在一個FormBindingData的實例bindingData中

6.調(diào)用MainAbility的方法updateForm(),并將bindingData作為第二個實參。

JS卡片重寫updateFormData()方法的代碼如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

JAVA卡片的定點更新步驟:

1.前三步與JS卡片相同

2.構(gòu)造一個ComponentProvider的實例,用于表示一個Java卡片實例,傳入的第一個實參是根據(jù)卡片尺寸得到的布局文件。然后,調(diào)用方法setText()修改卡片的標(biāo)題;最后,調(diào)用MainAbility的方法updateForm(),并將componentProvider作為第二個實參。

JAVA卡片重寫updateFormData()方法的代碼如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

卡片的定時刷新

卡片的定時刷新的最小單位時間是三十分鐘,這就帶來了兩個問題:

1.創(chuàng)建卡片后的最初的三十分鐘是不會進(jìn)行卡片刷新的,所以需要進(jìn)行手動的刷新。

2.如果是編寫刷新間隔小于三十分的卡片(如時鐘卡片每一秒刷新一次),那么需要自己重新創(chuàng)建一個timer實例來設(shè)定刷新時間。

添加手動刷新:用onCreateForm()調(diào)用onUpdateForm(formId)即可,代碼摘抄自亮子力的嗶哩嗶哩卡片

  1. @Override 
  2. protected ProviderFormInfo onCreateForm(Intent intent) { 
  3.     ... ... 
  4.  
  5.     //初始化時先在線更新一下卡片 
  6.     onUpdateForm(formId); 
  7.  
  8.     return formController.bindFormData(); 

 重新編寫刷新時間的代碼為代碼摘抄自Codelabs 之 時鐘FA卡片開發(fā)樣例

  1. private void startTimer() { 
  2.         Timer timer = new Timer(); 
  3.         timer.schedule( 
  4.                 new TimerTask() { 
  5.                     @Override 
  6.                     public void run() { 
  7.                         updateForms(); 
  8.                     } 
  9.                 }, 
  10.                 0, 
  11.                 SEND_PERIOD); 
  12.     } 
  1. private void updateForms() { 
  2.         // 從數(shù)據(jù)庫中獲取卡片信息 
  3.         HiLog.info(LABEL, "從數(shù)據(jù)庫中獲取卡片"); 
  4.         OrmPredicates ormPredicates = new OrmPredicates(Form.class); 
  5.         List<Form> formList = connect.query(ormPredicates); 
  6.         int layoutId=0; 
  7.         // 更新時分秒 
  8.         if (formList.size() <= 0) { 
  9.             return
  10.         } 
  11.         HiLog.info(LABEL, "遍歷卡片列表,逐個更新"); 
  12.         for (Form form : formList) { 
  13.             // 遍歷卡片列表更新卡片 
  14.             ComponentProvider componentProvider = ComponentProviderUtils.getComponentProvider(form, this); 
  15.             try { 
  16.                 Long updateFormId = form.getFormId(); 
  17.                 HiLog.info(LABEL, "updateForm,更新卡片[:"+updateFormId+"] 的數(shù)據(jù),并非數(shù)據(jù)庫操作" ); 
  18.                 //更新卡片數(shù)據(jù) 
  19.                 boolean isSucc=updateForm(updateFormId, componentProvider); 
  20.                 HiLog.info(LABEL, "更新卡片數(shù)據(jù)完成,"+isSucc); 
  21.             } catch (FormException e) { 
  22.                 // 刪除不存在的卡片 
  23.                 DatabaseUtils.deleteFormData(form.getFormId(), connect); 
  24.                 HiLog.error(LABEL, "更新卡片異常,刪除數(shù)據(jù)庫中不存在的卡片"); 
  25.             } 
  26.         } 
  27.     }

JAVA與JS卡片定點定時更新的對比總結(jié)

由上可見,兩者的大體思路是相同的:即先在config.json文件中修改配置,然后對具體的xxxxlmpl中的updateFormData()進(jìn)行重寫。不同的是,JS卡片式通過創(chuàng)建一個ZSONOject實例,然后封裝在FormBindingData的實例中的辦法更新數(shù)據(jù);而JAVA卡片則是通過創(chuàng)建ComponentProvider的實例,通過它來更新數(shù)據(jù)。因而,在調(diào)用MainAbility的方法updateForm()的時候,JS卡片的第二個實參是bingding Data,而JAVA卡片是componentProvider。

卡片的跳轉(zhuǎn)事件:

運作機制示意圖如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

JS卡片的跳轉(zhuǎn)事件步驟

1.在對應(yīng)卡片的index.json文件中添加跳轉(zhuǎn)配置

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

相關(guān)參數(shù)意義具體如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

2.在index.hml中,在標(biāo)簽image中添加一個屬性onclick,并將值設(shè)置為剛剛在index.json中定義的action的名稱“startSecondAbility”

3.根據(jù)key的值“params”獲得一個字符串格式的JSON數(shù)據(jù);然后,調(diào)用ZSONObject.stringToZSON()將其轉(zhuǎn)換為一個ZSONObject的實例data;最后,從data中分別獲得”param1”和”param2”這兩個key對應(yīng)的value。

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

JAVA卡片的跳轉(zhuǎn)事件步驟

1.打開MainWidget3Impl,在方法bindFormData()中,當(dāng)卡片尺寸為2*4時,調(diào)用componentProvider的方法setIntentAgent(),傳入的第一個實參是標(biāo)題在布局文件中的id,第二個實參是用于頁面跳轉(zhuǎn)的IntentAgent實例。代碼如下所示:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

2.定義方法getStartAbilityIntentAgent()的具體實現(xiàn),代碼如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

總結(jié)

Java卡片要通過IntentAgent來設(shè)置事件,相比之下JS似乎顯得要方便一些。

卡片的消息事件

JS卡片的消息事件步驟

1.在對應(yīng)卡片的index.json文件中添加信息事件配置

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

相關(guān)參數(shù)意義具體如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

2.重寫方法onTriggerFormEvent(),代碼如下:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

message是一個字符串格式的JSON數(shù)據(jù);然后,調(diào)用ZSONObject.stringToZSON()將message轉(zhuǎn)換為一個ZSONObject的實例data;最后,從data中分別獲得”p1”和”p2”這兩個key對應(yīng)的value。

服務(wù)卡片常用到的數(shù)據(jù)庫

數(shù)據(jù)持久化

概念:數(shù)據(jù)持久化就是將內(nèi)存中的數(shù)據(jù)模型轉(zhuǎn)換為存儲模型,以及將存儲模型轉(zhuǎn)換為內(nèi)存中的數(shù)據(jù)模型的統(tǒng)稱

好處:

1、程序代碼重用性強,即使更換數(shù)據(jù)庫,只需要更改配置文件,不必重寫程序代碼。

2、業(yè)務(wù)邏輯代碼可讀性強,在代碼中不會有大量的SQL語言,提高程序的可讀性。

3、持久化技術(shù)可以自動優(yōu)化,以減少對數(shù)據(jù)庫的訪問量,提高程序運行效率。

數(shù)據(jù)持久化對象的基本操作有:保存、更新、刪除、查詢等。

輕量級偏好數(shù)據(jù)庫

輕量級數(shù)據(jù)庫官方文檔鏈接

輕量級偏好數(shù)據(jù)庫在服務(wù)卡片開發(fā)中的使用場景

根據(jù)輕量級偏好數(shù)據(jù)庫的特點,在服務(wù)卡片的開發(fā)中,涉及到保存網(wǎng)絡(luò)上的內(nèi)容時,可以使用輕量級偏好數(shù)據(jù)庫來存儲cookie信息。

輕量級偏好數(shù)據(jù)庫的創(chuàng)建(獲取preference實例)

  1. context = getContext(); 
  2. databaseHelper = new DatabaseHelper(context); 
  3. filename = "preference_db";//文件名,不能為空,也不能包含路徑 
  4. preferences = databaseHelper.getPreferences(filename); 

輕量級偏好數(shù)據(jù)庫的插入,刪除,修改,查詢

插入與修改:

首先獲取指定文件對應(yīng)的Preferences實例,然后借助Preferences API將數(shù)據(jù)寫入Preferences實例,通過flush或者flushSync將Preferences實例持久化。其中flush為異步地寫入,flushSync為同步寫入。flush()會立即更改內(nèi)存中的Preferences對象,但會將更新異步寫入磁盤。flushSync()更改內(nèi)存中的數(shù)據(jù)的同時會將數(shù)據(jù)同步寫入磁盤。由于flushSync()是同步的,建議不要從主線程調(diào)用它,以避免界面卡頓。

異步寫入代碼:

  1. preferences.putInt("number",number); 
  2. preferences.putString("fruit","apple"); 
  3. preferences.flush(); 

同步寫入的代碼:

  1. preferences.putInt("intKey", 3); 
  2. preferences.putString("StringKey""String value"); 
  3. bool result = preferences.flushSync(); 

查詢:

  1. int value = preferences.getInt("intKey", 0); 

刪除:

1.刪除preferen單實例

  1. DatabaseHelper databaseHelper = new DatabaseHelper(context); 
  2. String fileName = "name"; // fileName表示文件名,其取值不能為空,也不能包含路徑。 
  3. databaseHelper.removePreferencesFromCache(fileName); 

2.刪除指定文件

  1. DatabaseHelper databaseHelper = new DatabaseHelper(context); 
  2. String fileName = "name"; // fileName表示文件名,其取值不能為空,也不能包含路徑。 
  3. boolean result = databaseHelper.deletePreferences(fileName); 

注冊觀察者

  1. private class PreferencesObserverImpl implements Preferences.PreferencesObserver { 
  2.     
  3.     @Override     
  4.     public void onChange(Preferences preferences, String key) { 
  5.         if ("intKey".equals(key)) { 
  6.            HiLog.info(LABLE, "Change Received:[key=value]");         
  7.         }     
  8.     } 
  9.  
  10. // 向preferences實例注冊觀察者 
  11. PreferencesObserverImpl observer = new PreferencesObserverImpl(); 
  12. preferences.registerObserver(observer); 
  13. // 修改數(shù)據(jù) 
  14. preferences.putInt("intKey", 3); 
  15. preferences.flush(); 
  16. // 修改數(shù)據(jù)后,observer的onChange方法會被回調(diào) 
  17. // 向preferences實例注銷觀察者 
  18. preferences.unRegisterObserver(observer); 

輕量級數(shù)據(jù)庫在服務(wù)卡片中的使用例子:(摘抄自亮子力的嗶哩嗶哩卡片

  1. /** 
  2.    * Map[保存]到偏好型數(shù)據(jù)庫 
  3.    * @param preferences  數(shù)據(jù)庫的Preferences實例 
  4.    * @param map  要保存的map 
  5.    */ 
  6.   public static void SaveMap(Preferences preferences,Map<String,String> map){ 
  7.       // 遍歷map 
  8.       for (Map.Entry<String, String> entry : map.entrySet()) { 
  9.           HiLog.info(TAG,entry.getKey() + "=" + entry.getValue()); 
  10.           preferences.putString(entry.getKey(),entry.getValue());//3.將數(shù)據(jù)寫入Preferences實例, 
  11.       } 
  12.       preferences.flushSync();//4.通過flush()或者flushSync()將Preferences實例持久化。 
  13.   } 
  14.  
  15.   /** 
  16.    *  從偏好型數(shù)據(jù)庫[讀取]Map 
  17.    * @param preferences  數(shù)據(jù)庫的Preferences實例 
  18.    * @return  要讀取的map 
  19.    */ 
  20.   public static Map<String,?> GetCookieMap(Preferences preferences){ 
  21.       Map<String, ?> map = new HashMap<>(); 
  22.       map = preferences.getAll();//3.讀取數(shù)據(jù) 
  23.       return map; 
  24.   } 

對象關(guān)系映射數(shù)據(jù)庫

對象關(guān)系映射數(shù)據(jù)庫官方文檔

對象關(guān)系數(shù)據(jù)庫在服務(wù)卡片中的應(yīng)用

對象關(guān)系數(shù)據(jù)庫在服務(wù)卡片中主要用作存儲卡片的信息,如卡片id,卡片名字,卡片大小等。

對象關(guān)系數(shù)據(jù)庫的創(chuàng)建

1.配置“build.gradle”文件,這里僅展示使用注解處理器的模塊為“com.huawei.ohos.hap”模塊,則需要在模塊的“build.gradle”文件的ohos節(jié)點中添加以下配置:

  1. compileOptions{         
  2.     annotationEnabled true     
  3. }  

2.構(gòu)造對象關(guān)系映射數(shù)據(jù)庫:創(chuàng)建數(shù)據(jù)庫類并配置對應(yīng)的屬性

  1. //數(shù)據(jù)庫有三個表,User,Book, AllDataType三個表,版本號為1 
  2. @Database(entities = {User.class, Book.class, AllDataType.class}, version = 1)  
  3. public abstract class BookStore extends OrmDatabase {  

3.構(gòu)造數(shù)據(jù)表,即創(chuàng)建數(shù)據(jù)庫實體類并配置對應(yīng)的屬性(如對應(yīng)表的主鍵,外鍵等)。數(shù)據(jù)表必須與其所在的數(shù)據(jù)庫在同一個模塊中。

  1. @Entity(tableName = "user", ignoredColumns = {"ignoredColumn1""ignoredColumn2"}, 
  2.     indices = {@Index(value = {"firstName""lastName"}, name = "name_index"unique = true)})  
  3. public class User extends OrmObject {  
  4.     // 此處將userId設(shè)為了自增的主鍵。注意只有在數(shù)據(jù)類型為包裝類型時,自增主鍵才能生效。 
  5.     @PrimaryKey(autoGenerate = true)  
  6.     private Integer userId;    
  7.     private String firstName;    
  8.     private String lastName;    
  9.     private int age;    
  10.     private double balance;    
  11.     private int ignoredColumn1;  
  12.     private int ignoredColumn2;  
  13.   
  14.     // 需添加各字段的getter和setter方法。  

4.使用對象數(shù)據(jù)操作接口OrmContext創(chuàng)建數(shù)據(jù)庫。

  1. // context入?yún)㈩愋蜑閛hos.app.Context,注意不要使用slice.getContext()來獲取context,請直接傳入slice,否則會出現(xiàn)找不到類的報錯。 
  2. DatabaseHelper helper = new DatabaseHelper(this);  
  3.  
  4. OrmContext context = helper.getOrmContext("BookStore""BookStore.db", BookStore.class);  

5.對象關(guān)系映射數(shù)據(jù)庫的增刪改查

查詢數(shù)據(jù):

  1. OrmPredicates query = context.where(User.class).equalTo("lastName""San");  
  2. List<User> users = context.query(query); 

更新數(shù)據(jù):更新數(shù)據(jù)有兩種方法,這里僅貼出其中一種

  1. // 更新數(shù)據(jù) 
  2. OrmPredicates predicates = context.where(User.class); 
  3. predicates.equalTo("age", 29); 
  4. List<User> users = context.query(predicates); 
  5. User user = users.get(0); 
  6. user.setFirstName("Li"); 
  7. context.update(user); 
  8. context.flush(); 

刪除數(shù)據(jù):刪除數(shù)據(jù)也有兩種方法,這里也僅貼出其中一種,另一種方法可以到官方文檔查看

  1. // 刪除數(shù)據(jù) 
  2. OrmPredicates predicates = context.where(User.class); 
  3. predicates.equalTo("age", 29); 
  4. List<User> users = context.query(predicates); 
  5. User user = users.get(0); 
  6. context.delete(user); 
  7. context.flush(); 

6.注冊觀察者

  1. // 定義一個觀察者類。 
  2. private class CustomedOrmObjectObserver implements OrmObjectObserver { 
  3.     @Override     
  4.     public void onChange(OrmContext changeContext, AllChangeToTarget subAllChange) { 
  5.         // 用戶可以在此處定義觀察者行為 
  6.     } 
  7.  
  8. // 調(diào)用registerEntityObserver方法注冊一個觀察者observer。 
  9. CustomedOrmObjectObserver observer = new CustomedOrmObjectObserver(); 
  10. context.registerEntityObserver("user", observer); 
  11.  
  12. // 當(dāng)以下方法被調(diào)用,并flush成功時,觀察者observer的onChange方法會被觸發(fā)。其中,方法的入?yún)⒈仨殲?span id="5gk0f71da" class="func">User類的對象。 
  13. public <T extends OrmObject> boolean insert(T object) 
  14. public <T extends OrmObject> boolean update(T object) 
  15. public <T extends OrmObject> boolean delete(T object) 

對象關(guān)系映射數(shù)據(jù)庫在服務(wù)卡片中的應(yīng)用實例

  1. @Entity(tableName = "form"
  2. public class Form extends OrmObject { 
  3.     @PrimaryKey() 
  4.     // 卡片id 
  5.     private Long formId; 
  6.  
  7.     // 卡片名稱 
  8.     private String formName; 
  9.  
  10.     // 卡片名稱 
  11.     private int dimension; 
  12.  
  13.     /** 
  14.      * 有參構(gòu)造 
  15.      * 
  16.      * @param formId 卡片id 
  17.      * @param formName 卡片名 
  18.      * @param dimension 卡片規(guī)格 
  19.      */ 
  20.     public Form(Long formId, String formName, int dimension) { 
  21.         this.formId = formId; 
  22.         this.formName = formName; 
  23.         this.dimension = dimension; 
  24.     } 
  1. protected ProviderFormInfo onCreateForm(Intent intent) { 
  2.         HiLog.info(TAG, "onCreateForm"); 
  3.         long formId = intent.getLongParam(AbilitySlice.PARAM_FORM_IDENTITY_KEY, INVALID_FORM_ID); 
  4.         String formName = intent.getStringParam(AbilitySlice.PARAM_FORM_NAME_KEY); 
  5.         int dimension = intent.getIntParam(AbilitySlice.PARAM_FORM_DIMENSION_KEY, DEFAULT_DIMENSION_2X2); 
  6.         HiLog.info(TAG, "onCreateForm: formId=" + formId + ",formName=" + formName); 
  7.         FormControllerManager formControllerManager = FormControllerManager.getInstance(this); 
  8.         FormController formController = formControllerManager.getController(formId); 
  9.         formController = (formController == null) ? formControllerManager.createFormController(formId, 
  10.                 formName, dimension) : formController; 
  11.         if (formController == null) { 
  12.             HiLog.error(TAG, "Get null controller. formId: " + formId + ", formName: " + formName); 
  13.             return null
  14.         } 
  15.  
  16.         //初始化時先在線更新一下卡片 
  17.         onUpdateForm(formId); 
  18.  
  19.         // TODO 獲取添加到桌面的服務(wù)卡片ID 
  20.  
  21.         // 存儲卡片信息。對象關(guān)系映射數(shù)據(jù)庫2.通過對象數(shù)據(jù)操作接口OrmContext,創(chuàng)建一個別名為“FormDatabase”,數(shù)據(jù)庫文件名為“FormDatabase.db”的數(shù)據(jù)庫 
  22.         ormContext = databaseHelper.getOrmContext("FormDatabase""FormDatabase.db", MyOrmDatabase.class); 
  23.         // 對象關(guān)系映射數(shù)據(jù)庫3.實例化數(shù)據(jù)表 
  24.         HiLog.info(TAG, "存儲卡片信息: formId=" + formId + ",formName=" + formName + ",dimension=" + dimension); 
  25.         Form form = new Form(formId, formName, dimension); 
  26.         // 對象關(guān)系映射數(shù)據(jù)庫4.添加方法 
  27.         ormContext.insert(form); 
  28.         ormContext.flush(); 
  29.  
  30.  
  31.         return formController.bindFormData(); 
  32.     } 

網(wǎng)絡(luò)編程的相關(guān)知識

這部分在我平時的學(xué)習(xí)未曾接觸過,在大家眼中很平常的概念,在我這里都是全新的知識,所以會有較多的概念記錄。

WebView組件的使用

WebView組件官方文檔

WebView提供在應(yīng)用中集成Web頁面的能力。

服務(wù)卡片的開發(fā)中一般只需要加載Web頁面,則常用操作如下:

1.配置應(yīng)用的網(wǎng)絡(luò)權(quán)限(如未配置網(wǎng)絡(luò)權(quán)限的話)

  1.   ... 
  2.   "module": { 
  3.     ... 
  4.     "reqPermissions": [ 
  5.       { 
  6.         "name""ohos.permission.INTERNET" 
  7.       } 
  8.     ], 
  9.     ... 
  10.   } 

2.使用load方法加載Web頁面

這里僅貼出使用xml方式布局的代碼,使用代碼方式布局可參看官方文檔

  1. WebView webView = (WebView) findComponentById(ResourceTable.Id_webview); 
  2. webView.getWebConfig().setJavaScriptPermit(true);  // 如果網(wǎng)頁需要使用JavaScript,增加此行;如何使用JavaScript下文有詳細(xì)介紹   
  3. final String url = EXAMPLE_URL; // EXAMPLE_URL由開發(fā)者自定義 
  4. webView.load(url); 

什么是JSON文件

JSON的全稱為JavaScript Object Notation,是輕量級的文本數(shù)據(jù)交換格式,JSON實際上是JavaScript的一個子集。重要的是,許多API請求返回值都是josn格式的結(jié)果。

JSON生成Java實體類

網(wǎng)上有很多相關(guān)的工具,如何自己編寫我暫且還未學(xué)會,就決定先應(yīng)用現(xiàn)有的工具了

什么是Cookie

由于HTTP是一種無狀態(tài)協(xié)議,服務(wù)器沒有辦法單單從網(wǎng)絡(luò)連接上面知道訪問者的身份,因此就使用Cookie作為辨識訪問者的一種標(biāo)志。

Cookie是一段不超過4KB的小型文本數(shù)據(jù),由一個名稱(Name)、一個值(Value)和其它幾個用于控制Cookie有效期、安全性、使用范圍的可選屬性組成。

運作機制如下圖:

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

客戶端請求服務(wù)器,如果服務(wù)器需要記錄該用戶狀態(tài),就使用response向客戶端瀏覽器頒發(fā)一個Cookie,客戶端瀏覽器會把Cookie保存起來。當(dāng)瀏覽器再請求該網(wǎng)站時,瀏覽器把請求的網(wǎng)址連同該Cookie一同提交給服務(wù)器。服務(wù)器檢查該Cookie,

以此來辨認(rèn)用戶狀態(tài)。服務(wù)器還可以根據(jù)需要修改Cookie的內(nèi)容。

實際就是頒發(fā)一個通行證,每人一個,無論誰訪問都必須攜帶自己通行證。這樣服務(wù)器就能從通行證上確認(rèn)客戶身份了。這就是Cookie的工作原理。

cookie 可以讓服務(wù)端程序跟蹤每個客戶端的訪問,但是每次客戶端的訪問都必須傳回這些Cookie,如果 Cookie 很多,這無形地增加了客戶端與服務(wù)端的數(shù)據(jù)傳輸量。

Cookie相關(guān)方法

CookieStore官方文檔

學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)
學(xué)習(xí)筆記——HarmonyOS服務(wù)卡片開發(fā)知識總結(jié)-鴻蒙HarmonyOS技術(shù)社區(qū)

卡片開發(fā)的基本步驟總結(jié)

1.選擇已有的卡片模板,或者自行繪制卡片樣式

2.對卡片進(jìn)行初始化的設(shè)置

3.建立數(shù)據(jù)庫(對象關(guān)系映射數(shù)據(jù)庫存儲卡片信息,涉及網(wǎng)絡(luò)的可以用輕量級數(shù)據(jù)庫存儲cookie

4.給卡片上面的組件添加響應(yīng)的事件

5.實現(xiàn)卡片的功能

想了解更多內(nèi)容,請訪問:

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

https://harmonyos.51cto.com

 

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

2021-06-21 15:21:52

鴻蒙HarmonyOS應(yīng)用開發(fā)

2021-07-28 14:59:08

鴻蒙HarmonyOS應(yīng)用

2023-08-04 17:24:43

2021-09-18 09:57:20

鴻蒙HarmonyOS應(yīng)用

2021-08-18 10:06:33

鴻蒙HarmonyOS應(yīng)用

2021-06-30 09:27:58

鴻蒙HarmonyOS應(yīng)用

2022-04-24 15:26:38

服務(wù)卡鴻蒙

2021-09-15 10:19:15

鴻蒙HarmonyOS應(yīng)用

2009-01-11 09:14:45

Javascript開發(fā)總結(jié)

2011-08-15 10:35:43

iPhone開發(fā)Atomicnonatomic

2011-08-15 10:45:11

iPhone開發(fā)delegate

2021-07-22 08:45:47

鴻蒙HarmonyOS應(yīng)用

2010-03-18 14:24:31

云計算

2021-06-23 16:05:05

鴻蒙HarmonyOS應(yīng)用

2023-09-13 15:27:14

鴻蒙應(yīng)用元服務(wù)

2013-01-06 09:52:43

SQLite

2013-04-09 16:04:06

iOS開發(fā)SQLite知識總結(jié)

2023-04-07 09:20:55

2021-08-20 14:23:14

鴻蒙HarmonyOS應(yīng)用

2022-05-09 11:52:38

Java卡片服務(wù)卡片
點贊
收藏

51CTO技術(shù)棧公眾號