关于ImageView图片点击切换前景图片实现CheckBox的功能

今天项目需求碰到了一个问题,废话不多说了上图,如下点击右边ImageView动态去切换ImageView的状态,代码如下:


packagecom.silver.clound.adapter;

importandroid.app.Activity;

importandroid.content.Context;

importandroid.view.View;

importandroid.view.ViewGroup;

importandroid.widget.BaseAdapter;

importandroid.widget.ImageView;

importandroid.widget.TextView;

importcom.silver.clound.R;

importcom.silver.clound.model.SongsBean;

importjava.util.HashMap;

importjava.util.List;

/**

* Created by joe on 2017/3/6.

*/

public classMusicAdapterextendsBaseAdapter  {

privateContextcontext;

privateListlist;

//图片是否被选中

private booleanisChoice=false;

privateHashMapivMap=newHashMap<>();

publicMusicAdapter(Activity mActivity,List list) {

this.context= mActivity;

this.list= list;

for(inti =0;i < list.size();i++) {

ivMap.put(i,isChoice);

}

}

@Override

public intgetCount() {

returnlist.size();

}

@Override

publicObjectgetItem(inti) {

returnlist.get(i);

}

@Override

public longgetItemId(inti) {

returni;

}

privateViewHolderholder;

@Override

publicViewgetView(final inti,View view,ViewGroup viewGroup) {

if(view ==null) {

holder=newViewHolder();

//引入布局

view = View.inflate(context,R.layout.item_music_listview, null);

//实例化对象

holder.song= (TextView) view.findViewById(R.id.tv_song);

holder.singer= (TextView) view.findViewById(R.id.tv_singer);

holder.ivChoice= (ImageView) view.findViewById(R.id.iv_choice);

view.setTag(holder);

}else{

holder= (ViewHolder) view.getTag();

}

//给控件赋值

holder.song.setText(list.get(i).song.toString());

holder.singer.setText("("+list.get(i).singer.toString() +")");

holder.ivChoice.setImageResource(ivMap.get(i)?R.drawable.select_circle:R.drawable.ic_file_circle);

holder.ivChoice.setOnClickListener(newView.OnClickListener() {

@Override

public voidonClick(View v) {

ivMap.put(i,!ivMap.get(i));

if(ivMap.get(i)) {

holder.ivChoice.setImageResource(ivMap.get(i)?R.drawable.select_circle:R.drawable.ic_file_circle);

notifyDataSetChanged();

}

}

});

returnview;

}

classViewHolder {

TextViewsong;//歌曲名

TextViewsinger;//歌手

ImageViewivChoice;//选中与否的图片

}

}

点击事件无论如何都没办法立刻去切换ImageView的前景图片只有滑动到item消失再重新加载才会根据map中boolean值来设置图片前景(忘了notifyDataSetChanged();了),查看setImageResource()源码


翻译:这个方法是在UI线程中对图片读取和解析的,所以有可能对一个Activity的启动造成延迟。所以如果顾虑到这个官方建议用setImageDrawable和setImageBitmap来代替。所以我们使用setImageBitmap或者setImageDrawable来设置图片,来看源码解析


@android.view.RemotableViewMethod

public void setImageBitmap(Bitmap bm) {

// if this is used frequently, mayhandle bitmaps explicitly

// to reduce the intermediate drawable object

setImageDrawable(newBitmapDrawable(mContext.getResources(), bm));

}

实际上setImageBitmap做的事情就是把Bitmap对象封装成Drawable对象,然后调用setImageDrawable来设置图片。因此代码里面才写上了建议,如果需要频繁调用这个方法的话最好自己封装个固定的Drawable对象,直接调用setImageDrawable,这样可以减少Drawable对象。因为每次调用setImageBitmap方法都会对Bitmap对象new出一个Drawable。

setImageDrawable参数是Drawable,也是可以接受不同来源的图片,方法中所做的事情就是更新ImageView的图片。上面两个方法实际上最后调用的都是setImageDrawable(setImageResource没有直接调用,不过更新的方法与setImageDrawable一样)。

所以综合来看setImageDrawable是最省内存高效的,如果担心图片过大或者图片过多影响内存和加载效率,可以自己解析图片然后通过调用setImageDrawable方法进行设置。

好了以上小弟的真知灼见,只能写这么些啦!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容