1.先解决流式布局的FrameLayout,以方便拉入布局界面
public class FlowLayout extends FrameLayout {
private final static int H_DISTANCE=20;//水平间距20
private final static int V_DISTANCE=20;//竖直间距20
public FlowLayout(@NonNull Context context) {
super(context);
}
public FlowLayout(@NonNull Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
}
public FlowLayout(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
public void addTextView(String keys){
//加载字体布局
TextView textView = (TextView) View.inflate(getContext(), R.layout.flow_item, null);
textView.setText(keys);
//布局宽高自适应
LayoutParams params = new LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
textView.setLayoutParams(params);//控件设置上布局出参数
addView(textView);
}
@Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
super.onLayout(changed, left, top, right, bottom);
int width=getWidth();//获取本空间宽度,用于计算行数
int row=0;//行数
int disWidth=H_DISTANCE;//子控件左边的左表
for (int i = 0; i < getChildCount(); i++) {
View view=getChildAt(i);
int viewWidth = view.getWidth();
int viewHeight = view.getHeight();
Log.i("dt", "textHeight "+viewHeight);
if (disWidth&