(1)android:layout_gravity 和 android:gravity 的区别
比如说button: android:layout_gravity 表示按钮在界面上的位置。 android:gravity表示button上的字在button上的位置。
(2)其中,
android:divider[Drawable/Color]用于设置相邻两个列表项之间的分界线式样;
android:dividerHeight[dimension]用于设置相邻两个列表项之间的分界线高度;
android:entries[array resource]用于将静态数组中的内容直接填充到ListView列表中。
android:divider="#f9b68b" //分割线颜色
android:dividerHeight="1dp" //分割线边距
android:scrollbars="none" //不显示滚动条
android:fadingEdge="none" 去掉上边和下边黑色的阴影
进行上面的设置之后,ListView点击item时就没有任何现象了,
我在这里看了一篇别人博客对于LayoutParams 的解释,我觉的很到位,所以就继续拿来主义。
其实这个LayoutParams类是用于child view(子视图) 向 parent view(父视图)传达自己的意愿的一个东西(孩子想变成什么样向其父亲说明)其实子视图父视图可以简单理解成
一个LinearLayout 和 这个LinearLayout里边一个 TextView 的关系 TextView 就算LinearLayout的子视图 child view 。需要注意的是LayoutParams只是ViewGroup的一个内部类这里边这个也就是ViewGroup里边这个LayoutParams类是 base class 基类实际上每个不同的ViewGroup都有自己的LayoutParams子类
- //创建一个线性布局
- private LinearLayout mLayout;
- mLayout = (LinearLayout) findViewById(R.id.layout);
- //现在我要往mLayout里边添加一个TextView
- //你可能会想直接在布局文件里边配置不就O 了 那是 但是这里为了说明问题我们用代码实现
- TextView textView = new TextView(Activity01.this);
- textView.setText("Text View " );
- //这里请不要困惑这里是设置 这个textView的布局 FILL_PARENT WRAP_CONTENT 和在xml文件里边设置是一样的如
- //在xml里边怎么配置高宽大家都会的。
- //第一个参数为宽的设置,第二个参数为高的设置。
- LinearLayout.LayoutParams p = new LinearLayout.LayoutParams(
- LinearLayout.LayoutParams.FILL_PARENT,
- LinearLayout.LayoutParams.WRAP_CONTENT
- );
- //调用addView()方法增加一个TextView到线性布局中
- mLayout.addView(textView, p);
- //比较简单的一个例子
如果还不能理解下边在来一段直白的说明:
LayoutParams继承于Android.View.ViewGroup.LayoutParams.
LayoutParams相当于一个Layout的信息包,它封装了Layout的位置、高、宽等信息。假设在屏幕上一块区域是由一个Layout占领的,如果将一个View添加到一个Layout中,最好告诉Layout用户期望的布局方式,也就是将一个认可的layoutParams传递进去。
可以这样去形容LayoutParams,在象棋的棋盘上,每个棋子都占据一个位置,也就是每个棋子都有一个位置的信息,如这个棋子在4行4列,这里的“4行4列”就是棋子的LayoutParams。
但LayoutParams类也只是简单的描述了宽高,宽和高都可以设置成三种值:
1,一个确定的值;
2,FILL_PARENT,即填满(和父容器一样大小);
3,WRAP_CONTENT,即包裹住组件就好。
ViewGroup.getChildMeasureSpec(int spec, int padding, int childDimension)
参数:
spec 父窗口传递给子视图的大小和模式
padding 父窗口的边距,也就是xml中的android:padding
childDimension 子视图想要绘制的准确大小,但最终不一定绘制此值
MeasureSpec介绍及使用详解
http://zhujiao.iteye.com/blog/1851689一个MeasureSpec封装了父布局传递给子布局的布局要求,每个MeasureSpec代表了一组宽度和高度的要求。一个MeasureSpec由大小和模式组成。它有三种模式:
UNSPECIFIED(未指定),父元素不对子元素施加任何束缚,子元素可以得到任意想要的大小;
EXACTLY(完全),父元素决定自元素的确切大小,子元素将被限定在给定的边界里而忽略它本身大小;
AT_MOST(至多),子元素至多达到指定大小的值。
它常用的三个函数:
1.static int getMode(int measureSpec):根据提供的测量值(格式)提取模式(上述三个模式之一)
2.static int getSize(int measureSpec):根据提供的测量值(格式)提取大小值(这个大小也就是我们通常所说的大小)
3.static int makeMeasureSpec(int size,int mode):根据提供的大小值和模式创建一个测量值(格式)
/**
* @param spec 父View的详细测量值(MeasureSpec)
* @param padding 子view内外边距
*@param childDimension 子view预定的大小(LayoutParam.width或height)---最终不一定绘制该大小
*子布局大小需要由自身的layoutPrams属性和父View的MeasureSpec共同决定
*/
ViewGroup.getChildMeasureSpec(int spec, int padding, int childDimension);
MeasureSpec.makeMeasureSpec(int size,int mode);此处得到的即是spec
区别:
getChildMeasureSpec可以设置子View的内外边距。并且记录预定大小
若spec,padding均为0,则子布局为实际大小。
makeMeasureSpec(size,MeasureSpec.EXACTLY)得到的是size。
makeMeasureSpec(size,MeasureSpec.UNSPECIFIED)得到的是子布局的实际大小。
http://blog.csdn.net/lmj623565791/article/details/38339817/
ViewGroup的职能为:给childView计算出建议的宽和高和测量模式 ;决定childView的位置;为什么只是建议的宽和高,而不是直接确定呢,别忘了childView宽和高可以设置为wrap_content,这样只有childView才能计算出自己的宽和高。
View的职责,根据测量模式和ViewGroup给出的建议的宽和高,计算出自己的宽和高;同时还有个更重要的职责是:在ViewGroup为其指定的区域内绘制自己的形态。
关于getMeasuredHeight和getHeight区别
getMeasuredHeight:是用于测量的高度,也就是View实际的高度(先暂时这么记,后面还有一个显示出来的高度),getMeasuredHeight的值是在onMeasure方法里面通过setMeasuredDimension();
设置出来的。也就是说要在onMeasure方法之后调用,不能再之前,这样会得到0。
如果你的View没有设置setMeasuredDimension方法,而是android:layout_height="match_parent"
那么你的getMeasuredHeight就等于你手机屏幕的宽度,Log.i("yaoyan"," "+ getMeasuredWidth());
博主手机分辨率还是蛮高的,如果你设置的
android:layout_height="match_parent"
为200dp,那么打印出来的是像素你可以通过View.getResources().getDisplayMetrics().density*200
这样就可以转换为像素了。
getHeight:是指在屏幕上显示出来的高度(这里要强调一点就是不能再onCreate方法里面获得一个View的高度),这个方法得到的是View显示在桌面上的高度(跟前面测量的高度相对对应),因为View的onMeasure方法运行完之后还会运行一个onLayout方法,要等到onLayout运行完之后才能得到具体的值,这个方法是指View所在屏幕上的位置,通过View.layout(int Left,int Top,int Right,int Bottom)改变View在屏幕上的大小(这个方法只是改变形状上的大小,实际的View并没有改变)
实际上在当屏幕可以包裹内容的时候,他们的值相等,