当前位置: 首页 > news >正文

网站开发 需要用到什么软件网站访问统计报告模板

网站开发 需要用到什么软件,网站访问统计报告模板,长春网站优化平台,wordpress feed插件前言#xff1a;对于listView的BaseAdapter的派生#xff0c;难度比较大。最难理解的莫过于getView(int position, View convertView, ViewGroup parent)这个函数是如何产生每条记录的#xff0c;有些博客中利用holderView#xff0c;有些博客却没有用#xff0c;种种方法… 前言对于listView的BaseAdapter的派生难度比较大。最难理解的莫过于getView(int position, View convertView, ViewGroup parent)这个函数是如何产生每条记录的有些博客中利用holderView有些博客却没有用种种方法之间有什么异同今天我们就来揭开这个绘制ITEM机制的面纱。 本篇借助《PullToRefresh使用详解(二)---重写BaseAdapter实现复杂XML下拉刷新》的例子。所以本篇对于代码的讲解就比较粗略如果有读者对于如何重写BaseAdapter不太熟悉的话请先移步看看这篇文章然后再回来这里相信会有不一样的收获。 一、ConvertView回收机制 工作原理: 1、ListView 针对List中每个item要求 adapter “给我一个视图” (getView)。 2、一个新的视图被返回并显示 如果我们有上亿个项目要显示怎么办为每个项目创建一个新视图NO!这不可能 实际上Android为你缓存了视图。Android中有个叫做Recycler的构件下图是他的工作原理 如果你有10亿个项目(item)其中只有可见的项目存在内存中其他的在Recycler中。 ListView先请求一个type1视图(getView)然后请求其他可见的项目。convertView在getView中是空(null)的。 当item1滚出屏幕并且一个新的项目从屏幕低端上来时ListView再请求一个type1视图。convertView此时不是空值了它的值是item1。你只需设定新的数据然后返回convertView不必重新创建一个视图。   以上摘自《ListView中getView的原理如何在ListView中放置多个item》 也就是说 1、android的listView在初始化的时候如上面这个列表整个屏幕只能放下7个item那么listView在初始化时就会只创建7个view对于这些view也就是参数中的convertView。 2、那问题来了当继续网上滑动item1消失了而item8出来了。那系统还是为item8重新创建一个新的convertView吗另一个问题,item1的convertView去哪了销毁回收资源还是重新利用如果你是系统设计者你会怎么做大家想想如果为每个要显示的item都创建新convertView是不是太浪费了况且对于item1的convertView已经没用了我们何不把它拿来给item8用。对系统就是这样做的这就是convertView的回收机制。就是将那些不再被用的ITEM的convertView重新给即将显示的ITEM使用的机制 二、例子 先给大家看一下单个ITEM的布局图片对于具体布局代码看源码吧。 对于JAVA源码我们先看这种方式写的convertView的生成方法。 package com.example.try_pulltorefresh_map; /*** 完成了从TXT文本中提取并向下刷新* blog:http://blog.csdn.net/harvic880925* author harvic* date 2014-5-8* */ import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.UnsupportedEncodingException; import java.util.ArrayList; import java.util.HashMap; import org.json.JSONArray;import com.handmark.pulltorefresh.library.PullToRefreshBase; import com.handmark.pulltorefresh.library.PullToRefreshListView; import com.handmark.pulltorefresh.library.PullToRefreshBase.Mode; import com.handmark.pulltorefresh.library.PullToRefreshBase.OnRefreshListener;import android.os.Bundle; import android.app.ListActivity; import android.content.Context; import android.graphics.Color; import android.text.format.DateUtils; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ListView; import android.widget.TextView;public class MainActivity extends ListActivity {private ArrayListHashMapString, Object listItem new ArrayListHashMapString, Object();private PullToRefreshListView mPullRefreshListView;MyAdapter adapternull;Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);mPullRefreshListView (PullToRefreshListView) findViewById(R.id.pull_refresh_list);//设定下拉监听函数mPullRefreshListView.setOnRefreshListener(new OnRefreshListenerListView() {Overridepublic void onRefresh(PullToRefreshBaseListView refreshView) {String label DateUtils.formatDateTime(getApplicationContext(), System.currentTimeMillis(),DateUtils.FORMAT_SHOW_TIME | DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_ALL);// Update the LastUpdatedLabelrefreshView.getLoadingLayoutProxy().setLastUpdatedLabel(label);// Do work to refresh the list here.}});mPullRefreshListView.setMode(Mode.PULL_FROM_END);//设置底部下拉刷新模式listItemgetData();//获取LIST数据adapter new MyAdapter(this);//设置适配器ListView actualListView mPullRefreshListView.getRefreshableView();actualListView.setAdapter(adapter); }private ArrayListHashMapString, Object getData() {ArrayListHashMapString, Object list new ArrayListHashMapString, Object();HashMapString, Object map new HashMapString, Object();InputStream inputStream;try {inputStreamthis.getAssets().open(my_home_friends.txt);String jsonreadTextFile(inputStream);JSONArray array new JSONArray(json);for (int i 0; i array.length(); i) {map new HashMapString, Object();map.put(name, array.getJSONObject(i).getString(name));map.put(info, array.getJSONObject(i).getString(info));map.put(img,array.getJSONObject(i).getString(photo));list.add(map);}return list; } catch (Exception e) {// TODO: handle exceptione.printStackTrace();}return list; }public final class ViewHolder{public TextView name;public TextView info;public TextView attentntion;} public class MyAdapter extends BaseAdapter{private LayoutInflater mInflater;public MyAdapter(Context context){this.mInflater LayoutInflater.from(context);}Overridepublic int getCount() {// TODO Auto-generated method stubreturn listItem.size();}Overridepublic Object getItem(int arg0) {// TODO Auto-generated method stubreturn null;}Overridepublic long getItemId(int arg0) {// TODO Auto-generated method stubreturn 0;}Overridepublic View getView(int position, View convertView, ViewGroup parent) {System.out.println(position:position convertView:convertView);ViewHolder holder null;holdernew ViewHolder(); convertView mInflater.inflate(R.layout.item, null);holder.name (TextView)convertView.findViewById(R.id.name);holder.info (TextView)convertView.findViewById(R.id.info);holder.attentntion(TextView)convertView.findViewById(R.id.attention);holder.name.setText((String)listItem.get(position).get(name));holder.info.setText((String)listItem.get(position).get(info));final TextView attentionholder.attentntion;holder.attentntion.setOnClickListener(new View.OnClickListener() { Overridepublic void onClick(View v) {// TODO Auto-generated method stubattention.setTextColor(Color.RED);}});convertView.setTag(holder); return convertView;}}工具类/*** * param inputStream* return*/public String readTextFile(InputStream inputStream) {String readedStr ;BufferedReader br;try {br new BufferedReader(new InputStreamReader(inputStream, UTF-8));String tmp;while ((tmp br.readLine()) ! null) {readedStr tmp;}br.close();inputStream.close();} catch (UnsupportedEncodingException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}return readedStr;}}以上代码凡是懂如何派生自BaseAdapter的应该都可以看懂这里就不再多讲只看核心代码摘录如下Override public View getView(int position, View convertView, ViewGroup parent) {System.out.println(position:position convertView:convertView);ViewHolder holder null;holdernew ViewHolder(); convertView mInflater.inflate(R.layout.item, null);holder.name (TextView)convertView.findViewById(R.id.name);holder.info (TextView)convertView.findViewById(R.id.info);holder.attentntion(TextView)convertView.findViewById(R.id.attention);holder.name.setText((String)listItem.get(position).get(name));holder.info.setText((String)listItem.get(position).get(info));final TextView attentionholder.attentntion;holder.attentntion.setOnClickListener(new View.OnClickListener() { Overridepublic void onClick(View v) {// TODO Auto-generated method stubattention.setTextColor(Color.RED);}}); return convertView; }这里利用system.out.println对convertView进行捕捉运行如果如下 手机初始化是这样子的 根据上面我们讲的理论在初始化时整个屏幕能放下三个ITEM所以会创建三个全新的convertView。当我往下拉一个ITEM出现第四个ITEM的时候就会回收第一个ITEM的convertView给第四个。捕捉结果如下 清楚的看到前四个convertView为NULL当第五个ITEM出现时此时由于第一个ITEM肯定已经滚出屏幕所以将其重新传给即将出现的item5使用。我们上面说的第四个ITEM出现的时候就应该不再创建新convertView了我想android开发者在考虑多创建一个ITEM的目的在于更安全吧。 回到上面的代码好像看着代码没有任何问题我在里面写了个clickListener当点击“关注”的时候字体会变红试一下。             点击“关注”                     下拉后再拉回来 问题出现了当拉回来的时候“关注”不再红了为什么 问题出在代码上 holdernew ViewHolder(); convertView mInflater.inflate(R.layout.item, null); holder.name (TextView)convertView.findViewById(R.id.name); holder.info (TextView)convertView.findViewById(R.id.info); holder.attentntion(TextView)convertView.findViewById(R.id.attention); 每次运行getView获取当前ITEM时都会重新new 一个viewHolder与R.layout.item绑定也就是说每次都会产生一个新布局赋值给convertView让其显示。而我们上面讲了android会将回收过来的convertView返回给即将显示的getView使用以节约资源。而我们这里却没有领情每次都重新创建一个布局赋给convertView由于每次都创建一个新布局所以当ITEM1被重新拉回来显示的时候由于是重新创建的布局当然是初始状态。“关注”当然也就是黑色的了。改进 Override public View getView(int position, View convertView, ViewGroup parent) {System.out.println(position:position convertView:convertView);ViewHolder holder null;if (convertView null) {holdernew ViewHolder(); convertView mInflater.inflate(R.layout.item, null);holder.name (TextView)convertView.findViewById(R.id.name);holder.info (TextView)convertView.findViewById(R.id.info);holder.attentntion(TextView)convertView.findViewById(R.id.attention);convertView.setTag(holder); }else {holder (ViewHolder)convertView.getTag();}holder.name.setText((String)listItem.get(position).get(name));holder.info.setText((String)listItem.get(position).get(info));final TextView attentionholder.attentntion;holder.attentntion.setOnClickListener(new View.OnClickListener() { Overridepublic void onClick(View v) {// TODO Auto-generated method stubattention.setTextColor(Color.RED);}});return convertView; } 不同的部分在这ViewHolder holder null;if (convertView null) {holdernew ViewHolder(); convertView mInflater.inflate(R.layout.item, null); holder.name (TextView)convertView.findViewById(R.id.name); holder.info (TextView)convertView.findViewById(R.id.info); holder.attentntion(TextView)convertView.findViewById(R.id.attention); convertView.setTag(holder); }else {holder (ViewHolder)convertView.getTag(); }当convertView为空即初始化创建时我们就将生成的布局利用setTag()保存在convertView中当convertView利用回收机制回收过来让我们再次使用时我们通过getTag()将保存的布局取出来重新将布局里的各个控件重新赋值就可以了。这里就利用了android-listView的回收机制。 再看关注的点击事件运行的怎样看第二张图当拉下去再拉回来的时候一切正常但当我们再往下拉第三张图问题又出现了明明没有点P-5为什么关注反而是红色的 这是因为P-5用的是P-1回收来的convertView!!!而P-1的convertView的布局里“关注”是红色的。所以只要回收机制在我们就没有办法改变从P-1回收来的convertView里的图片布局除非人为的将其重置 理解了这个问题以后我们想想解决办法。 首先申请一个arrayList  attentionArr变量保存用户点击“关注”的ITEM的position然后在绘制当前ITEM时根据这个position是否在attentionArr里来判断是不是将“关注”重新变红。 代码如下 Override public View getView(final int position, View convertView, ViewGroup parent) {System.out.println(position:position convertView:convertView);ViewHolder holder null;if (convertView null) {holdernew ViewHolder(); convertView mInflater.inflate(R.layout.item, null);holder.name (TextView)convertView.findViewById(R.id.name);holder.info (TextView)convertView.findViewById(R.id.info);holder.attentntion(TextView)convertView.findViewById(R.id.attention);convertView.setTag(holder); }else {holder (ViewHolder)convertView.getTag();}holder.name.setText((String)listItem.get(position).get(name));holder.info.setText((String)listItem.get(position).get(info));final TextView attentionholder.attentntion;//根据当前position判断重新制做样式if (attentionArr.contains(position)) {attention.setTextColor(Color.RED);}else {attention.setTextColor(Color.BLACK);}holder.attentntion.setOnClickListener(new View.OnClickListener() { Overridepublic void onClick(View v) {// TODO Auto-generated method stubattention.setTextColor(Color.RED);attentionArr.add(position);//在点击时将position加入其中}});return convertView; }理解代码难度不大首先在OnClickListener时将position加入到attentionArr数组中然后在getView里判断当前position是不是用户点击过的即是否包含在attentionArr数组中如果是则将“关注”置为红色否则置为初始色黑色。
http://www.pierceye.com/news/403877/

相关文章:

  • wordpress弹幕视频插件广西seo搜索引擎优化
  • 网站开发与维护工资多少网络公司排名兴田德润
  • wordpress主题ux壹搜网站建设优化排名
  • 试剂产品商城网站建设杭州网站现场备案
  • 高唐企业建网站服务商wordpress google
  • 重庆网站开发商城最近新闻有哪些
  • 电商网站设计线路图有哪些网络推广平台
  • 海门市建设局网站科技与应用
  • 北京做网站s免费做app网站有哪些
  • 免费制作网页的网站网络营销师报名官网
  • 长沙网站制作好公司网络服务模型
  • 网站开发的时间流程微信平台可以做微网站吗
  • 镇江网站seo天猫网店代运营
  • 吴江城乡住房和城乡建设局网站怎么给别人做网站优化
  • 名师工作室网站建设 意义网站图片上浮动文字
  • 做co的网站商城网站不备案
  • 黄山建设网站公司电话网站下载链接怎么做
  • 开发企业网站多少钱电视剧排行榜百度搜索风云榜
  • 什么网站做软文装修公司报价如何计算
  • 网站开发免费视频播放器应用公园app免费制作
  • 道路建设去什么网站能看到做内贸注册什么网站
  • 代理东莞网站制作公司wordpress前台用户中心代码
  • 做拼团网站下载wap浏览器
  • 网站建设合同文百科阿里云加WordPress建站
  • 服装购物网站排名ppt制作神器
  • 长沙营销策划公司排名如何优化企业网站
  • 北京制卡厂家做卡公司北京制卡网站_北京制卡_北京 去114网wordpress 关闭注册
  • 网站建设技术优势广州天河区医院
  • python和php网站开发中国十大公司排行榜
  • 网站栅格如何建设一个外卖订餐平台网站