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

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

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

3天內不再提示

鴻蒙系統如何設置自定義下拉刷新控件

OpenHarmony技術社區 ? 來源: 鴻蒙技術社區 ? 作者:中軟國際 ? 2021-09-13 09:24 ? 次閱讀

Ohos-MaterialRefreshLayout 是一個自定義 Material 風格下拉刷新控件,支持設置水波紋效果,支持下拉刷新侵入式和非侵入式,初始化自動刷新及上滑加載更多,支持刷新頭部自定義圖案,上拉加載更多等。

該控件一般配合 ListContainer 使用,因涉及事件分發操作,本庫中使用了三方控件 NestedListContainer、事件分發等方便處理事件攔截分發事件。

自定義控件結構

MaterialRefreshLayout 控件,首先初始化設置頭部、腳部布局,在手勢下滑時顯示頭部布局,動態設置頭部高度,展示下拉刷新效果,在頁面底部向上滑動時顯示腳部布局,展示上拉加載更多效果,松手時圖形即開始旋轉動畫。

下拉圓形轉動風格 MaterialRefreshLayout:

MaterialRefreshLayout 包含自定義頭部布局 MaterialHeaderView 和腳部布局 MaterialFooterView。

頭部 MaterialHeaderView 包含圓形轉動條 CircleProgressBar 和下拉波紋 MaterialWaveView。

腳部布局 MaterialFooterView 同頭部結構一致,包含圓形轉動條 CircleProgressBar 和下拉波紋 MaterialWaveView。

CircleProgressBar 包含有自定義圖形的 MaterialProgressDrawable,設置圓形的轉動圖案。

下拉自定義笑臉風格 MaterialRefreshLayout:

MaterialRefreshLayout 包含 SunLayout 頭部布局和腳部布局 MaterialFooterView。

SunLayout 頭部包含滾動短線 SunLineView 和笑臉 SunFaceView。

當有手勢下滑時,自定義短線 SunLineView,開始旋轉動畫,監聽刷新動作,在 onSizeChanged 中動態改變圖形大小。

當手勢向下滑動時,自定義笑臉圖形 SunFaceView,監聽刷新動作,在 onSizeChanged 中動態改變圖形大小。

代碼實現解讀

首先在攔截事件中根據手指的滑動距離,設置自定義頭部布局 MaterialHeaderView 可見,底部向上滑動時,當滑到頁面底部,設置腳部布局 MaterialFooterView 可見。

①事件分發 onInterceptTouchEvent 中設置頭、腳布局可見

在攔截事件 onInterceptTouchEvent 中,手指移動 TouchEvent.POINT_MOVE 時,根據滑動距離及是否是在頭部的滑動。

設置頭部自定義 headerview 是否顯示,再根據向上滑動距離是否小于 0 及是否滑動到底部加載底部 footerview。

代碼如下:

case TouchEvent.POINT_MOVE:

float currentY = ev.getPointerPosition(0).getY();

Float dy= new BigDecimal(currentY).subtract(new BigDecimal(mTouchY)).floatValue();

if (dy 》 0 && !canChildScrollUp()) {

if (mMaterialHeaderView != null) {

mMaterialHeaderView.setVisibility(Component.VISIBLE);

mMaterialHeaderView.onBegin(this);

} else if (mSunLayout != null) {

mSunLayout.setVisibility(Component.VISIBLE);

mSunLayout.onBegin(this);

}

return true;

} else if (dy 《 0 && !canChildScrollDown() && isLoadMore) {

if (mMaterialFooterView != null && !isLoadMoreing) {

soveLoadMoreLogic();

}

return false;

}

break;

上一步完成后,緊接著就是在觸摸事件中動態設置頭部布局高度,水波紋高度,滑到最大距離時,設置為控件本身高度。

②事件觸摸 onTouchEvent 中設置高度

在觸摸事件 onTouchEvent 中,當手指下滑,onTouchEvent 中設置頭部自定義 headerview 的高度,隨著下滑距離增加,動態設置水波紋高度,當頭部為侵入式時,設置 component 向下平移。

代碼如下:

case TouchEvent.POINT_MOVE:

mCurrentY = e.getPointerPosition(0).getY();

float dy = new BigDecimal(mCurrentY).subtract(new BigDecimal(mTouchY)).floatValue();

dy = Math.min(mWaveHeight * 2, dy);

dy = Math.max(0, dy);

if (mChildView != null) {

float offsetY = dy / 2;

float fraction = offsetY / mHeadHeight;

if (mMaterialHeaderView != null) {

mMaterialHeaderView.setHeight((int) offsetY);

mMaterialHeaderView.postLayout();

mMaterialHeaderView.onPull(this, fraction);

} else if (mSunLayout != null) {

mSunLayout.setHeight((int) offsetY);

mSunLayout.postLayout();

mSunLayout.startSunLineAnim(this);

mSunLayout.onPull(this, fraction);

}

if (!isOverlay)

mChildView.setTranslationY(offsetY);

}

在松手時,監聽抬起事件 TouchEvent.PRIMARY_POINT_UP,當頭部 headerview 高度大于原有高度時,將頭部設置為刷新中狀態。

代碼如下:

if (mMaterialHeaderView.getLayoutConfig().height 》 mHeadHeight) {

updateListener();

mMaterialHeaderView.setHeight((int) mHeadHeight);

mMaterialHeaderView.postLayout();

}

再接下來就是完成自定義頭部控件的布局,并在下拉接口方法中設置下拉時的縮放,透明度等狀態。

③自定義頭部 MaterialHeaderView

自定義 MaterialHeaderView 由 MaterialWaveView 和 CircleProgressBar 兩個自定義 Component 組合成,實現 MaterialHeadListener 接口。

onBegin 方法中設置 materialWaveView 的起始狀態,circleProgressBar 縮放大小,透明度等。

代碼如下:

@Overridepublic void onBegin(MaterialRefreshLayout materialRefreshLayout) {

if (materialWaveView != null) {

materialWaveView.onBegin(materialRefreshLayout);

}

if (circleProgressBar != null) {

circleProgressBar.setScaleX(0.001f);

circleProgressBar.setScaleY(0.001f);

circleProgressBar.onBegin(materialRefreshLayout);

}

}

onPull 方法中設置 materialWaveView 的下拉狀態,circleProgressBar 縮放大小,透明度等。

代碼如下:

@Overridepublic void onPull(MaterialRefreshLayout materialRefreshLayout, float fraction) {

if (materialWaveView != null) {

materialWaveView.onPull(materialRefreshLayout, fraction);

}

if (circleProgressBar != null) {

circleProgressBar.onPull(materialRefreshLayout, fraction);

float a = Util.limitValue(1, fraction);

circleProgressBar.setScaleX(a);

circleProgressBar.setScaleY(a);

circleProgressBar.setAlpha(a);

}

}

設置刷新中 onRefreshing 狀態。代碼如下:

@Overridepublic void onRefreshing(MaterialRefreshLayout materialRefreshLayout) {

if (materialWaveView != null) {

materialWaveView.onRefreshing(materialRefreshLayout);

}

if (circleProgressBar != null) {

circleProgressBar.onRefreshing(materialRefreshLayout);

}

}

onComlete 刷新完成后自定義 Component 的狀態初始化,代碼如下:

@Override

public void onComlete(MaterialRefreshLayout materialRefreshLayout) {

if (materialWaveView != null) {

materialWaveView.onComlete(materialRefreshLayout);

}

if (circleProgressBar != null) {

circleProgressBar.onComlete(materialRefreshLayout);

circleProgressBar.setTranslationY(0);

circleProgressBar.setScaleX(0);

circleProgressBar.setScaleY(0);

}

}

頭部布局完成后,接下來就是實現自定義腳部布局實現。

④自定義腳部 MaterialFooterView

自定義 MaterialFooterView 由 MaterialWaveView 和 CircleProgressBar 兩個自定義 Component 組合成,實現 MaterialHeadListener 接口?;就?MaterialHeaderView 一致,接口實現方法設置內容相同。

onBegin 方法中設置 materialWaveView 的起始狀態,circleProgressBar 縮放 1,透明度等。

代碼如下:

@Overridepublic void onBegin(MaterialRefreshLayout materialRefreshLayout) {

if (materialWaveView != null) {

materialWaveView.onBegin(materialRefreshLayout);

}

if (circleProgressBar != null) {

circleProgressBar.onBegin(materialRefreshLayout);

circleProgressBar.setScaleX(1);

circleProgressBar.setScaleY(1);

}

}

onPull 方法中設置 materialWaveView 的下拉狀態,circleProgressBar 縮放 1,透明度等。

代碼如下:

@Overridepublic void onPull(MaterialRefreshLayout materialRefreshLayout, float fraction) {

if (materialWaveView != null) {

materialWaveView.onPull(materialRefreshLayout, fraction);

}

if (circleProgressBar != null) {

circleProgressBar.onPull(materialRefreshLayout, fraction);

float a = Util.limitValue(1, fraction);

circleProgressBar.setScaleX(1);

circleProgressBar.setScaleY(1);

circleProgressBar.setAlpha(a);

}

}

設置刷新中 onRefreshing 狀態。代碼如下:

@Overridepublic void onRefreshing(MaterialRefreshLayout materialRefreshLayout) {

if (materialWaveView != null) {

materialWaveView.onRefreshing(materialRefreshLayout);

}

if (circleProgressBar != null) {

circleProgressBar.onRefreshing(materialRefreshLayout);

}

}

onComlete 刷新完成后自定義 Component 的狀態初始化,代碼如下:

@Overridepublic void onComlete(MaterialRefreshLayout materialRefreshLayout) {

if (materialWaveView != null) {

materialWaveView.onComlete(materialRefreshLayout);

}

if (circleProgressBar != null) {

circleProgressBar.onComlete(materialRefreshLayout);

circleProgressBar.setTranslationY(0);

circleProgressBar.setScaleX(0);

circleProgressBar.setScaleY(0);

}

}

頭部、腳部布局都完成后,就開始要完成頭部和腳部布局里面的自定義組件,首先從頭部布局中的自定義組件開始。

前面講到頭部由圓形轉動條 CircleProgressBar 和下拉波紋 MaterialWaveView 組成,先開始繪制波浪紋 MaterialWaveView,實現 MaterialHeadListener 接口,接口回調中設置組件的狀態。

⑤自定義 MaterialWaveView

初始化畫筆設置,添加 addDrawTask 任務,onDraw 方法中繪制下拉區域圖形,并填充顏色。

代碼如下:

@Overridepublic void onDraw(Component component, Canvas canvas) {

path.reset();

paint.setColor(new Color(color));

path.lineTo(0, headHeight);

path.quadTo(getEstimatedWidth() / (float) 2, headHeight + waveHeight, getEstimatedWidth(), headHeight);

path.lineTo(getEstimatedWidth(), 0);

canvas.drawPath(path, paint);

}

實現 MaterialHeadListener 接口,監聽各下拉方法的回調,當有下拉的情形時,改變下拉區域狀態。下拉時在 onPull 中,設置下拉區域 header 高度及 wave 高度。

刷新中 onRefreshing,加載數值動畫并動態改變 wave 高度。結束 onComlete 中,加載數值動畫動態改變 head 的高度。代碼如下:

下拉時:

@Overridepublic void onPull(MaterialRefreshLayout br, float fraction) {

setHeadHeight((int) (Util.dip2px(getContext(), DefaulHeadHeight) * Util.limitValue(1, fraction)));

setWaveHeight((int) (Util.dip2px(getContext(), DefaulWaveHeight) * Math.max(0, new BigDecimal(fraction).subtract(new BigDecimal(1)).floatValue())));

invalidate();

}

刷新時:

@Override

public void onRefreshing(MaterialRefreshLayout br) {

setHeadHeight((int) (Util.dip2px(getContext(), DefaulHeadHeight)));

int waveHeight = getWaveHeight();

AnimatorValue animator = new AnimatorValue();

animator.setValueUpdateListener(new AnimatorValue.ValueUpdateListener() {

@Override

public void onUpdate(AnimatorValue animatorValue, float value) {

setWaveHeight(getIntValue((1 - (double) value) * waveHeight));

invalidate();

}

});

animator.setCurveType(Animator.CurveType.BOUNCE);

animator.setDuration(200);

animator.start();

}

結束時:

@Override

public void onComlete(MaterialRefreshLayout br) {

waveHeight = 0;

AnimatorValue animator = new AnimatorValue();

animator.setDuration(200);

animator.setValueUpdateListener(new AnimatorValue.ValueUpdateListener() {

@Override

public void onUpdate(AnimatorValue animatorValue, float value) {

headHeight = getIntValue((1 - (double) value) * headHeight);

invalidate();

}

});

animator.start();

}

上一步完成后接下來開始實現頭部圓形轉動的 CircleProgressBar,并設置圖案的自定義 ShapeElement 圖形,配合手勢操作,下拉時設置圖形動態大小,松手時旋轉刷新。

⑥自定義 CircleProgressBar

自定義圓形轉動 CircleProgressBar,設置自定義背景 MaterialProgressDrawable,實現 MaterialHeadListener 接口。

根據下拉狀態設置圓形 MaterialProgressDrawable 旋轉角度,釋放手勢時開始動畫,結束后停止旋轉并初始化狀態等。

代碼如下:

@Overridepublic void onPull(MaterialRefreshLayout materialRefreshLayout, float fraction) {

if (mProgressDrawable != null)

mProgressDrawable.setProgressRotation(fraction);

invalidate();

}

@OverridePublic void onRefreshing(MaterialRefreshLayout materialRefreshLayout) {

if (mProgressDrawable != null) {

mProgressDrawable.onStart();

}

}

@Overridepublic void onComlete(MaterialRefreshLayout materialRefreshLayout) {

if (mProgressDrawable != null) {

mProgressDrawable.onStop();

}

setVisibility(Component.INVISIBLE);

}

自定義 MaterialProgressDrawable 設置 CircleProgressBar 的背景,首先構造方法中初始化圓形 Ring 和旋轉動畫,設置畫筆顏色,寬度,大小,在 drawToCanvas 中繪制圓形 Ring。

當有手勢操作時調用 onStart 方法中的旋轉動畫,開始旋轉。在 Ring 類 draw 方法中,根據起始旋轉角度繪制圓形圈圈及三角箭頭。

代碼如下:

public void draw(Canvas c, Rect bounds) {

final RectFloat arcBounds = mTempBounds;

arcBounds.modify(bounds);

arcBounds.left = new BigDecimal(arcBounds.left).add(new BigDecimal(mStrokeInset)).floatValue();

arcBounds.top = new BigDecimal(arcBounds.top).add(new BigDecimal(mStrokeInset)).floatValue();

arcBounds.right = new BigDecimal(arcBounds.right).subtract(new BigDecimal(mStrokeInset)).floatValue();

arcBounds.bottom = new BigDecimal(arcBounds.bottom).subtract(new BigDecimal(mStrokeInset)).floatValue();

final float startAngle = new BigDecimal(mStartTrim).add(new BigDecimal(mRotation)).floatValue() * 360;

final float endAngle = new BigDecimal(mEndTrim).add(new BigDecimal(mRotation)).floatValue() * 360;

float sweepAngle = new BigDecimal(endAngle).subtract(new BigDecimal(startAngle)).floatValue();

mPaint.setColor(Color.RED);

c.drawArc(arcBounds, new Arc(startAngle, sweepAngle, false), mPaint);

drawTriangle(c, startAngle, sweepAngle, bounds);

if (mAlpha 《 255) {

mCirclePaint.setColor(new Color(mBackgroundColor));

mCirclePaint.setAlpha(255 - mAlpha);

c.drawCircle(bounds.getCenterX(), bounds.getCenterY(), bounds.getWidth() / (float) 2,

mCirclePaint);

}

}

上述基本上就完成了 Material 風格下拉刷新帶水波紋,帶轉動 progressbar 的實現步驟,緊接著講一講下拉自定義笑臉的另外一種刷新風格,實際上就是重新定義了刷新頭部的圖形,在這里也可以自己嘗試替換成其它不同的圖形。

⑦自定義頭部 SunLayout 布局

自定義頭部 SunLayout 由 SunFaceView 和 SunLineView 組成,SunFaceView 為自定義笑臉,SunLineView 為自定義笑臉周圍短線。

SunLayout 實現了 MaterialHeadListener 接口,開始狀態 onBegin 時縮放從零到有,下拉 onPull 時,設置 SunView 和 LineView 的大小,縮放等。代碼如下:

開始時:

@Override

public void onBegin(MaterialRefreshLayout materialRefreshLayout) {

setScaleX(0.001f);

setScaleY(0.001f);

}

下拉時:

@Overridepublic void onPull(MaterialRefreshLayout materialRefreshLayout, float fraction) {

float a = Util.limitValue(1, fraction);

if (a 》= 0.7) {

mLineView.setVisibility(VISIBLE);

} else {

mLineView.setVisibility(HIDE);

}

mSunView.setPerView(mSunRadius, a);

mLineView.setLineWidth(mLineWidth);

setScaleX(a);

setScaleY(a);

setAlpha(a);

}

自定義笑臉 SunFaceView,自定義短線 SunLineView。

SunLineView 繼承 Component 實現 Component.DrawTask, Component.EstimateSizeListener 接口,構造方法中初始化 Paint,onEstimateSize 中測量寬高,onDraw 中繪制線條。代碼如下:

測量時:

@Overridepublic boolean onEstimateSize(int widthMeasureSpec, int heightMeasureSpec) {

HiLog.info(Contants.LABEL, “onMeasure”);

int widthMode = EstimateSpec.getMode(widthMeasureSpec);

int widthSize = EstimateSpec.getSize(widthMeasureSpec);

int heightMode = EstimateSpec.getMode(heightMeasureSpec);

int heightSize = EstimateSpec.getSize(heightMeasureSpec);

int width;

int height;

if (widthMode == EstimateSpec.PRECISE) {

width = widthSize;

} else {

width = (mSunRadius + mFixLineHeight + mLineHeight) * 2 + getPaddingRight() + getPaddingLeft();

}

if (heightMode == EstimateSpec.PRECISE) {

height = heightSize;

} else {

height = (mSunRadius + mFixLineHeight + mLineHeight) * 2 + getPaddingTop() + getPaddingBottom();

}

setEstimatedSize(width, height);

mWidth = width;

mHeight = height;

return false;

}

畫線條:

private void drawLines(Canvas canvas) {

for (int i = 0; i 《= 360; i++) {

if (i % mLineLevel == 0) {

mLineLeft = mWidth / 2 - mLineWidth / 2;

mLineTop = mHeight / 2 - mSunRadius - mFixLineHeight;

mLineBottom = mLineTop + mLineHeight;

}

canvas.save();

canvas.rotate(i, mWidth / (float) 2, mHeight / (float) 2);

canvas.drawLine(mLineLeft, mLineTop, mLineLeft, mLineBottom, mLinePaint);

canvas.restore();

}

}

代碼參考:

https://gitee.com/chinasoft5_ohos/Ohos-MaterialRefreshLayout

作者:盧經緯

責任編輯:haq

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

    關注

    37

    文章

    6858

    瀏覽量

    123487
  • 中軟國際
    +關注

    關注

    0

    文章

    527

    瀏覽量

    7226
  • 鴻蒙系統
    +關注

    關注

    183

    文章

    2637

    瀏覽量

    66487
  • HarmonyOS
    +關注

    關注

    79

    文章

    1980

    瀏覽量

    30315

原文標題:鴻蒙下拉刷新組件,這個最好用!

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

收藏 人收藏

    評論

    相關推薦

    think-cell:自定義think-cell(四)

    C.5 設置默認議程幻燈片布局 think-cell 議程可以在演示文稿中使用特定的自定義布局來定義議程、位置和議程幻燈片上的其他形狀,例如標題或圖片。通過將此自定義布局添加到模板,您
    的頭像 發表于 01-13 10:37 ?45次閱讀
    think-cell:<b class='flag-5'>自定義</b>think-cell(四)

    think-cell;自定義think-cell(一)

    本章介紹如何自定義 think-cell,即如何更改默認顏色和其他默認屬性;這是通過 think-cell 的樣式文件完成的,這些文件將在前四個部分中進行討論。 第五部分 C.5 設置默認議程幻燈片
    的頭像 發表于 01-08 11:31 ?96次閱讀
    think-cell;<b class='flag-5'>自定義</b>think-cell(一)

    創建自定義的基于閃存的引導加載程序(BSL)

    電子發燒友網站提供《創建自定義的基于閃存的引導加載程序(BSL).pdf》資料免費下載
    發表于 09-19 10:50 ?0次下載
    創建<b class='flag-5'>自定義</b>的基于閃存的引導加載程序(BSL)

    如何自定義內存控制器的設置

    策略都有其特定的使用場景和優缺點。以下是一些步驟和建議,用于自定義內存控制器的設置: 1. 選擇合適的內存分配策略 heap_1 :最簡單的內存分配策略,但分配的內存不允許釋放。適用于那些一旦分配就長期使用的場景。 heap_2 :支持動態內存的申請和釋放,但不支持內存碎
    的頭像 發表于 09-02 14:28 ?531次閱讀

    NVIDIA NeMo加速并簡化自定義模型開發

    如果企業希望充分發揮出 AI 的力量,就需要根據其行業需求量身定制的自定義模型。
    的頭像 發表于 07-26 11:17 ?778次閱讀
    NVIDIA NeMo加速并簡化<b class='flag-5'>自定義</b>模型開發

    為blufi_device設置自定義名稱,但是無法修改,為什么?

    我想為blufi_device設置自定義名稱,但是無法修改,依舊顯示默認名稱。后來我修改了...blufiincludeesp_blufi.c中
    發表于 06-11 08:16

    【AWTK使用經驗】如何自定義combo_box下拉框樣式

    需要在ZTP800示教器實現一個用于日期選擇的下拉框,并且還要求對下拉框做一些美化,此時就需要用戶自定義下拉框樣式。下面將結合該需求介紹兩種修改combo_box
    的頭像 發表于 05-23 08:25 ?488次閱讀
    【AWTK使用經驗】如何<b class='flag-5'>自定義</b>combo_box<b class='flag-5'>下拉</b>框樣式

    HarmonyOS開發案例:【 自定義彈窗】

    基于ArkTS的聲明式開發范式實現了三種不同的彈窗,第一種直接使用公共組件,后兩種使用CustomDialogController實現自定義彈窗
    的頭像 發表于 05-16 18:18 ?1405次閱讀
    HarmonyOS開發案例:【 <b class='flag-5'>自定義</b>彈窗】

    TSMaster 自定義 LIN 調度表編程指導

    LIN(LocalInterconnectNetwork)協議調度表是用于LIN總線通信中的消息調度的一種機制,我們收到越來越多來自不同用戶希望能夠通過接口實現自定義LIN調度表的需求。所以在
    的頭像 發表于 05-11 08:21 ?711次閱讀
    TSMaster <b class='flag-5'>自定義</b> LIN 調度表編程指導

    HarmonyOS實戰開發-深度探索與打造個性化自定義組件

    今天分享一下 什么是自定義組件?及其自定義組件的實戰。 做過前端或者android開發的都知道自定義組件,鴻蒙中顯示在界面上的UI都稱為組件,小打一個按鈕,再到一個列表。
    發表于 05-08 16:30

    HarmonyOS開發案例:【自定義下拉刷新動畫】

    主要介紹組件動畫animation屬性設置。當組件的某些通用屬性變化時,可以通過屬性動畫實現漸變效果,提升用戶體驗。
    的頭像 發表于 04-29 16:06 ?1007次閱讀
    HarmonyOS開發案例:【<b class='flag-5'>自定義</b><b class='flag-5'>下拉</b><b class='flag-5'>刷新</b>動畫】

    LabVIEW里Ring自定義控件,其常量無法保持同步修改,如何解決

    自定義控件已經使用了“嚴格自定義控件”這一設置。 Ring控件雖然已經綁定
    發表于 04-24 11:20

    HarmonyOS開發實例:【自定義Emitter】

    使用[Emitter]實現事件的訂閱和發布,使用[自定義彈窗]設置廣告信息。
    的頭像 發表于 04-14 11:37 ?1025次閱讀
    HarmonyOS開發實例:【<b class='flag-5'>自定義</b>Emitter】

    鴻蒙ArkUI實例:【自定義組件】

    組件是 OpenHarmony 頁面最小顯示單元,一個頁面可由多個組件組合而成,也可只由一個組件組合而成,這些組件可以是ArkUI開發框架自帶系統組件,比如?`Text`?、?`Button`?等,也可以是自定義組件,本節筆者簡單介紹一下
    的頭像 發表于 04-08 10:17 ?667次閱讀

    鴻蒙開發UI界面——@ohos.font (注冊自定義字體)

    字體管理中注冊自定義字體。 系統能力: SystemCapability.ArkUI.ArkUI.Full 參數: 參數名 類型 必填 說明 options FontOptions 是 注冊的自定義
    的頭像 發表于 02-22 16:22 ?771次閱讀
    主站蜘蛛池模板: 婷婷色综合久久| 午夜剧场官网| 中文字幕一区二区三区视频在线| 日韩一级片免费观看| 天天操夜夜添| 99久久99久久免费精品蜜桃| 欧美网站视频| 免费人成年激情视频在线观看| 久久久久久久国产精品电影| 黄色三级视频在线观看| 欧美在线视频一区二区三区| 亚欧色视频在线观看免费| 中文字幕亚洲一区二区三区| 成人牲交一极毛片| 神马福利| 插插操操| 日本一二线不卡在线观看| 狼干综合| 男男宿舍高h炒肉bl| 啪啪调教所29下拉式免费阅读| 国模欢欢炮交啪啪150| 同性男男肉交短文| 在线观看亚洲一区二区| 国模小丫大尺度啪啪人体| 新版天堂中文资源官网| 亚洲国产成人精品青青草原100| 老司机亚洲精品影院在线| 怡红院日本| 日本a级片在线观看| 欧美在线免费| 国产亚洲美女| 国产精品国产三级国产普通话对白| 俺不色| bt天堂网在线资源www| 天天看a| 黄在线网站| 亚洲人成电影在线播放| 欧美人与禽| 国模谢心2013.05.06私拍| 国模精品| 天天澡天天摸天天添视频|