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

HarmonyOS PageSlider組件使用(二)Provider介紹

開發(fā) 前端 OpenHarmony
PageSliderProvider類提供頁面項管理功能,例如計算可用視圖的數(shù)量和在指定位置創(chuàng)建組件。您需要繼承并實現(xiàn)PageSliderProvider,以便在不同的頁面上顯示多個視圖。

[[422095]]

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

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

https://harmonyos.51cto.com

一、簡要概述

PageSliderProvider是為PageSlider組件提供用于管理頁面視圖的頁面適配器。

PageSliderProvider類提供頁面項管理功能,例如計算可用視圖的數(shù)量和在指定位置創(chuàng)建組件。您需要繼承并實現(xiàn)PageSliderProvider,以便在不同的頁面上顯示多個視圖。

PageSliderProvider類的使用比較簡單,但在復(fù)雜業(yè)務(wù)場景下使用時,需要做的工作比較多,而且這些工作都有重復(fù)性。所以在編寫本章節(jié)案例的同時,我對PageSliderProvider進行了一下通用封裝,并且把代碼共享到了碼云Gitee上,同時將封裝的代碼打包成har包,提交到了Maven中央倉庫,供大家使用。

碼云Gitee倉庫地址

二、方法介紹

需要掌握的PageSliderProvider類方法不多,一般只需要重寫下面四個方法即可為PageSlider提供Page數(shù)據(jù)支持。

PageSliderProvider類還提供了Page頁面數(shù)據(jù)刷新需要用到的方法,這部分方法可以相互配合,達(dá)到精準(zhǔn)更新Page頁面數(shù)據(jù)。

三、封裝解析

PageSliderProvider是一個abstract抽象類,每次使用此類的時候都需要繼承它,并重寫相應(yīng)的抽象方法。這種重復(fù)的工作,寫多了,既繁瑣,又浪費時間,降低開發(fā)效率。所以秉著高效易用的目的,先對PageSliderProvider進行一定封裝。

數(shù)據(jù)源的封裝。在常規(guī)業(yè)務(wù)開發(fā)模式中,為PageSliderProvider提供頁面元數(shù)據(jù)是最基礎(chǔ)的工作,一般都是將一個復(fù)雜的Object對象實例集合加入到一個List列表中??紤]數(shù)據(jù)的通用性,這里我們也將采用泛型來封裝PageSliderProvider類。

  1. public abstract class BasePageSliderProvider<M> extends PageSliderProvider { 
  2.  
  3.     //頁面加載數(shù)據(jù)源 
  4.     private final List<M> mPageSliderSourceData; 
  5.  
  6.     //構(gòu)造函數(shù)初始化列表集合 
  7.     public BasePageSliderProvider() { 
  8.         this.mPageSliderSourceData = new ArrayList<>(); 
  9.     } 
  10.      
  11.     /** 
  12.      * 對外提供清除數(shù)據(jù)源的操作方法, 
  13.      * 
  14.      * 后續(xù)需要根據(jù)業(yè)務(wù)自行判斷是否需要調(diào)用notifyDataChanged()方法 
  15.      */ 
  16.     public final void clearSourceData() { 
  17.         mPageSliderSourceData.clear(); 
  18.     } 
  19.  
  20.     /** 
  21.      * 對外提供設(shè)置/重置數(shù)據(jù)源的操作方法, 
  22.      * 
  23.      * 后續(xù)需要根據(jù)業(yè)務(wù)自行判斷是否需要調(diào)用notifyDataChanged()方法 
  24.      * @param data 
  25.      */ 
  26.     public final void setSourceData(List<M> data) { 
  27.         if (!data.isEmpty()) { 
  28.             mPageSliderSourceData.clear(); 
  29.             mPageSliderSourceData.addAll(data); 
  30.         } 
  31.     } 
  32.  
  33.     /** 
  34.      * 對外追加數(shù)據(jù)源的操作方法,可能在加載更多數(shù)據(jù)的時候有用。 
  35.      * 
  36.      * 后續(xù)需要根據(jù)業(yè)務(wù)自行判斷是否需要調(diào)用notifyDataChanged()方法 
  37.      * @param data 
  38.      */ 
  39.     public final void appendSourceData(List<M> data) { 
  40.         if (!data.isEmpty()) { 
  41.             mPageSliderSourceData.addAll(data); 
  42.         } 
  43.     } 
  44.  
  45.     /** 
  46.      * 對外提供刪除指定數(shù)據(jù)源的操作方法, 
  47.      * 
  48.      * 后續(xù)需要根據(jù)業(yè)務(wù)自行判斷是否需要調(diào)用notifyDataChanged()方法 
  49.      * @param data 
  50.      */ 
  51.     public final void removeSourceData(M data) { 
  52.         if (data != null) { 
  53.             mPageSliderSourceData.remove(data); 
  54.         } 
  55.     } 
  56.  
  57.     /** 
  58.      * 對外提供獲取指定位置數(shù)據(jù)的操作方法 
  59.      * @param position 
  60.      * @return 
  61.      */ 
  62.     public final M getItem(int position) { 
  63.         return mPageSliderSourceData.get(position); 
  64.     } 
  65.  
  66.     /** 
  67.      * 并使用final修飾,防止子類繼承重寫,導(dǎo)致出現(xiàn)問題。 
  68.      * @return 
  69.      */ 
  70.     @Override 
  71.     public final int getCount() { 
  72.         return mPageSliderSourceData.size(); 
  73.     } 
  74.      
  75. }     

在重寫PageSliderProvider類的getCount()抽象方法時,對此方法使用了final關(guān)鍵字修飾,目的是為了防止子類繼承重寫,導(dǎo)致出現(xiàn)問題。

頁面視圖組件的封裝。頁面視圖組件是嵌入式設(shè)備應(yīng)用開發(fā)中最需要關(guān)心的一件事情,嵌入式設(shè)備因內(nèi)存資源是有限的的,而頁面視圖組件占用內(nèi)存資源都還比較大,處理不好,甚至影響應(yīng)用的流暢性和穩(wěn)定性。所以在對頁面視圖組件封裝時,需要考慮視圖組件的快速創(chuàng)建和及時回收,防止內(nèi)存泄露/溢出等問題。

在以往的應(yīng)用開發(fā)經(jīng)驗中,ViewHolder綁定視圖組件是一種非常高效解決視圖組件回收復(fù)再利用的好模式。本次我們也使用這種ViewHolder模式來封裝頁面視圖組件,并在PageSliderProvider類中進行簡單的組件回收和再利用處理。

創(chuàng)建一個PageViewHolder類,用于綁定頁面視圖組件。在PageViewHolder類中進行簡單的視圖組件封裝,業(yè)務(wù)開發(fā)中繼承本類,去實現(xiàn)更多跟復(fù)雜的組件操作。

  1. public abstract class PageViewHolder { 
  2.  
  3.     protected final Component component; 
  4.  
  5.     public PageViewHolder(Component component) { 
  6.         this.component = component; 
  7.     } 
  8.  
  9.     /** 
  10.      * 返回綁定的視圖組件 
  11.      * @return 
  12.      */ 
  13.     public final Component getComponent() { 
  14.         return component; 
  15.     } 

具體的業(yè)務(wù)開發(fā)中,使用的ViewHolder肯定是PageViewHolder的子類,是無法確定具體的實例對象類型的。所以在重寫PageSliderProvider類的時候,我們也需要采用泛型來達(dá)到通用性。

頁面視圖組件的回收和再利用,常規(guī)簡單操作我們都是使用列表或者隊列進行存儲,模擬回收站功能。在創(chuàng)建組件和銷毀組件的方法中進行再利用和回收操作,已達(dá)到可以反復(fù)循環(huán)利用的目的,減少頁面視圖組件的多次創(chuàng)建帶來的性能消耗。

  1. public abstract class BasePageSliderProvider<M, VH extends PageViewHolder> extends PageSliderProvider { 
  2.  
  3.     //頁面PageViewHolder緩存,主要保存當(dāng)前處于活躍狀態(tài)的PageViewHolder對象 
  4.     private final HashMap<Integer, VH> mPageSliderComponentCache; 
  5.  
  6.     //頁面PageViewHolder回收站 
  7.     private final Queue<VH> mPageSliderComponentRecyclers; 
  8.  
  9.      
  10.     public BasePageSliderProvider() { 
  11.         this.mPageSliderComponentCache = new HashMap<>(); 
  12.         this.mPageSliderComponentRecyclers = new LinkedBlockingQueue<>(); 
  13.     } 
  14.  
  15.     /** 
  16.      * 對外提供獲取指定位置PageViewHoder對象的方法 
  17.      * @param position 
  18.      * @return 
  19.      */ 
  20.     public final VH getPageViewHolder(int position) { 
  21.         return mPageSliderComponentCache.get(position); 
  22.     } 
  23.  
  24.     @Override 
  25.     public Object createPageInContainer(ComponentContainer componentContainer, int index) { 
  26.         if (componentContainer == null || index >= getCount()) { 
  27.             return Optional.empty(); 
  28.         } 
  29.  
  30.         //從PageViewHolder回收站中獲取對象,如果沒有,創(chuàng)建新的PageViewHolder實例 
  31.         VH pageViewHolder = mPageSliderComponentRecyclers.poll(); 
  32.         if (pageViewHolder == null) { 
  33.             pageViewHolder = onCreatePageViewHolder(componentContainer, index); 
  34.         } 
  35.  
  36.         onBindPageViewHolder(pageViewHolder, index); 
  37.         componentContainer.addComponent(pageViewHolder.getComponent()); 
  38.         //添加到緩存中 
  39.         mPageSliderComponentCache.put(index, pageViewHolder); 
  40.  
  41.         return pageViewHolder; 
  42.     } 
  43.  
  44.     @Override 
  45.     public void destroyPageFromContainer(ComponentContainer componentContainer, int index, Object object) { 
  46.         if (componentContainer == null || index >= getCount()) { 
  47.             return
  48.         } 
  49.  
  50.         if (object instanceof PageViewHolder) { 
  51.             componentContainer.removeComponent(((PageViewHolder) object).getComponent()); 
  52.             mPageSliderComponentCache.remove(index); 
  53.             //回收已經(jīng)被銷毀的PageViewHolder 
  54.             mPageSliderComponentRecyclers.offer((VH) object); 
  55.         } 
  56.     } 
  57.  
  58.     @Override 
  59.     public boolean isPageMatchToObject(Component component, Object object) { 
  60.         if (object instanceof PageViewHolder) { 
  61.             return component == ((PageViewHolder) object).getComponent(); 
  62.         } 
  63.         return component == object; 
  64.     } 
  65.  
  66.     /** 
  67.      * 創(chuàng)建并返回一個PageViewHolder對象 
  68.      * @param componentContainer 
  69.      * @param position 
  70.      * @return 
  71.      */ 
  72.     protected abstract VH onCreatePageViewHolder(ComponentContainer componentContainer, int position); 
  73.  
  74.     /** 
  75.      * 為指定位置的PageViewHolder對象綁定數(shù)據(jù) 
  76.      * @param holder 
  77.      * @param position 
  78.      */ 
  79.     protected abstract void onBindPageViewHolder(VH holder, int position); 
  80.      

四、應(yīng)用實戰(zhàn)

經(jīng)過一系列的簡單封裝,PageSliderProvider類使用起來就簡單了。我們就不需要再去為頁面數(shù)據(jù)和組件的綁定,重復(fù)的去造輪子。直接從BasePageSliderProvider類繼承,重寫onCreatePageViewHolder和onBindPageViewHolder兩個方法,直接綁定數(shù)據(jù)即可完成PageSlider組件的數(shù)據(jù)和頁面組件的提供。

1.在工程layout目錄下的創(chuàng)建Page頁面布局文件。比如:component_page.xml

  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.  
  7.     <Text 
  8.         ohos:id="$+id:text_component" 
  9.         ohos:height="match_parent" 
  10.         ohos:width="match_parent" 
  11.         ohos:text_size="32fp" 
  12.         ohos:text_font="sans-serif-medium" 
  13.         ohos:text_weight="800" 
  14.         ohos:text_color="#ffffff" 
  15.         ohos:text_alignment="center"/> 
  16.  
  17. </DependentLayout> 

2.繼承PageViewHolder類,綁定Page頁面布局組件。比如:CasePageViewHolder

  1. private static class CasePageViewHolder extends PageViewHolder { 
  2.  
  3.     private Text mTextCom; 
  4.  
  5.     public CasePageViewHolder(Component component) { 
  6.         super(component); 
  7.         mTextCom = (Text) component.findComponentById(ResourceTable.Id_text_component); 
  8.     } 
  9.  
  10.     public void setText(String text) { 
  11.         mTextCom.setText(text); 
  12.     } 
  13.  
  14.     public void setBackground(RgbColor color) { 
  15.         ShapeElement element = new ShapeElement(); 
  16.         element.setShape(ShapeElement.RECTANGLE); 
  17.         element.setRgbColor(color); 
  18.         mTextCom.setBackground(element); 
  19.     } 

3.繼承BasePageSliderProvider類,綁定Page頁面數(shù)據(jù)源和PageViewHolder。

  1. private static class CasePageSliderProvider extends BasePageSliderProvider<PageInfo, CasePageViewHolder> { 
  2.  
  3.     @Override 
  4.     protected CasePageViewHolder onCreatePageViewHolder(ComponentContainer componentContainer, int position) { 
  5.         LayoutScatter layoutScatter = LayoutScatter.getInstance(componentContainer.getContext()); 
  6.         Component component = layoutScatter.parse(ResourceTable.Layout_component_page, componentContainer, false); 
  7.         return new CasePageViewHolder(component); 
  8.     } 
  9.  
  10.     @Override 
  11.     protected void onBindPageViewHolder(CasePageViewHolder holder, int position) { 
  12.         PageInfo pageInfo = getItem(position); 
  13.         holder.setText(pageInfo.getContent()); 
  14.         holder.setBackground(pageInfo.getColor()); 
  15.     } 

4.初始Page頁面元數(shù)據(jù)和PageSlider組件,并將PageSliderProvider對象綁定到PageSlider組件中。

  1. public class MainAbilitySlice extends AbilitySlice { 
  2.  
  3.     private PageSlider mPageSlider; 
  4.     private CasePageSliderProvider mPageSliderProvider; 
  5.  
  6.     @Override 
  7.     public void onStart(Intent intent) { 
  8.         super.onStart(intent); 
  9.         super.setUIContent(ResourceTable.Layout_ability_main); 
  10.         mPageSlider = (PageSlider) findComponentById(ResourceTable.Id_page_slider_component); 
  11.  
  12.         mPageSliderProvider = new CasePageSliderProvider(); 
  13.         mPageSliderProvider.setSourceData(createAndInitPageData()); 
  14.         mPageSlider.setProvider(mPageSliderProvider); 
  15.     } 
  16.  
  17.     //初始化Page頁面元數(shù)據(jù) 
  18.     private List<PageInfo> createAndInitPageData(){ 
  19.         List<PageInfo> initData = new ArrayList<>(); 
  20.         for (int i = 0; i < 15; i++) { 
  21.             PageInfo pageInfo = new PageInfo(); 
  22.             char tempChar = (char) (new Random().nextInt(26) + 65); 
  23.             pageInfo.setContent("Case " + String.valueOf(tempChar)); 
  24.             pageInfo.setColor(new RgbColor( 
  25.                     new Random().nextInt(255), 
  26.                     new Random().nextInt(255), 
  27.                     new Random().nextInt(255))); 
  28.             initData.add(pageInfo); 
  29.         } 
  30.         return initData; 
  31.     } 
  32.     
  33.     private static class PageInfo { 
  34.  
  35.         private String content; 
  36.         private RgbColor color; 
  37.  
  38.         public String getContent() { 
  39.             return content; 
  40.         } 
  41.  
  42.         public void setContent(String content) { 
  43.             this.content = content; 
  44.         } 
  45.  
  46.         public RgbColor getColor() { 
  47.             return color; 
  48.         } 
  49.  
  50.         public void setColor(RgbColor color) { 
  51.             this.color = color; 
  52.         } 
  53.     } 

五、總結(jié)

這里只是簡單的對PageSliderProvider類進行了一下封裝試用,并將代碼提交到了碼云Gitee倉庫,并進行了Maven中央倉庫管理。PageSliderProvider類其實還可以進行更多功能改造,封裝的更加高效易用,如果有意向,可以直接在碼云Gitee倉庫進行代碼共享哦。

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

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

https://harmonyos.51cto.com

 

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

2009-07-21 10:40:36

ASP.NET Pro

2009-11-18 16:51:21

Oracle Prov

2018-04-20 15:24:55

DockerfileDocker鏡像

2023-09-21 07:06:17

PSDriveProvider

2021-09-30 10:04:01

鴻蒙HarmonyOS應(yīng)用

2009-12-29 10:40:36

ADO組件

2009-07-10 18:06:59

JTree Swing

2011-04-28 10:41:12

simpleframeSimple

2009-07-17 14:38:51

輕量級Swing組件

2021-03-18 09:36:02

鴻蒙HarmonyOS應(yīng)用

2009-11-18 16:43:59

2021-10-14 15:14:36

鴻蒙HarmonyOS應(yīng)用

2009-08-25 13:38:35

C# Timer組件

2009-07-17 11:13:46

AWT和SwingSwing組件

2021-09-13 15:17:28

鴻蒙HarmonyOS應(yīng)用

2017-01-19 18:58:11

iOS組件化方案

2013-01-10 14:39:28

Android開發(fā)Content Pro組件

2011-03-21 11:01:54

2023-07-17 16:13:21

組件模塊開發(fā)的鴻蒙

2010-01-25 16:58:53

Android組件交互
點贊
收藏

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