软件编程
位置:首页>> 软件编程>> Android编程>> Android编程重写ViewGroup实现卡片布局的方法

Android编程重写ViewGroup实现卡片布局的方法

作者:xurong  发布时间:2022-02-14 13:08:01 

标签:Android,ViewGroup

本文实例讲述了Android编程重写ViewGroup实现卡片布局的方法。分享给大家供大家参考,具体如下:

实现效果如图

Android编程重写ViewGroup实现卡片布局的方法

实现思路

1. 重写onMeasure(int widthMeasureSpec, int heightMeasureSpec)设置每个子View的大小

2. 重写onLayout(boolean changed, int l, int t, int r, int b) 设置每个子View的位置

第一步:新建FlowLayout继承ViewGroup


package com.rong.activity;
import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
import android.view.ViewGroup;
/**
* 卡片布局
*
* @author 徐荣
*
*/
public class FlowLayout extends ViewGroup {
 public FlowLayout(Context context, AttributeSet attrs) {
   super(context, attrs);
 }
 @Override
 protected void onLayout(boolean changed, int l, int t, int r, int b) {
   // 当前子View的数量
   int childSize = getChildCount();
   // 获取行宽
   int lineWidth = getMeasuredWidth();
   // 当前是第几行
   int lines = 1;
   // 当前累加的行宽
   int nowLineWidth = 0;
   for (int i = 0; i < childSize; i++) {
     View view = getChildAt(i);
     // 子View的宽度
     int childWidth = view.getMeasuredWidth();
     // 子View的高度
     int childHeight = view.getMeasuredHeight();
     // 如果当前的nowLineWidth+childWidth>= lineWidth 则换行
     if (nowLineWidth + childWidth >= lineWidth) {
       nowLineWidth = 0;
       lines = lines + 1;
     }
     // 设置子View的位置
     view.layout(nowLineWidth, childHeight * (lines - 1), nowLineWidth + childWidth, childHeight * lines);
     nowLineWidth = nowLineWidth + childWidth;
     // 如果nowLineWidth >= lineWidth 则换行
     if (nowLineWidth >= lineWidth) {
       nowLineWidth = 0;
       lines = lines + 1;
     }
   }
 }
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
   super.onMeasure(widthMeasureSpec, heightMeasureSpec);
   // 设置自己View的大小
   setMeasuredDimension(widthMeasureSpec, heightMeasureSpec);
   for (int i = 0; i < getChildCount(); i++) {
     View view = getChildAt(i);
     // 设置每个子View的大小
     view.measure(view.getMeasuredWidth(), view.getMeasuredHeight());
   }
 }
}

第二步:新建布局文件


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:background="@android:color/black"
 android:orientation="vertical" >
 <com.rong.activity.FlowLayout
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:background="#ffffff" >
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Apple" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Button" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Cup" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Double" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Ear" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Flower" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Game" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="Hotdog" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="interseting" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="joker" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="king" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="mother" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="lost" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="noting" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="orange" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="poker" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="qustion" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="ring" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="string" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="type" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="unit" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="vertion" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="west" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="x" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="young" />
   <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="zip" />
 </com.rong.activity.FlowLayout>
</RelativeLayout>

运行!

希望本文所述对大家Android程序设计有所帮助。

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com