布局属性和优化
常用UI的布局
1.LinearLayout: 线性布局
用来控制其子View以水平和垂直方式展开
2.RelativeLayout: 相对布局
用来控制其子view以相对定位的方式进行布局显示
3.FrameLayout: 帧布局
每一个子view都代表一个画布,后面出现的会覆盖前面的画面
通过view的android:layout_gravity属性来指定子视图的位置
-
常用视图的属性:
1.视图的常用属性
image.png
内边距的属性:
data:image/s3,"s3://crabby-images/0a57d/0a57d4e94572ff9f961a3a37c487eb6c483d1667" alt=""
外边距的属性
data:image/s3,"s3://crabby-images/35c3c/35c3c60f36222fba91e397165e35870ccfca8f18" alt=""
只针对RelativeLayout:
相对兄弟视图定位
同方向对齐属性:
data:image/s3,"s3://crabby-images/e1cc5/e1cc57a9a02903f3706b42dfd749fc7d0dc69380" alt=""
反对向对齐属性:
data:image/s3,"s3://crabby-images/9b670/9b670d732cf20bb15d999ca466cf7c2b1a46f635" alt=""
相对于父视图:
data:image/s3,"s3://crabby-images/a0803/a080316293d4f2e96f38ba89be2d5ae1aabc5cf0" alt=""
对于权重:
data:image/s3,"s3://crabby-images/d57c5/d57c592662d941fa30aabc4e4ebc623f82735c7b" alt=""
ListView的理解使用
data:image/s3,"s3://crabby-images/1e422/1e422b9d30461ee2733c3bc00bcc24b1f47dc161" alt=""
data:image/s3,"s3://crabby-images/eafef/eafef2ee5892b9490542a121cedf94ec6a886708" alt=""
经常使用的适配器:
ArrayAdaptater
data:image/s3,"s3://crabby-images/84147/84147159b8cea8f8c170bd689496380cfabc2de3" alt=""
data:image/s3,"s3://crabby-images/6db0e/6db0e3c628a31b936adf779a8a6d3ac03c429b1f" alt=""
data:image/s3,"s3://crabby-images/b9441/b9441661ff09d0d0668bf903ac7f62619337394e" alt=""
data:image/s3,"s3://crabby-images/d74d9/d74d909f09684ea83e80e37476801241fafa1022" alt=""
data:image/s3,"s3://crabby-images/ee7c7/ee7c7b66282eb374904d942752c2542531b4a73f" alt=""
BaseAdapter: 需要重写四个方法:
data:image/s3,"s3://crabby-images/dab34/dab348818c412d50eb7115256afcd6c587c3e649" alt=""
四个方法:
1.getCount() : 得到集合的个数
2.getItem() : 根据position得到对应的数据对象
3.getItemId(): 返回对应数据的ItemID
4.getView(): 得到Item视图对象
其中 convertView可以复用
为null 没有复用,我们必须加载布局,并赋值,不为null,直接用此视图对象
后面:找到子view找到对应的数据,设置数据 给listView的Item点击监听
listView.setOnItemClickListenner(listener)
item的长按监听
listView.setOnLongItemClickListener(listener)
--------------优化--------------
第0层:
不优化
每次都会执行getView(),都会执行 convertView=View.inflate(R.layout.XXX);
问题:效率太低,再快速滑动时会有卡顿,在数据多的时候甚至内存溢出
第1层:
复用convertView
if(convertView==null){
convertView=View.inflate(R.layout.XXX); //n+1
}
问题: 每次执行getview()都需要执行convertView.findViewByid()得到子view
第二层:
使用ViewHolder,减少findViewByid()的次数 减到n+1次
ViewHolder holder=null;
if(convertView==null){
convertView=View.inflate(R.layout.XXX); //n+1
holder=new ViewHolder();
holder.imageView=(ImageView)convertView.findViewById(xxx);
holder.textView=(TextView)convertView.findViewById(yyy);
convertView.setTag(holder);
}else{
holder=(ViewHolder)convertView.getTag();
}
person p= data.get(position);//之前创建的类
holder.imageView.setImageResource(p.getIco());
holder.textView.setText(p.getName());
static class ViewHolder(){
ImageView imageView;
TextView textView;
}
问题1:
对于联网获取列表数据,如果数据量太大(比如超过100000)条甚至更多一次取出来显示,太慢太消耗流量
问题2.对于联网获取列表数据,如果包含图片数据,每次请求获取显示,太慢太耗流量
第三层:
图片三级缓存处理(LRu算法)
1.内存缓存,优先加载,速度最快
2.本地缓存,次优先加载。速度稍快
3.网络缓存,最后加载,速度由网络速度决定(浪费流量)
第4层:
对数据列表进行分页加载显示
1.自己做:通过Scroll监听
listView。setOnScrollListener(scrollListenter),当到达底部时加载下一页列表数据并显示
2.使用第三方开源框架:Aandroid-PullToRefresh或其他
Style和Theme
1.style: 多个视图标签属性的集合
好处:复用标签属性
目标: 布局文件中的视图标签
Theme: 本质也是style
好处:复用标签属性
目标:功能清单文件中整个应用Activity