实例化布局

同其他布局一样,new 一个根布局出来用来放置控件

ConstraintLayout layout = new ConstraintLayout(mContext);

控件定位约束

控件的定位和约束控制需要借助 ConstraintLayout.LayoutParams 来设置,在设置约束时,要知道所参考的控件的 ID 值,如果是自定义的控件,记得给控件加上 setId()

定位参考父布局

首先要拿到根布局的ID值,在xml中我们直接使用 parent 在代码里,也有相对应的ID值
ConstraintLayout.LayoutParams.PARENT_ID

ConstraintLayout.LayoutParams layoutParams = new ConstraintLayout.LayoutParams(ConstraintLayout.LayoutParams.WRAP_CONTENT, ConstraintLayout.LayoutParams.WRAP_CONTENT);
layoutParams.startToStart = ConstraintLayout.LayoutParams.PARENT_ID;
layoutParams.endToEnd = ConstraintLayout.LayoutParams.PARENT_ID;
layoutParams.topToTop = ConstraintLayout.LayoutParams.PARENT_ID;

参考代码添加的控件

以下是伪代码,只作说明怎么设置参考的id值,完整代码在另一篇 通过代码添加和调整布局控件

int id = 1;   
//添加一个TextView
TextView textView = new TextView(context);
textView.setId(id);
id++;
textView = new TextView(context);
textView.setId(id);
//设置定位
layoutParams.topToBottom = id - 1;
layoutParams.topMargin = 9;

返回定义好的布局

layout.getRootView() 即可拿到我们设置好的布局

return layout.getRootView();

完整代码参考

ConstraintLayout layout = new ConstraintLayout(mContext);
TextView textView = new TextView(mContext);
textView.setTextAlignment(View.TEXT_ALIGNMENT_CENTER);
textView.setText(String.valueOf(mList.get(i)));
textView.setTextSize(16);
textView.setTypeface(Typeface.DEFAULT_BOLD);
textView.setPadding(5, 9, 5, 9);
ConstraintLayout.LayoutParams layoutParams = new ConstraintLayout.LayoutParams(ConstraintLayout.LayoutParams.WRAP_CONTENT, ConstraintLayout.LayoutParams.WRAP_CONTENT);
layoutParams.startToStart = ConstraintLayout.LayoutParams.PARENT_ID;
layoutParams.endToEnd = ConstraintLayout.LayoutParams.PARENT_ID;
layoutParams.topToTop = ConstraintLayout.LayoutParams.PARENT_ID;
layout.addView(textView, layoutParams);
return layout.getRootView();

TextView设置加粗

这个不怎么用,一直找不到方法,最后发现是放在 Typeface 里,提醒一下有需要的朋友

textView.setTypeface(Typeface.DEFAULT_BOLD);
                    实例化布局,同其他布局一样,new 一个根布局出来用来放置控件。控件的定位和约束控制需要借助  `ConstraintLayout.LayoutParams` 来设置,在设置约束时,要知道所参考的控件的 ID 值,如果是自定义的控件,记得给控件加上 `setId()` 。定位参考父布局,首先要拿到根布局的ID值,在xml中我们直接使用 parent 在代码里,也有相对应的ID值`ConstraintLayout.LayoutParams.PARENT_ID`。
				
发生场景:mapper层方法传2个参数,默认一个参数可以不需要@Param,但传多个参数必须指定@Param(“别名”) 说明:该问题出错在mapper层与xml层的参数设置问题 文章目录第一种情况:mapper层方法缺少@Param注解第二种情况:传2个参数都是对象的时候,而不是简单地string、int等等 第一种情况:mapper层方法缺少@Param注解 第二种情况:传2个参数都是对象的时候,而不是简单地string、int等等 出错原因:对象具体的xx属性没加对象名 出错代码: 正确代码: public abstract class BaseDialog extends Dialog { protected ConstraintLayout mRootView; protected View mContentView; private boolean mT...
一般来说,做android开发,用xml布局比较多,相对于用代码布局还是多一些,但是也有一些场景需要用到代码动态添加布局,一些不确定的场景就需要了。主要代码如下 实现效果如下图所示:
ConstraintLayout.LayoutParams params = new ConstraintLayout.LayoutParams(width,height); holder.catView.setLayoutParams(paramsView); 但是有个问题,这样修改完父布局后,子布局与...
0、ContraintLayout约束布局) (约束布局ConstraintLayout 类似于 (相对布局)RelativeLayout,但约束布局比相对布局更灵活,性能更出色。而且ContraintLayout可以按照比例约束控件位置和尺寸,能够更好地适配屏幕不同的机型。 1、添加依赖 需要在app/build.gradle文件中添加ContraintLayout的依赖 implementation ‘com.android.support.constraint:constraint-la
android.support.constraint.ConstraintLayout记录一下:1. android.support.constraint.ConstraintLayout 1.1.x 以上才有百分比属性,否则报错  app:layout_constraintWidth_percent="0.5"app:layout_constraintHeight_percent="0.5"
本文根据本人学习和使用记录的内容。 ConstraintLayout,比较牛逼的一种布局,结合了其他几种布局的优点,也可以看做RelativeLayout的升级版。 使用ConstraintLayout需要引入: implementation 'com.android.support.constraint:constraint-layout:1.1.3' 首先很重要也是很基础的几个属性 app:...
感觉你这个错误应该是依赖添加的方式不对,看提示是说版本号没认到。你的AndroidStudio应该是最近新版的吧?好像依赖的添加方式有点不一样,你可搜索一下你的版本看下和之前有什么不同再试下。 没看到你的完整项目架构,不好给出建议。 官方github:https://github.com/lecho/hellocharts-android下面有实例你可以参考下