• Android开发ListView嵌套ImageView实现单选按钮


    Android开发两年的时间,技术稍稍有一些提升,刚好把自己实现的功能写出来,记录一下,如果能帮助到同行的其他人,我也算是做了件好事,哈哈!!废话不多说,先上个图。

    先上一段代码: 

    1 if (lastposition == position){
    2                     viewHolder.setImageResource(R.id.iv_yuandian1,R.mipmap.ic_button_checked);
    3                 } else {
    4                     viewHolder.setImageResource(R.id.iv_yuandian1,R.mipmap.ic_button_unchecked);
    5                 }

    我先在Adapter中记录一下默认的位置,因为本人在项目中搭建了一个ListViewAdapter的抽象类,所以每次在使用时只需要直接在Activity中new一下,然后直接在方法里面设置文本内容或者图片资源(如上面的代码的写法),以后会跟大家分享这个抽象类,当然,这个抽象类还是在高手的指导下完成的,大伙可以忽略我这种写法,就按照正常的BaseAdapter上面写就行了。扯远了,说回主题。其实整个功能的主要部分在ListView的Item点击事件中,其主要代码如下: 

     1 lv_choosecompany.setOnItemClickListener(new AdapterView.OnItemClickListener() {
     2             @Override
     3             public void onItemClick(AdapterView<?> adapterView, View view, int position, long l) {
     4                 //把当前选中的条目加上选中效果
     5                 old_imageView = (ImageView) view.findViewById(R.id.iv_yuandian1);
     6                 old_imageView.setImageResource(R.mipmap.ic_button_checked);
     7 
     8                 new_imageView = (ImageView)view.findViewById(R.id.iv_yuandian1);
     9                 if (lastposition != -1 && lastposition != position){
    10                     //如果已经单击过条目并且上次保存的item位置和当前位置不同
    11                     new_imageView.setImageResource(R.mipmap.ic_button_unchecked);//把上次选中的样式去掉
    12                 }
    13                 new_imageView = old_imageView;//把当前的条目保存下来
    14                 lastposition = position;//把当前的位置保存下来
    15 
    16                 listViewAdapter.notifyDataSetChanged();
    17 
    18             }
    19 
    20         });

    整体流程差不多就是这个样子,如果想保留选中以后的文本信息,只需要在点击的时候,将TextView的内容保存下来即可,这里就不在展示代码,不足的地方还请同行们多多指教。

  • 相关阅读:
    码到成功——冲刺随笔 day 8
    码到成功——冲刺随笔 day 7
    码到成功——冲刺随笔 day 6
    码到成功——冲刺随笔 day 5
    码到成功——冲刺随笔 day 4
    码到成功——冲刺随笔 day 3
    码到成功——冲刺随笔 day 2
    Alpha冲刺 —— 5.9
    Alpha冲刺 —— 5.8
    Alpha冲刺 —— 5.7
  • 原文地址:https://www.cnblogs.com/liuqiuyue/p/5772208.html
Copyright © 2020-2023  润新知