流式布局

//效果(https://img-blog.csdn.net/20171130152450097?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvQWJ5c3NhbE1hZ2lj/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
//view

package com.example.liushi;

import android.content.Context;
import android.graphics.Canvas;
import android.util.AttributeSet;
import android.view.View;
import android.view.ViewGroup;

/**
 * Created by Administrator on 2017/11/30 0030.
 */

public class liu extends ViewGroup {
    public liu(Context context) {
        super(context);
    }

    public liu(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public liu(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    //测量
    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        //测量子view
      measureChildren(widthMeasureSpec,heightMeasureSpec);

    }
     //绘制的方法
    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
    }

    //用来确定子view的位置
    @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b) {

        //初始化子view的宽高
     int wid=0;
     int hei=0;

     //得到子view的个数
     int childcount=getChildCount();


     for(int i=0;i<childcount;i++) {

         //得到这个viewgroup里面的每一个子view
         View childView=getChildAt(i);

         //得到每一个子view的宽高
         int width=childView.getMeasuredWidth();
         int height=childView.getMeasuredHeight();

        //确定子view的高度
         childView.layout(wid,hei,wid+width,hei+height);

         //累加所有子view宽高
         wid+=width;
         hei+=height;

     }

    }
}

//mainactivty

package com.example.liushibuju;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

public class liushibuju extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_liushibuju);
    }
}

//xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" tools:context="com.example.liushibuju.liushibuju">

   <com.example.liushibuju.view.liu
       android:layout_width="wrap_content"
       android:layout_height="wrap_content">
       <TextView
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="心火烧"/>
       <TextView
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="心火烧"/>
       <TextView
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="心扉呀"/>
   </com.example.liushibuju.view.liu>

</android.support.constraint.ConstraintLayout>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值