08 ListView 优化的例子
package com.fmy.homework; import java.util.List; import com.fmy.homework.httputil.HttpUtil;
import com.fmy.homework.myadapter.MyAdpter;
import com.fmy.homework.parsexml.ParseXmlUtil; import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemLongClickListener;
import android.widget.ListView;
import android.widget.TextView; public class MainActivity extends Activity { private ListView lv;
private TextView tv; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv = (ListView) findViewById(R.id.lv);
tv = (TextView) findViewById(R.id.tv);
//设置当List没有条目显示此控件 如果有隐藏此控件
//注意头尾视图不包含在内 意思说哪怕有头尾视图但没有实际条目依然为空
lv.setEmptyView(tv);
//创建一个布局填充器
LayoutInflater inflater = getLayoutInflater();
//把布局文件填充为一个View
View head = inflater.inflate(R.layout.head, null);
//把布局文件填充为一个View
View foot = inflater.inflate(R.layout.foot, null); //添加头试图
lv.addHeaderView(head); //添加尾视图
lv.addFooterView(foot);
//启动异步任务
new MyAsync().execute("http://c.m.163.com/nc/article/list/T1348648517839/0-20.html");
} class MyAsync extends AsyncTask<String, Void, List<String>>{ @Override
protected List<String> doInBackground(String... params) {
String json = HttpUtil.conn(params[0]); return ParseXmlUtil.parse(json);
} @Override
protected void onPostExecute(List<String> result) {
super.onPostExecute(result);
MyAdpter myAdpter = new MyAdpter(result, MainActivity.this);
lv.setAdapter(myAdpter);
//如果lv中某个条目设置setOnClickListener
//那么本方式和长按方法不生效
lv.setOnItemClickListener(new OnItemClickListener() {
/**
* 第一个参数 ListView
* 第二个参数当前条目的View
* 当前条目的位置包括头试图的位置 比如说头试图(headView) 的值是0 调用的是适配器中:getItem
* 当前实际内容条目的ID 如果直接返回的是postion的话 那么返回的是实际条目内容地址
* 接上:不包括头试图和尾视图 两者的返回值是 -1 调用的是适配器中:getItemId
*/
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) { }
});
//按下的时间是0.18s 触发
lv.setOnItemLongClickListener(new OnItemLongClickListener() {
/**
* 第一个参数 ListView
* 第二个参数当前条目的View
* 当前条目的位置包括头试图的位置 比如说头试图(headView) 的值是0 调用的是适配器中:getItem
* 当前实际内容条目的ID 如果直接返回的是postion的话 那么返回的是实际条目内容地址
* 接上:不包括头试图和尾视图 两者的返回值是 -1 调用的是适配器中:getItemId
*/
/*
* 这里的返回值 :如果是false 长按之后还会触发短按监听
* */
@Override
public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
return false;
}
}); } } }
package com.fmy.homework.httputil; import java.io.IOException; import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.params.CoreConnectionPNames;
import org.apache.http.util.EntityUtils;
import org.json.JSONObject; public class HttpUtil { static public String conn(String url){
HttpClient client = new DefaultHttpClient();
client.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT, 1000*5);
HttpGet get = new HttpGet(url);
try {
HttpResponse response = client.execute(get);
if (response.getStatusLine().getStatusCode()==200){
return EntityUtils.toString(response.getEntity());
}
} catch (Exception e) {
e.printStackTrace();
}
return url;
}
}
package com.fmy.homework.myadapter; import java.util.List; import com.fmy.homework.R; import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView; public class MyAdpter extends BaseAdapter { //每个item中要显示的数据
List<String> list = null;
//传入的上下文 方便后面用布局填充器
Context context = null; public MyAdpter(List<String> list, Context context) {
super();
this.list = list;
this.context = context;
} // 返回列表中所有数量
// 如果设置为1 那么列表将只有一个item (只有一行)
@Override
public int getCount() {
// TODO Auto-generated method stub
return list.size();
} // 返回每个显示内容的位置 如果同时设置头(headView)和尾试图(footView)
// 也包含在内 所以 头的数值为:0 总大小比getCount+2
@Override
public Object getItem(int position) {
return position;
} // 返回内容的每个条目的id 如果没有直接返回 positon那么将直接返回实际内容
// 头(headView)和尾试图(footView) 返回-1 其他正常显示
@Override
public long getItemId(int position) {
return position;
} /*
* position 实际内容位置(不包含头尾): convertView 每个条目的缓存 parent指代listView
*/
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = null;
viewHold hold =null;
// 判断缓存是否为空
if (convertView == null) {
//生成布局填充器
LayoutInflater Inflater = LayoutInflater.from(context);
//用填充器生成一个view对象
/**
* 第一个参数 :需要从布局文件转化为view的id
* 第二个参数:ListView对象
* 第三个参数:是否追加 填充对象的父级 如果为true 生成的条目将会有两个布局(ListView 转化的布局文件) 会直接奔溃
*/
view = Inflater.inflate(android.R.layout.simple_spinner_item, parent,false); //生成一个存放view子空间的id 省去下次遍历id带来的消耗
hold = new viewHold(); //给hold放入子控件对象
hold.tv = (TextView) view; //将hold装入view中
view.setTag(hold);
}else{
//如果存在缓存 从缓存中拿出即可
view = convertView;
//拿出存放控件id的类
hold = (viewHold) view.getTag();
} //设置样式
hold.tv.setText(list.get(position));
return view;
} // 保存缓存item子控件的id
// 到用时候不用重新findView(此方法遍历整个id文件比较浪费资源)
class viewHold {
TextView tv;
}
}
package com.fmy.homework.parsexml; import java.util.ArrayList;
import java.util.List; import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject; public class ParseXmlUtil { static public List<String> parse(String json){
List<String> list= new ArrayList<String>();
try {
JSONObject root = new JSONObject(json);
JSONArray jsonArray = root.getJSONArray("T1348648517839");
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonObject = jsonArray.getJSONObject(i);
String string = jsonObject.getString("title");
list.add(string);
}
return list;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}
08 ListView 优化的例子的更多相关文章
- 08 ListView 优化
ListVie的优化 1 固定ListView长宽高 如下图在清单文件中: <ListView android:id="@+id/lv" android:layout_wid ...
- listview优化 汇总
1,listview加载性能优化ViewHolder 转自: http://blog.csdn.net/jacman/article/details/7087995 在android开发中Listvi ...
- Android——ListView优化
1.ListView基本概念 列表显示需要三个元素: ListView:用来展示列表的View. 适配器:用来把数据映射到ListView上 数据:具体的将被映射的字符串,图片或基本组件 适配器类型分 ...
- Adaptert Listview 优化
这次是关于Listview的优化的,之前一直采用愚蠢的方式来使用listview,出现的情况就是数据多的话下拉的时候会出现卡顿的情况,内存占用多.所以学习了关于listview的优化,并且这也是普遍使 ...
- Android 常驻与很驻型广播的差别,及ListView优化,Android新手基本知识巩固
1.常驻型广播 常驻型广播,当你的应用程序关闭了,假设有广播信息来,你写的广播接收器相同的能接受到. 他的注冊方式就是在你的应用程序中的AndroidManifast.xml进行注冊. 通常说这样 ...
- sql优化经典例子
场景 我用的数据库是mysql5.6,下面简单的介绍下场景 课程表 create table Course( c_id int PRIMARY KEY, name varchar(10) ) 数据10 ...
- 内存泄露--contentView缓存使用与ListView优化
引起Android内存泄露有很多种原因,下面罗列了一些问题,以后会一一解决 1.构造Adapter时没有使用缓存convertView(衍生出ListView优化问题) 2.查询数据库游标没有关闭 3 ...
- Android零基础入门第43节:ListView优化和列表首尾使用
原文:Android零基础入门第43节:ListView优化和列表首尾使用 前面连续几期都在学习ListView的各种使用方法,如果细心的同学可能会发现其运行效率是有待提高的,那么本期就来一起学习有哪 ...
- Android开发之ListView详解 以及简单的listView优化
ListView列表视图 最常用的控件之一,使用场景例如:微信,手机QQ等等. android:divider:每个item之间的分割线,可以使用图片或者色值. android:dividerHeig ...
随机推荐
- bzoj4596[Shoi2016]黑暗前的幻想乡 Matrix定理+容斥原理
4596: [Shoi2016]黑暗前的幻想乡 Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 464 Solved: 264[Submit][Sta ...
- Xtrabackup2.4.8备份、还原、恢复Mysql5.7.19实操
环境:CentOS 6.7 + Mysql 5.7.19 + Xtraback 2.4.8 innobackupex常用参数: --user=USER 指定备份用户,不指定的话为当前系统用户 --p ...
- thymeltesys-基于Spring Boot Oauth2的扫码登录框架
thymeltesys thymelte是一个基于Spring Boot Oauth2的扫码登录框架,使用PostgreSQL存储数据,之后会慢慢支持其他关系型数据库.即使你不使用整个框架,只使用其中 ...
- mysql免安装版下载及配置教程
第一步:下载 下载地址:http://dev.mysql.com/downloads/mysql/ 滚动到下方就能看到了,根据自己的需求下载: 我的电脑为64为的所以下载的为 Windows (x86 ...
- 谷歌发布 TensorFlow Lite [官方网站,文档]
机器学习社区:http://tensorflow123.com/ 简介 TensorFlow Lite TensorFlow Lite 是 TensorFlow 针对移动和嵌入式设备的轻量级解决方案. ...
- Spring中@Autowired与@Resource的区别
1.@Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上. 2.@Autowired默认按类型装配(这个注解是属业spring的),默认情况下必 ...
- Java Web -【分页功能】详解
分页简介 分页功能在网页中是非常常见的一个功能,其作用也就是将数据分割成多个页面来进行显示. 使用场景: 当取到的数据量达到一定的时候,就需要使用分页来进行数据分割. 当我们不使用分页功能的时候,会面 ...
- Uncaught RangeError: Maximum call stack size exceeded-栈溢出
在看函数的arguments对象的时候,用了arguments.callee写了一个递归. 当执行函数func(99999)时候,直接报错了,一看,原来栈溢出了. 当执行递归运算的时候,忘记加点判断条 ...
- Maven实现多环境打包
在开发的过程中,经常需要面对不同的运行环境(开发环境.测试环境.生产环境.内网环境.外网环境等等),在不同的环境中,相关的配置一般不一样,比如数据源配置.日志文件配置.以及一些软件运行过程中的基本配置 ...
- ubuntu15.10 opencv3.1 安装配置codeblocks
安装codeblocks: sudo add-apt-repository ppa:damien-moore/codeblocks-stable // 添加codeblocks的ppa sudo ap ...