日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Android自定義ViewGroup實現流式布局

瀏覽:23日期:2022-09-22 14:28:21

本文實例為大家分享了Android自定義ViewGroup實現流式布局的具體代碼,供大家參考,具體內容如下

Android自定義ViewGroup實現流式布局

1.概述

本篇給大家帶來一個實例,FlowLayout,什么是FlowLayout,我們常在App 的搜索界面看到熱門搜索詞,就是FlowLayout,我們要實現的就是圖中的效果,就是根據容器的寬,往容器里面添加元素,如果剩余的控件不足時候,自行添加到下一行,FlowLayout也叫流式布局,在開發中還是挺常用的.

2.對所有的子View進行測量

onMeasure方法的調用次數是不確定的,所以為了避免測量出錯,需要把總的List集合,清空一下,一個View的繪制,需要經過onMeasure方法的測量,和onLayout方法的排版才能顯示出來,在測量的方法中,我們把該ViewGroup中的所有子View遍歷出來,添加到一行中的List集合中,再把一行中的所有的元素集合添加到總的集合中去,并對每個子View元素進行測量,測量的參數,我們給0,或者未指定,,如果不是一行中的第一元素,并且通過 getUsablewWidth()方法獲取一行中可用的寬度,不夠容納下一元素,時就新創建一個集合,來裝一行中所有元素,再把所有的子View元素全部測量完成后,我們還需要通過setMeasuredDemoetion()方法把測量出來的寬和高保存起來,保存之后可以調用getMeasureWidth獲取測量之后的寬了.

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { allLines.clear(); //測量容器的寬和高 int containerMeasuredWidth = MeasureSpec.getSize(widthMeasureSpec); //這個集合用于保存單行 ArrayList<View> oneLine = null; for (int i = 0; i < getChildCount(); i++) { //獲取每一Chiledview View child = getChildAt(i); int UnspecifiedMeasureSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED); child.measure(UnspecifiedMeasureSpec, UnspecifiedMeasureSpec);//相當于傳了一個0,0; //如果是第1個view就new一個新行出來,或者View大于了可用的寬度, if (i == 0 || child.getMeasuredWidth() > getUsablewWidth(containerMeasuredWidth, oneLine,oneLine.size())) { oneLine = new ArrayList<View>(); allLines.add(oneLine); } oneLine.add(child); } int lineNumber = allLines.size(); int allLinesHeight = getChildAt(0).getMeasuredHeight() * lineNumber; int verticalTotalpadding = getPaddingBottom() + getPaddingTop(); //垂直總的spcing int verticalTotalSpcing = 8 * (lineNumber - 1); //容器的高 = 所有View的高 + 垂直方向的Padding + 垂直總的spcing int containerMeasureHeight = allLinesHeight + verticalTotalpadding + verticalTotalSpcing; setMeasuredDimension(containerMeasuredWidth, containerMeasureHeight); }

3.獲取一行中可用的空間

獲取一行中可用的寬度,需要我們傳入容器的寬度,和一行元素的集合,和元素之間的間隔,,然后遍歷所有的元素,通過一個變量來保存所有View測量出來寬度的總和,用容器的寬 減去,子View寬度的總和減去水平方向的間隔,以及左右兩邊的Padding,得到一行中可用的寬度

private int getUsablewWidth(int containerMeasuredWidth, ArrayList<View> oneLine,int needSpacingCount) { int oneLineWidth = 0; for (View view : oneLine) { oneLineWidth += view.getMeasuredWidth(); } //水平方向兩邊的padding int horizotalPadding = getPaddingLeft() + getPaddingRight(); int horizontalTotalSpcing = horizotalPadding * needSpacingCount; int usablewWidth = containerMeasuredWidth - oneLineWidth - horizotalPadding - horizontalTotalSpcing; return usablewWidth; }

4.對所有的子View進行排版

還是遍歷每一行中的每一個元素,對該元素執行排版方法,通過child.getMeasuredWidth();和child.getMeasuredHeight();獲取測量后的View的寬和高,通過child.layout(l,t,r,b),對View進行位置的擺放,left就是上個元素的Rigth,Top,就是上一行元素的Bootom,Rigth就是Left+View自身的寬度,Bottom是Top+View自身的高度,最后,因為我們手動把TextView的寬改變了,跟測量時的寬不一樣了,重新調用測量即可

protected void onLayout(boolean changed, int l, int t, int r, int b) { int tempRight = 0;//保存一行中上一個View的Right int tempBottom = 0;//保存上一行View的Bottom位置 ///遍歷第一排 for (int row = 0; row < allLines.size(); row++) { ArrayList<View> oneLines = allLines.get(row); //計算一行中每個Veiw可以分到的平均寬度 int totalUsableWidth= getUsablewWidth(getMeasuredWidth(), oneLines,oneLines.size()-1); int averageUsablewWidth = totalUsableWidth/oneLines.size(); //遍歷的是一行的內容 for (int column = 0; column < oneLines.size(); column++) { View child = oneLines.get(column); //獲取測量的寬高 int measuredWidth = child.getMeasuredWidth(); int measuredHeight = child.getMeasuredHeight(); //如果是一行中的第一個View則排在第0個位置 int left = column == 0 ? getPaddingLeft() : tempRight + 8; //如果是第1行Top坐標是PaddingTop的位置,否則就上一個View的bottom位置 int top = row == 0 ? getPaddingTop() : tempBottom + 8; int right = left + measuredWidth ;//+ averageUsablewWidth;int bootom = top + measuredHeight; child.layout(left, top, right, bootom); tempRight = right;int WidthMeasureSpec = MeasureSpec.makeMeasureSpec(child.getWidth(), MeasureSpec.EXACTLY); int HeightMakeMeasureSpec = MeasureSpec.makeMeasureSpec(child.getHeight(), MeasureSpec.EXACTLY); child.measure(WidthMeasureSpec,HeightMakeMeasureSpec); } tempBottom = oneLines.get(0).getBottom(); } }

5.Activity

public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); FlowLayout flowLayout = new FlowLayout(this); flowLayout.setPadding(6, 6, 6, 6); for (String text : list) { TextView textView = new TextView(this); textView.setBackgroundResource(R.drawable.bg_text); textView.setGravity(Gravity.CENTER); textView.setPadding(6, 6, 6, 6); textView.setText(text); textView.setTextSize(20); flowLayout.addView(textView); } setContentView(flowLayout); } }

6.TextView 的背景

<shape xmlns:android='http://schemas.android.com/apk/res/android' android:shape='rectangle'> <stroke android: android:color='#5000' /> <corners android:radius='6dp'/></shape>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜精品一区二区三区国产| 成人日韩在线观看| 91精品国产调教在线观看| 欧美激情另类| 丁香婷婷久久| 精品日本视频| 高清精品久久| 中国字幕a在线看韩国电影| 黑森林国产精品av| 日韩深夜视频| 欧美午夜精品一区二区三区电影| 91精品国产成人观看| 欧美日韩精品在线一区| 欧美精品九九| 日韩中文字幕1| 日韩不卡在线观看日韩不卡视频| 一区二区国产精品| 青青国产精品| 麻豆中文一区二区| 国产精品xx| 蜜桃成人av| 老司机精品久久| 欧美偷窥清纯综合图区| 精品国产午夜| 欧美亚洲国产一区| 蜜桃91丨九色丨蝌蚪91桃色| 亚洲精品第一| 美女高潮久久久| 三级小说欧洲区亚洲区| 欧美91视频| 亚洲精品第一| 国产亚洲人成a在线v网站| 国产96在线亚洲| 欧美+日本+国产+在线a∨观看| 一区在线免费观看| 婷婷五月色综合香五月| 国产日韩亚洲| 日韩福利一区| 午夜在线播放视频欧美| 国产日产高清欧美一区二区三区 | 日韩啪啪电影网| 久久久久久免费视频| 亚洲一区久久| 国产精品亚洲二区| 99热精品久久| 日韩免费精品| 成人福利视频| 亚洲v天堂v手机在线| 精品一区二区三区中文字幕视频 | 欧美亚洲精品在线| 婷婷综合福利| 久久亚洲人体| 伊人影院久久| 国产精品入口久久| 国产精品av久久久久久麻豆网| 综合激情网站| 国产一区二区精品久| 国产农村妇女精品一二区| 国产精品最新| 激情久久久久久久| 国产欧美日韩亚洲一区二区三区| 久久久国产亚洲精品| 亚洲精品国模| 亚洲va在线| 国产精品极品国产中出| 精品一区免费| 国产亚洲电影| 午夜av一区| 精品一区二区三区中文字幕视频 | 国产aⅴ精品一区二区四区| 欧美日韩国产亚洲一区| 久久99蜜桃| 国产一区91| 福利在线一区| 欧美一级网址| 国产精品三上| 福利片在线一区二区| 日韩精品一区二区三区中文在线 | 在线一区电影| 麻豆视频在线观看免费网站黄| 日韩精品a在线观看91| 欧美日韩一区二区综合| 久久中文字幕导航| 日本伊人午夜精品| 欧美另类专区| 日韩一区二区三区免费播放| 国产精品网站在线看| 亚洲综合色婷婷在线观看| 黄在线观看免费网站ktv| 日韩久久视频| 欧美精品97| 午夜性色一区二区三区免费视频| 日本不卡免费高清视频在线| 久久爱www.| 久久福利精品| 日韩一区欧美| 国产欧美高清视频在线| 久久一级电影| 国产区精品区| 日本亚洲欧美天堂免费| 91精品亚洲| 欧美aa在线视频| 综合激情视频| 91成人精品| 福利在线一区| 97久久亚洲| 免费人成在线不卡| 免费观看亚洲| 欧美成a人片免费观看久久五月天| 中国女人久久久| 蜜桃视频在线网站| 久久不见久久见免费视频7| 人人爽香蕉精品| 激情五月综合网| 日韩国产一区二区三区| 国产精品大片| 亚洲涩涩av| 亚洲精品成a人ⅴ香蕉片| 国产在线欧美| 日韩电影免费网站| 久久亚洲人体| 日韩av一级片| 午夜在线视频一区二区区别 | 日韩久久一区| 免费黄网站欧美| 男人的天堂久久精品| 在线视频观看日韩| 日本在线高清| 国产精品毛片久久| 麻豆成人av在线| 国产精品毛片久久久| 欧美日韩一区二区三区四区在线观看 | 日本视频在线一区| 久久在线视频免费观看| 欧美日韩国产在线观看网站| 日韩和的一区二在线| 精品国产黄a∨片高清在线| 国产日产高清欧美一区二区三区| 一区二区三区午夜视频| 日韩视频一区| 视频一区中文| 日韩激情一区| 欧美日韩精品一本二本三本| 99久久久久| 日韩免费av| 日韩免费高清| 国产 日韩 欧美 综合 一区| 欧美激情日韩| 韩国女主播一区二区三区| 精品中文字幕一区二区三区| 国产精品久久久久久久免费软件| 欧美亚洲福利| 日本不卡一二三区黄网| 日韩福利在线观看| 日韩二区三区在线观看| 日本中文字幕一区二区| 亚洲尤物av| 欧美日韩亚洲一区二区三区在线| 欧美日韩午夜| 国产调教一区二区三区| 欧美91在线| 粉嫩av一区二区三区四区五区 | 国产理论在线| 成人免费电影网址| 欧美日韩在线观看视频小说| 99国产精品视频免费观看一公开 | 国产精品视区| 综合亚洲视频| 91嫩草精品| 久久麻豆视频| 日韩欧美午夜| 婷婷激情图片久久| 亚洲精选91| 日韩高清在线一区| 91青青国产在线观看精品| 久久久久国产精品一区三寸| 黄色日韩精品| 亚洲理论在线| 欧美黄色一区| 成人午夜国产| 中文日韩欧美| 精品99在线| 久久国产中文字幕| 视频一区二区三区入口| 国产日韩三级| 一区二区精品伦理...| 日韩视频一区| 久久精品免费看| 欧美亚洲精品在线| 亚洲精品一级二级三级| 美女高潮久久久| 激情婷婷综合| 欧美久久香蕉| 日韩欧美自拍| 亚洲乱码一区| 老牛影视精品| 蜜臀av在线播放一区二区三区| 国产精一区二区| 久久久久一区| 天堂av一区|