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 优化的例子的更多相关文章

  1. 08 ListView 优化

    ListVie的优化 1 固定ListView长宽高 如下图在清单文件中: <ListView android:id="@+id/lv" android:layout_wid ...

  2. listview优化 汇总

    1,listview加载性能优化ViewHolder 转自: http://blog.csdn.net/jacman/article/details/7087995 在android开发中Listvi ...

  3. Android——ListView优化

    1.ListView基本概念 列表显示需要三个元素: ListView:用来展示列表的View. 适配器:用来把数据映射到ListView上 数据:具体的将被映射的字符串,图片或基本组件 适配器类型分 ...

  4. Adaptert Listview 优化

    这次是关于Listview的优化的,之前一直采用愚蠢的方式来使用listview,出现的情况就是数据多的话下拉的时候会出现卡顿的情况,内存占用多.所以学习了关于listview的优化,并且这也是普遍使 ...

  5. Android 常驻与很驻型广播的差别,及ListView优化,Android新手基本知识巩固

    1.常驻型广播  常驻型广播,当你的应用程序关闭了,假设有广播信息来,你写的广播接收器相同的能接受到.  他的注冊方式就是在你的应用程序中的AndroidManifast.xml进行注冊. 通常说这样 ...

  6. sql优化经典例子

    场景 我用的数据库是mysql5.6,下面简单的介绍下场景 课程表 create table Course( c_id int PRIMARY KEY, name varchar(10) ) 数据10 ...

  7. 内存泄露--contentView缓存使用与ListView优化

    引起Android内存泄露有很多种原因,下面罗列了一些问题,以后会一一解决 1.构造Adapter时没有使用缓存convertView(衍生出ListView优化问题) 2.查询数据库游标没有关闭 3 ...

  8. Android零基础入门第43节:ListView优化和列表首尾使用

    原文:Android零基础入门第43节:ListView优化和列表首尾使用 前面连续几期都在学习ListView的各种使用方法,如果细心的同学可能会发现其运行效率是有待提高的,那么本期就来一起学习有哪 ...

  9. Android开发之ListView详解 以及简单的listView优化

    ListView列表视图 最常用的控件之一,使用场景例如:微信,手机QQ等等. android:divider:每个item之间的分割线,可以使用图片或者色值. android:dividerHeig ...

随机推荐

  1. zoj2112 树状数组+主席树 区间动第k大

    Dynamic Rankings Time Limit: 10000MS   Memory Limit: 32768KB   64bit IO Format: %lld & %llu Subm ...

  2. 用ECMAScript4 ( ActionScript3) 实现Unity的热更新 -- 操作符重载和隐式类型转换

    C#中,某些类型会定义隐式类型转换和操作符重载.Unity中,有些对象也定义了隐式类型转换和操作符重载.典型情况有:UnityEngine.Object.UnityEngine.Object的销毁是调 ...

  3. sharepoint环境安装

    SharePoint 2013 测试环境安装配置指南 软件版本 Windows Server 2012 标准版 SQL Server 2012 标准版 SharePoint Server 2013 企 ...

  4. Cisco 的基本配置实例之六----常排错命令--关闭提示

    TEST#terminal monitor # 排除网络故障以前,请打开这一命令以便实时的接收到交换机的提示信息. TEST# TEST#sh run #显示所有的配置清单,可将这些配置保存成文本作为 ...

  5. Linux系统之TroubleShooting(故障排除)(转)

    尽管Linux系统非常强大,稳定,但是我们在使用过程当中,如果人为操作不当,仍然会影响系统,甚至可能使得系统无法开机,无法运行服务等等各种问题.那么这篇博文就总结一下一些常见的故障排除方法,但是不可能 ...

  6. Redis持久化的两种方式(RDB和AOF)

    redis提供了两种持久化的方式,分别是RDB(Redis DataBase)和AOF(Append Only File). RDB,简而言之,就是在不同的时间点,将redis存储的数据生成快照并存储 ...

  7. swing JTable

    JTable 实例 import java.awt.Dimension; import java.awt.GridBagConstraints; import java.awt.GridBagLayo ...

  8. docker volume创建、备份、nfs存储

    docker存储volume #环境 centos7.4 , Docker version 17.12.0-ce docker volume创建.备份.nfs存储 #docker volume 数据存 ...

  9. 《读书报告 -- Elasticsearch入门 》--简单使用(2)

    <读书报告 – Elasticsearch入门 > ' 第四章 分布式文件存储 这章的主要内容是理解数据如何在分布式系统中存储. 4.1 路由文档到分片 创建一个新文档时,它是如何确定应该 ...

  10. MySQL系列教程(一)

    摘要 MySQL的最初的核心思想,主要是开源.简便易用.其开发可追溯至1985年,而第一个内部发行版本诞生,已经是1995年.到1998年,MySQL已经可以支持10中操作系统了,其中就包括win平台 ...