学习笔记---常模糊的知识点

(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是常用的显示控件,默认背景是和系统窗口一样的透明色,如果给ListView加上背景图片,或者背景颜色时,滚动时listView会黑掉,
原因是,滚动时,列表里面的view重绘时,用的依旧是系统默认的透明色,颜色值为#FF191919,
要改变这种情况,只需要调用listView的setCacheColorHint(0),颜色值设置为0
或者xml文件中listView的属性 Android:cacheColorHint="#00000000"即可,
滚动时,重绘View的时候就不会有背景颜色。
 
android:listSelector="#00000000"

进行上面的设置之后,ListView点击item时就没有任何现象了,

android:listSelector="@null"不可以实现。
自定义listview的时候,当你不使用android:cacheColorHint=“#00000000”会出现下面选中一个空间黑色底色的情况,破坏整体美观度:
http://www.cnblogs.com/SharkBin/p/3714310.html

2017.10.12
http://blog.csdn.net/liuhaomatou/article/details/22899925

我在这里看了一篇别人博客对于LayoutParams 的解释,我觉的很到位,所以就继续拿来主义。

其实这个LayoutParams类是用于child view(子视图) 向 parent view(父视图)传达自己的意愿的一个东西(孩子想变成什么样向其父亲说明)其实子视图父视图可以简单理解成
一个LinearLayout 和 这个LinearLayout里边一个 TextView 的关系 TextView 就算LinearLayout的子视图 child view 。需要注意的是LayoutParams只是ViewGroup的一个内部类这里边这个也就是ViewGroup里边这个LayoutParams类是 base class 基类实际上每个不同的ViewGroup都有自己的LayoutParams子类


Java代码 :
  1.       //创建一个线性布局   
  2.        private LinearLayout mLayout;      
  3.        mLayout = (LinearLayout) findViewById(R.id.layout);      
  4.       //现在我要往mLayout里边添加一个TextView    
  5.      //你可能会想直接在布局文件里边配置不就O 了 那是 但是这里为了说明问题我们用代码实现   
  6.       TextView textView = new TextView(Activity01.this);      
  7.            textView.setText("Text View " );   
  8.            //这里请不要困惑这里是设置 这个textView的布局 FILL_PARENT WRAP_CONTENT 和在xml文件里边设置是一样的如   
  9.     
  10. //在xml里边怎么配置高宽大家都会的。   
  11.   //第一个参数为宽的设置,第二个参数为高的设置。   
  12.            LinearLayout.LayoutParams p = new LinearLayout.LayoutParams(      
  13.                    LinearLayout.LayoutParams.FILL_PARENT,      
  14.                    LinearLayout.LayoutParams.WRAP_CONTENT      
  15.            );      
  16.            //调用addView()方法增加一个TextView到线性布局中   
  17.            mLayout.addView(textView, p);      
  18.           //比较简单的一个例子  


如果还不能理解下边在来一段直白的说明:
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并没有改变) 


实际上在当屏幕可以包裹内容的时候,他们的值相等,


只有当view超出屏幕后,才能看出他们的区别:

getMeasuredHeight()是实际View的大小,与屏幕无关,

而getHeight的大小此时则是屏幕的大小。

当超出屏幕后,getMeasuredHeight()等于getHeight()加上屏幕之外没有显示的大小





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值