精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

HarmonyOS 自定義組件之上拉抽屜

開發(fā) OpenHarmony
這里給大家提供了一個BottomSheet上拉抽屜的組件,同時通過這個組件示例講解一下HarmonyOS中的幾個自定義控件用到的知識,分享一下自己自定義組件的思路。

[[441431]]

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

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

https://harmonyos.51cto.com

簡介

HarmonyOS 開發(fā)自定義組件目前還不是很豐富,在開發(fā)過程中常常會有一些特殊效果的組件,這就需要我們額外花一些時間實現(xiàn),這里給大家提供了一個BottomSheet上拉抽屜的組件,同時通過這個組件示例講解一下HarmonyOS中的幾個自定義控件用到的知識,分享一下自己自定義組件的思路。

效果演示

#星光計劃2.0# HarmonyOS 自定義組件之上拉抽屜-鴻蒙HarmonyOS技術(shù)社區(qū)

實現(xiàn)思路

1.布局設(shè)計

選擇的是相對布局,蒙層區(qū)來改變內(nèi)容區(qū)隨著抽屜的位置調(diào)節(jié)透明度。

圖1:

#星光計劃2.0# HarmonyOS 自定義組件之上拉抽屜-鴻蒙HarmonyOS技術(shù)社區(qū)
[[441433]]

 

2.手勢判斷

先得出Component在屏幕的上下左右的坐標(biāo),然后手指的坐標(biāo)是否在Component內(nèi)。

  1. /** 
  2.  * (x,y)是否在view的區(qū)域內(nèi) 
  3.  * 
  4.  * @param component 
  5.  * @param x 
  6.  * @param y 
  7.  * @return 
  8.  */ 
  9. private boolean isTouchPointInComponent(Component component, float x, float y) { 
  10.     int[] locationOnScreen = component.getLocationOnScreen(); 
  11.     int left = locationOnScreen[0]; 
  12.     int top = locationOnScreen[1]; 
  13.     int right = left + component.getEstimatedWidth(); 
  14.     int bottom = top + component.getEstimatedHeight(); 
  15.     boolean inY = y >= top && y <= bottom; 
  16.     boolean inX = x >= left && x <= right
  17.     return inY && inX; 

3.抽屜偏移

  • 這里采用的是整個component對Touch事件的監(jiān)聽;
  • 手指按下的判斷是否在抽屜上,然后記錄當(dāng)前觸摸y坐標(biāo);
  • 移動是算出偏移量offY;
  1. setTouchEventListener(new TouchEventListener() { 
  2.     @Override 
  3.     public boolean onTouchEvent(Component component, TouchEvent touchEvent) { 
  4.         HiLog.info(logLabel, "onTouchEvent action:" + touchEvent.getAction()); 
  5.         switch (touchEvent.getAction()) { 
  6.             case TouchEvent.PRIMARY_POINT_DOWN: 
  7.                 marginBottom = directionalLayout.getMarginBottom(); 
  8.                 MmiPoint position = touchEvent.getPointerScreenPosition(0); 
  9.                 if (isTouchPointInComponent(directionalLayout, position.getX(), position.getY())) { 
  10.                     dragStartPointY = touchEvent.getPointerPosition(0).getY(); 
  11.                     return true
  12.                 } 
  13.                 break; 
  14.             case TouchEvent.PRIMARY_POINT_UP: 
  15.                 onTouchUp(); 
  16.                 break; 
  17.             case TouchEvent.POINT_MOVE: 
  18.                 float y = touchEvent.getPointerPosition(0).getY(); 
  19.                 float offY = dragStartPointY - y; 
  20.                 setDrawerMarginBottom((int) offY); 
  21.                 break; 
  22.         } 
  23.         return false
  24.     } 
  25. }); 

根據(jù)偏移量改變抽屜的位置;

  1. private void setDrawerMarginBottom(int offY) { 
  2.     int bottom = marginBottom + offY; 
  3.     if (bottom > 0) { 
  4.         bottom = 0; 
  5.         listContainer.setEnabled(true); 
  6.     } 
  7.  
  8.     if (bottom < -H / 2) { 
  9.         bottom = -H / 2; 
  10.     } 
  11.     HiLog.info(logLabel, "setDrawerMarginBottom bottom:" + bottom); 
  12.  
  13.     float alpha = (0.5f - Math.abs((float) bottom / (float) H)) * 0.5f; 
  14.     HiLog.info(logLabel, "setDrawerMarginBottom alpha:" + alpha); 
  15.     bgComponent.setAlpha(alpha); 
  16.     directionalLayout.setMarginBottom(bottom); 

4.事件沖突解決

首先發(fā)現(xiàn)不能按安卓的思想去處理:

  • HarmonyOS中是沒有事件分發(fā)這概念的,只有事件消費,ListContainer先拿到事件,然后是抽屜布局;
  • 根據(jù)抽屜在完全展開的位置,在ListContainer收到觸摸事件時,把ListContainer事件靜止掉,不讓其消費;
  • 待抽屜完全展開時,解開ListContainer的事件;
  1. listContainer.setTouchEventListener(new TouchEventListener() { 
  2.     @Override 
  3.     public boolean onTouchEvent(Component component, TouchEvent touchEvent) { 
  4.         marginBottom = directionalLayout.getMarginBottom(); 
  5.         boolean drag_down = listContainer.canScroll(DRAG_DOWN); 
  6.         boolean drag_UP = listContainer.canScroll(DRAG_UP); 
  7.         if (marginBottom == 0 && drag_down) { 
  8.             component.setEnabled(true); 
  9.             return true
  10.         } 
  11.         component.setEnabled(false); 
  12.         return false
  13.     } 
  14. }); 

這里是抽屜容器定位抽屜時,判斷是否打開ListContainer事件。

  1. private void setDrawerMarginBottom(int offY) { 
  2.     int bottom = marginBottom + offY; 
  3.     if (bottom > 0) { 
  4.         bottom = 0; 
  5.         listContainer.setEnabled(true); 
  6.     } 
  7.     ....... 

5.背景亮暗變化

  • 首先我們XML布局參照上述布局設(shè)計—圖1;
  • 背景亮暗的改變根據(jù)抽屜位置按比例設(shè)置蒙層的透明度;
  1. float alpha = (0.5f - Math.abs((float) bottom / (float) H)) * 0.5f; 
  2. bgComponent.setAlpha(alpha); 

6.回彈效果

運用到了數(shù)值動畫,在手勢抬起時,判斷上下臨界點決定動畫的上下。

  1. private void onTouchUp() { 
  2.     HiLog.info(logLabel, "onTouchUp"); 
  3.     createAnimator(); 
  1. private void createAnimator() { 
  2.     marginBottom = directionalLayout.getMarginBottom(); 
  3.     HiLog.info(logLabel, "createAnimator marginBottom:" + marginBottom); 
  4.     //創(chuàng)建數(shù)值動畫對象 
  5.     AnimatorValue animatorValue = new AnimatorValue(); 
  6.     //動畫時長 
  7.     animatorValue.setDuration(300); 
  8.     //播放前的延遲時間 
  9.     animatorValue.setDelay(0); 
  10.     //循環(huán)次數(shù) 
  11.     animatorValue.setLoopedCount(0); 
  12.     //動畫的播放類型 
  13.     animatorValue.setCurveType(Animator.CurveType.ACCELERATE_DECELERATE); 
  14.     //設(shè)置動畫過程 
  15.     animatorValue.setValueUpdateListener(new AnimatorValue.ValueUpdateListener() { 
  16.         @Override 
  17.         public void onUpdate(AnimatorValue animatorValue, float value) { 
  18.             HiLog.info(logLabel, "createAnimator value:" + value); 
  19.             if (marginBottom > -H / 4) { // top 
  20.                 HiLog.info(logLabel, "createAnimator top:" + value); 
  21.                 setDrawerBottomOrToP((int) (marginBottom - value * marginBottom)); 
  22.             } else { // bottom 
  23.                 HiLog.info(logLabel, "createAnimator bottom:" + value); 
  24.                 int top = H / 2 + marginBottom; 
  25.                 setDrawerBottomOrToP((int) (marginBottom - value *top)); 
  26.             } 
  27.         } 
  28.     }); 
  29.     //開始啟動動畫 
  30.     animatorValue.start(); 
  1. private void setDrawerBottomOrToP(int bottom) { 
  2.     if (bottom > 0) { 
  3.         bottom = 0; 
  4.         listContainer.setEnabled(true); 
  5.     } 
  6.  
  7.     if (bottom < -H / 2) { 
  8.         bottom = -H / 2; 
  9.     } 
  10.   
  11.     float alpha = (0.5f - Math.abs((float) bottom / (float) H)) * 0.5f; 
  12.  
  13.     bgComponent.setAlpha(alpha); 
  14.     directionalLayout.setMarginBottom(bottom); 

總結(jié)

自定義組件步驟及思考方向:

明確父容器和子view的關(guān)系;

如何繪制一般采用以下三個方向:

  1. 已有控件組合;
  2. 采用畫布繪制等;
  3. 繼承控件擴展功能;

若涉及到觸摸事件,需要考慮如何處理事件分發(fā)與消費;

動畫選擇,可根據(jù)需求選擇合適動畫(本文采用屬性動畫);

計算問題,復(fù)雜的需要豐富的數(shù)學(xué)知識;

性能問題(過度計算,重復(fù)繪制,對象重復(fù)創(chuàng)建)。

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

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

https://harmonyos.51cto.com

 

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

2022-04-24 15:17:56

鴻蒙操作系統(tǒng)

2023-02-20 15:20:43

啟動頁組件鴻蒙

2021-11-01 10:21:36

鴻蒙HarmonyOS應(yīng)用

2022-07-15 16:45:35

slider滑塊組件鴻蒙

2022-06-30 14:02:07

鴻蒙開發(fā)消息彈窗組件

2021-09-15 10:19:15

鴻蒙HarmonyOS應(yīng)用

2022-10-26 15:54:46

canvas組件鴻蒙

2022-10-25 15:12:24

自定義組件鴻蒙

2022-07-06 20:24:08

ArkUI計時組件

2022-06-20 15:43:45

switch開關(guān)鴻蒙

2022-02-21 15:16:30

HarmonyOS鴻蒙操作系統(tǒng)

2021-11-22 10:00:33

鴻蒙HarmonyOS應(yīng)用

2022-02-16 16:09:12

鴻蒙游戲操作系統(tǒng)

2021-12-24 15:46:23

鴻蒙HarmonyOS應(yīng)用

2022-07-12 16:56:48

自定義組件鴻蒙

2022-02-16 15:25:31

JS代碼Canvas鴻蒙

2022-06-23 07:23:34

自定義組件計時器

2025-09-22 08:03:34

2021-01-11 11:36:23

鴻蒙HarmonyOSApp開發(fā)

2009-06-24 15:13:36

自定義JSF組件
點贊
收藏

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

欧美3p视频| а√天堂8资源中文在线| 麻豆精品久久久| 欧美精品一区二区免费| 中文字幕 日本| 欧美性理论片在线观看片免费| 国产精品久久二区二区| 国产伦理久久久| 亚洲最大成人av| 亚洲精选成人| www国产精品视频| 91丨porny丨对白| 91精品亚洲一区在线观看| 亚洲国产一二三| 先锋影音网一区| 日日躁夜夜躁白天躁晚上躁91| 日本系列欧美系列| 韩国精品美女www爽爽爽视频| 天堂资源在线视频| 欧洲亚洲成人| 日韩欧美国产电影| 五月婷婷深爱五月| 人人草在线视频| 亚洲视频免费在线观看| 日本一区二区三区免费看| 亚洲国产精品无码久久| 久久99最新地址| 国产成人精品免高潮费视频| 99免费在线观看| 日韩精品dvd| 亚洲欧美激情另类校园| 美女露出粉嫩尿囗让男人桶| 国产亚洲字幕| 欧美在线观看视频一区二区| 国产又黄又大又粗视频| 波多野结衣在线高清| 亚洲色图欧美激情| 亚洲欧洲国产日韩精品| 国产永久av在线| 2023国产精品| 精品免费视频123区| 免费观看国产精品| 国产成人精品亚洲日本在线桃色| 国产精品一区二区性色av| 久久久久久无码精品大片| 99成人免费视频| 国产做受69高潮| 国产亚洲精品久久久久久打不开| 在线看片不卡| 久久九九热免费视频| 潮喷失禁大喷水aⅴ无码| 精品日产免费二区日产免费二区| 亚洲欧洲日韩国产| 色无极影院亚洲| 亚洲va久久久噜噜噜久久| 国产视频精品久久久| 中文字幕一区二区久久人妻网站 | 欧美一级大胆视频| 在线观看黄网站| 国产欧美一区二区色老头| 午夜精品一区二区三区在线播放| 国产精品成人av久久| 亚洲大胆在线| 91高潮精品免费porn| 天堂网一区二区三区| 国产视频欧美| 国产精品观看在线亚洲人成网 | 欧美久久久影院| 欧美大片久久久| 国产不卡精品| 精品电影一区二区| 日韩精品卡通动漫网站| 激情五月综合| 久久精品这里热有精品| 久一视频在线观看| 亚洲欧美日韩一区在线观看| 国产成人精品久久亚洲高清不卡| 在线观看亚洲一区二区| 国产精品18久久久久| 国产精品三区www17con| 邻居大乳一区二区三区| 久久久国际精品| 一级特黄录像免费播放全99| 91香蕉在线观看| 亚洲高清不卡在线观看| 免费观看成人在线视频| 亚洲欧美综合久久久久久v动漫| 日韩一区二区精品在线观看| 大尺度做爰床戏呻吟舒畅| 精品国产91| 欧美大尺度在线观看| 日本熟女毛茸茸| 久久福利资源站| 成人综合色站| 国产毛片在线| 亚洲一级二级三级| 久久精品一区二| 国产精品国产亚洲精品| 日韩精品亚洲视频| 国产精品三区在线观看| 久久深夜福利| 97av自拍| 成年人视频网站在线| 亚洲专区一二三| 91香蕉视频污版| 97视频一区| 最新国产精品拍自在线播放 | 伊人久久婷婷| 国产精品美女呻吟| 四虎在线视频免费观看| 亚洲欧洲三级电影| 欧美 激情 在线| 日韩欧美中文字幕在线视频| 国产亚洲在线播放| 日本系列第一页| 韩国精品在线观看| 日韩福利二区| 九色porny自拍视频在线观看| 欧美日韩一卡二卡三卡| 少妇毛片一区二区三区| 亚洲天堂黄色| 91久久久久久| 中文字幕日本在线观看| 欧美午夜无遮挡| 亚洲色偷偷色噜噜狠狠99网| 一本精品一区二区三区| 国产精品视频最多的网站| 日本午夜在线| 午夜亚洲福利老司机| 日本成人xxx| 欧美激情理论| 国产精品久久9| 精品欧美不卡一区二区在线观看| 亚洲成人动漫在线观看| 特种兵之深入敌后| 亚洲精品成人无限看| 国产精品免费一区豆花| 国产小视频福利在线| 日韩欧美国产网站| 亚洲av无码一区二区三区网址| 国产一区视频在线观看免费| 亚洲伊人成综合成人网| 国产精品一卡二卡三卡| 制服丝袜中文字幕一区| 欧美三级黄色大片| 激情欧美一区二区三区在线观看| 亚洲欧洲免费无码| 国产一区高清| 精品国产一区二区三区久久久| 中文字幕av网站| 日本一区二区综合亚洲| 国产精品人人爽人人爽| 欧美亚洲在线日韩| 国产精品久久久久久网站| 91在线网址| 91精品国产欧美一区二区成人| 黑人狂躁日本娇小| 国产一区二区日韩精品| 91免费国产精品| 韩国精品福利一区二区三区| 性色av一区二区三区免费| 亚洲av成人无码网天堂| 欧美日韩一区免费| 中文字幕在线观看免费高清| 奇米888四色在线精品| 在线观看成人一级片| 爱情电影网av一区二区| 欧美黑人巨大xxx极品| 欧美一级做性受免费大片免费| 午夜免费久久看| av永久免费观看| 韩国v欧美v亚洲v日本v| 精品人妻大屁股白浆无码| 香蕉国产成人午夜av影院| 国产精品久久久久久久久久三级| 麻豆传媒免费在线观看| 欧美mv和日韩mv的网站| 丁香六月婷婷综合| 国产精品乱子久久久久| 美女露出粉嫩尿囗让男人桶| 久久天天综合| 日本免费黄色小视频| 女同一区二区三区| 国产区精品视频| 黄页在线观看免费| 伊人伊人伊人久久| www三级免费| 色综合久久中文字幕| 婷婷伊人五月天| 97精品视频在线观看自产线路二| www亚洲成人| 日韩一区二区免费看| 亚洲一卡二卡三卡| 久久久久久毛片免费看 | 亚洲va欧美va人人爽成人影院| 8090成年在线看片午夜| 蜜桃视频网站在线| 国产午夜精品久久久| 国产男女裸体做爰爽爽| 欧美性videos高清精品| 午夜少妇久久久久久久久| 久久久美女毛片| 91av免费观看| 蜜臀av亚洲一区中文字幕| 男人添女人下部高潮视频在观看| 俺要去色综合狠狠| 久久爱av电影| 精品一区91| 国产精品久久久久久久久久99| 成人免费高清观看| 久久综合免费视频| 成人三级黄色免费网站| 亚洲精品成人av| 精品二区在线观看| 欧美日韩国产色站一区二区三区| 91美女免费看| 亚洲一区在线电影| 国产suv一区二区三区| 国产精品女同一区二区三区| 在线国产视频一区| 91在线视频播放地址| 在线成人精品视频| 极品尤物av久久免费看| 一区二区三区入口| 久久国产主播| 免费av观看网址| 精品二区视频| 青青青在线观看视频| 亚洲天堂免费| 一区二区三区四区国产| 精品美女久久| 日本一区视频在线播放| 国内精品久久久久久久影视简单 | 国产在线日韩精品| 欧美一区二区视频在线| 亚洲老女人视频免费| 国产在线精品一区二区三区》 | 日本伊人色综合网| 国产精品一区二区羞羞答答| 视频一区在线播放| 麻豆av免费在线| 久热精品在线| 激情综合网俺也去| 日本美女一区二区三区视频| 爱情岛论坛成人| 日本在线不卡一区| 亚洲国产精品三区| 久久精品国产亚洲一区二区三区| 亚洲xxxx2d动漫1| 蜜桃传媒麻豆第一区在线观看| 手机在线看福利| 麻豆国产精品官网| 午夜av中文字幕| 国产精品一区二区久久不卡 | 久久精品91久久香蕉加勒比| 日本不卡不卡| 久久的精品视频| 影音先锋男人资源在线| 欧美激情网友自拍| 极品av在线| 国产va免费精品高清在线观看| 欧美性理论片在线观看片免费| 国产伦精品一区二区三区精品视频| 祥仔av免费一区二区三区四区| 亚洲va欧美va在线观看| aaa国产精品视频| 快播日韩欧美| 91亚洲国产| 男人天堂新网址| 免费久久99精品国产自在现线| 天天碰免费视频| 国产尤物一区二区| 国产人妻黑人一区二区三区| 久久久国产综合精品女国产盗摄| 欧美肥妇bbwbbw| 亚洲福中文字幕伊人影院| 中文字幕在线播| 欧美一级片在线| 午夜成人鲁丝片午夜精品| 一本色道久久综合亚洲精品小说 | 国产成人av在线播放| 57pao成人永久免费| 国产欧美日韩综合精品二区| 九九在线高清精品视频| 懂色av一区二区三区四区五区| 亚洲国产午夜| 日本新janpanese乱熟| 国产在线精品不卡| 欧美丰满少妇人妻精品| 国产精品毛片大码女人| 国产精品自拍视频一区| 欧美日韩日日夜夜| 天天操天天操天天操| 日韩亚洲精品视频| 涩涩视频网站在线观看| 亚洲影院色无极综合| 女人丝袜激情亚洲| 欧洲精品在线播放| 久久电影网站中文字幕 | a天堂中文在线观看| 日韩电影网在线| 久久综合网导航| 日本精品视频在线播放| 亚洲3区在线| 亚洲永久激情精品| 欧美一级播放| 黄色激情在线观看| 亚洲三级电影全部在线观看高清| 中文字幕日韩免费| 亚洲激情视频网| 八戒八戒神马在线电影| 国产精品久久久久久久久久久久 | 国产精品美女在线播放| 亚洲综合国产| 国产精品日日摸夜夜爽| 国产精品传媒入口麻豆| 手机在线看片1024| 亚洲电影免费观看高清完整版在线| 麻豆视频在线观看免费网站| 国产成人精品综合久久久| 日韩精品丝袜美腿| 欧美久久久久久久久久久久久久| 精品一区二区免费看| 精品欧美一区二区久久久| 亚洲va欧美va人人爽| 999av视频| 久久最新资源网| 日本午夜精品久久久久| 少妇特黄a一区二区三区 | 国产成人精品一区| 日韩高清一级| 国产美女无遮挡网站| 国产成人av影院| 黄页网站免费观看| 欧美一区二区在线视频| 国产在线更新| 91精品在线影院| 中文无码久久精品| 欧美视频亚洲图片| 亚洲精品日韩专区silk| 国产视频在线观看视频| 欧美日韩ab片| 亚洲高清在线一区| 嫩草影院中文字幕| 成人激情综合网站| 人人干人人干人人干| 亚洲国产日韩一区| 少妇视频在线观看| 蜜桃麻豆www久久国产精品| 销魂美女一区二区三区视频在线| 无码熟妇人妻av| 欧美日韩国产精品一区二区不卡中文| 人人妻人人澡人人爽人人欧美一区 | 亚洲已满18点击进入在线看片 | 寂寞少妇一区二区三区| 国产精品久久久视频| 色婷婷av一区二区三区软件| 精品av中文字幕在线毛片 | 97久久久久久久| 亚洲精品一二区| 四虎4545www国产精品| 亚洲一区二区在线免费观看| 精品亚洲porn| 日日骚一区二区三区| 欧美成人一区二区三区| www.综合| 日本高清久久一区二区三区| 老司机午夜精品| 欧美国产日韩在线观看成人| 亚洲成人激情在线| 亚洲伦理影院| 亚洲综合激情五月| bt欧美亚洲午夜电影天堂| 日韩手机在线视频| 久热精品视频在线| 精品国产导航| 国产免费又粗又猛又爽| 一区二区三区四区五区视频在线观看| 天堂中文字幕av| 国产精品欧美风情| 欧美成人嫩草网站| 18禁裸乳无遮挡啪啪无码免费| 欧美色区777第一页| 羞羞视频在线免费国产| 免费观看成人高| 国产在线一区观看| 一区二区三区福利视频| 少妇av一区二区三区| 久久99精品国产自在现线| 男女爽爽爽视频| 性欧美大战久久久久久久久| 999在线视频| 久久精品午夜一区二区福利| 久久99精品国产.久久久久| 日韩免费不卡视频| y97精品国产97久久久久久| 免费看久久久| 又黄又爽又色的视频| 91黄视频在线观看| 国产精品一品|