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 ...
随机推荐
- 深度学习 Fine-tune 技巧总结
深度学习中需要大量的数据和计算资源(乞丐版都需要12G显存的GPU - -)且需花费大量时间来训练模型,但在实际中难以满足这些需求,而使用迁移学习则能有效 降低数据量.计算量和计算时间,并能定制在新场 ...
- TensorFlow官方文档
关于<TensorFlow官方文档> <TensorFlow官方文档>原文地址:http://devdocs.io/tensorflow~python/ ,本次经过W3Csch ...
- linux下磁盘分区详解 图文(fdisk;mkfs)
linux分区不同于windows,linux下硬盘设备名为(IDE硬盘为hdx(x为从a-d)因为IDE硬盘最多四个,SCSI,SATA,USB硬盘为sdx(x为a-z)),硬盘主分区最多为4个,不 ...
- centos7.2中文乱码解决办法
centos7.2 中文乱码解决办法 1.查看安装中文包: 查看系统是否安装中文语言包 (列出所有可用的公共语言环境的名称,包含有zh_CN) # locale -a |grep "zh_C ...
- js 删除字符串中所有空格
//去除头尾和中间空格,制表符 function trimSpaces(Str){ var ResultStr = ""; ...
- day07 Cookie 和 Session(非常重要)
day07 Cookie 和 Session 1. 会话技术 2. cookie 的方法和 cookie 案例-显示用户上次访问网站的时间 3. cookie 的细节 - 删除 cookie 4. S ...
- 全局变量&局部变量,global&nonlocal
###全局变量与局部变量 1.函数内部的变量名如果第一次出现,且出现在=前面,即被视为定义一个局部变量,不管全局域中有没有用到该变量名,函数中使用的将是局部变量 2.函数内部的变量名如果第一次出现,且 ...
- Python中如何自定义一个计时器
import time as t class MyTimer(): # 初始化构造函数 def __init__(self): self.prompt = "未开始计时..." s ...
- centos6.8下weblogic12c静默安装
环境: centos6.8 无桌面环境 jdk1.7.0_25 关闭iptables.selinux 安装前准备: 1.新建weblogic用户,设置weblogic密码 useradd weblog ...
- 利用Python进行数据分析——Ipython
利用Python进行数据分析--Ipython 一.Ipython一些常用命令 1.TAB自动补全 2.变量+? 显示相关信息 3.函数名+??可以获取函数的代码 4.使用通配符* np.load? ...