`

onItemClick理解和点击item后背景变色的实现

 
阅读更多

我们有时做一个菜单,点击后,背景变为点击后色,效果如下:



 

 

这里只是简单介绍实现过程:

定义存放菜单的listview:

<ListView
        android:id="@+id/subject_menu_category_lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_above="@id/subject_menu_bottom_layout"
        android:layout_below="@id/subject_menu_top"
        android:listSelector="@drawable/selector_subject_menu_listview"
		android:divider="@color/menu_divider"
		android:dividerHeight="1dp"
		android:background="@color/menu_item_normal"
		>
    </ListView>

 

这里将devider设置为1dp,指定颜色就有分隔线了,如果不想要分隔线或将分隔线放在item里写,listview就使用android:divider="@null"。

颜色配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<resources>


    
    <!-- 学科分类颜色设置 -->
    <color name="menu_item_normal">#8f8c87</color>
    <color name="menu_item_press">#6b6863</color>
    <color name="menu_text_normal">#dddddd</color>
    <color name="menu_text_press">#fefefe</color>
    <color name="menu_text_normal">#dddddd</color>
    <color name="menu_divider">#bab7b1</color>
    
    
    
    
</resources>

 

 

listview的adapter:

package com.yiduoyun.tiku.adapter;

import java.util.ArrayList;

import android.app.Activity;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import com.yiduoyun.tiku.R;
import com.yiduoyun.tiku.model.SubjectCatalog;

/**
 * 学科的适配器
 */
public class SubjectCatalogAdapter extends ArrayListAdapter<SubjectCatalog> {
	
	private Context context = null;
	
	/**
	 * 首次使用,默认第一项目背景变黑
	 */
	private boolean first = true;
	
	public SubjectCatalogAdapter(Context context) {
		super(context);
		this.context = context;
	}


	public void setSubjectCatalogList(ArrayList<SubjectCatalog> subjectCatalogList) {
		setList(subjectCatalogList);
	}


	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		
		ViewHolder viewHolder = null;
		
		if (convertView == null){
			convertView = ((Activity)getContext()).getLayoutInflater().inflate(
					R.layout.subject_category_item, null);

			viewHolder = new ViewHolder();
			
			viewHolder.subjectName = (TextView) convertView.findViewById(R.id.category_name_tv);
			
			convertView.setTag(viewHolder);
		}
		else {
			viewHolder = (ViewHolder) convertView.getTag();
		}
		
		/**
		 * 将第一个item设置为选中状态
		 */
		if(first == true && position == 0){
			convertView.setBackgroundResource(R.color.menu_item_press);//背景变黑色
			viewHolder.subjectName.setTextColor(context.getResources().getColor(R.color.menu_text_press));//字体变白色
			first = false;
		}
		
		
		SubjectCatalog sc = getItem(position);
		viewHolder.subjectName.setText(sc.getName());
		
		return convertView;
	
	}
	
	class ViewHolder{
		TextView subjectName;//学科名
	}
}

 

每一个item是那个的简单:

subject_category_item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="8dp" >
    
    <TextView 
        android:id="@+id/category_name_tv"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="语文"
        android:textColor="@color/menu_text_normal"
        android:textSize="20sp"/>

</LinearLayout>

 

 

 

重点点击事件,背景变色功能:

categoryListView = (ListView) getActivity().findViewById(R.id.subject_menu_category_lv);
		

		adapter = new SubjectCatalogAdapter(getActivity());
		adapter.setSubjectCatalogList(subjectCatalogList);
		categoryListView.setAdapter(adapter);

		
		
		
		categoryListView.setOnItemClickListener(new OnItemClickListener() {

			@Override
			public void onItemClick(AdapterView<?> parent, View view,//这里的parent是listview,因为setOnItemClickListener可以是listview或gridview等,系统定为泛型,运行时系统会传入的
					int position, long id) {
				
				/**
				 * 设置点击效果背景
				 */
				for(int i=0;i<parent.getCount();i++){
					
					/**
					 * 因为parent这里是listview,所以parent.getChildAt(i)就是一个一个的item
					 */
		            View item=parent.getChildAt(i);
		            
		            /**
		             * 找到item里的每一个元素再进行相关操作
		             */
		            TextView categoryNameTextView = (TextView)(item.findViewById(R.id.category_name_tv));
					
		            
		            if (position == i) {
		            	item.setBackgroundResource(R.color.menu_item_press);
		                categoryNameTextView.setTextColor(getResources().getColor(R.color.menu_text_press));
		            } else {
		            	item.setBackgroundResource(R.color.menu_item_normal);
		                categoryNameTextView.setTextColor(getResources().getColor(R.color.menu_text_normal));
		            }
		        }
				
				
				/**
				 * 界面切换
				 */
				Bundle bundle = new Bundle();
				SubjectCatalog sc = subjectCatalogList.get(position);
				bundle.putSerializable(Constant.TAG_SUBJECT_CATALOG , sc);
				MainSlidingMenuActivity.getInstance().startToActivity(new SubjectHomeFragment() , bundle);
			}
		});

 

 

点击事件最重要理解onItemClick的参数:

AdapterView<?> arg0 参数得意思:官方解释说:the AdapterView where the click happened. 也就是当前点击的adapterview,这个参数是系统自动传入的,我们也不用调用,一般常用第二个和第三个参数。

 

然后给你讲AdapterView<?> ,这个属于java基础的内容,叫做泛型,就是告诉你传入的参数是哪种类型。 比如String<?>,List<T>,Map<K,V>,String<E> ?表示不确定的java类型。 T 表示java类型。 K V 分别代表java键值中的Key Value。 E 代表Element。 ListView, GridView, Spinner and Gallery 中都要用到adapter,所以这里用问好表示不确定传入的是哪种类型,不用我们关系,系统自动传入,到时使用时就是什么(ListView, GridView, Spinner and Gallery中的一个)。

 

这个方法的参数是这样的AdapterView<?> parent, View view,第一个是指父View,比如你的是ListView,那么arg0就是ListView了,arg1就是你点击的那个Item的View。arg2是position,arg3是id,相对于我上面举的ListView的例子来说,position是你适配器里面的position,一般是第几个项,id是哪个项View的id。当ADT的版本高一些,自动导入接口的必须实现的方法的时候,对于以上的方法会返回public void onItemClick(AdapterView<?> parent, View view, int position, long id

 

 

上面代码先找到listview的item,再从item里找出元素,再进行点击效果操作,重点是下面两句代码:

/**
					 * 因为parent这里是listview,所以parent.getChildAt(i)就是一个一个的item
					 */
		            View item=parent.getChildAt(i);
		            
		            /**
		             * 找到item里的每一个元素再进行相关操作
		             */
		            TextView categoryNameTextView = (TextView)(item.findViewById(R.id.category_name_tv));

 

 

 

 

 

 

 

  • 大小: 69.1 KB
分享到:
评论

相关推荐

    listView Item 点击文字跟着变色

    在Android开发中,ListView是一种...以上就是实现“ListView Item点击文字跟着变色”的关键知识点。在实际应用中,可能还需要考虑到多线程、性能优化、不同设备适配等问题,但这些都是基于上述基础进行的扩展和细化。

    andriod ListView条目点击变色demo

    要实现点击变色效果,我们需要监听ListView的item点击事件。可以通过为ListView设置OnItemClickListener来实现。在onItemClick()方法中,我们可以获取到被点击的条目位置,并根据这个位置更新对应的视图颜色。 代码...

    在RecyclerView中实现item点击效果

    如果想要实现更丰富的点击效果,比如改变item的背景色或透明度,可以在ViewHolder中使用`TransitionDrawable`或`StateListDrawable`。当item被点击时,切换颜色状态以实现动画效果。 综上所述,实现RecyclerView的...

    GridView中的TextView选中背景变色

    要实现TextView选中时背景变色,我们需要关注以下几个关键步骤: 1. **自定义Adapter**: 创建一个继承自BaseAdapter的自定义Adapter,重写`getView()`方法。在这个方法中,我们可以根据item的状态来设置TextView...

    ListView选中item颜色改变

    通过以上步骤,我们就可以实现ListView点击item颜色改变的效果。这个过程中涉及到了Android的基础组件使用、自定义布局、颜色选择器、适配器机制以及事件监听,这些都是Android开发中必备的知识点。在实际开发中,...

    ViewPager实现无限轮播+item点击事件

    总结,实现一个带有无限轮播和点击事件的ViewPager,需要自定义PagerAdapter、设置`offscreenPageLimit`属性、为item设置点击事件以及可能的页面变换动画。通过这样的方式,我们可以创建一个高效且交互丰富的Android...

    Listview点击item高亮显示,

    标题“Listview点击item高亮显示”和描述“点击一个Listview的item高亮显示,不灭。点另一个item,前一个不显示高亮,第二个高亮”正是描述了这样一个需求:当用户点击ListView中的某一项时,该项应该保持高亮状态,...

    android listview点击保持背景颜色,实现已读功能

    在许多应用中,我们经常需要实现点击ListView项后保持其背景颜色,以显示已读或未读的状态,这样用户可以清楚地看到哪些项已被查看。本教程将详细讲解如何在Android中实现这个功能。 首先,我们需要创建一个自定义...

    android的ListView点击item使item展开的做法

    在实际应用中,我们经常需要实现点击ListView的某一项(item)时,该item能够展开显示更多的内容,例如子列表或者详细信息。这个功能可以通过自定义ListView的Adapter和设置监听器来实现。下面将详细解释如何实现这...

    RecyclerView加载不同item并实现其item点击事件,实现添加常用应用的功能demo

    本项目“RecyclerViewDemo”将教你如何利用RecyclerView来加载不同的item,并实现每个item的点击事件,以创建一个添加常用应用的功能演示。 首先,我们需要在布局文件中引入RecyclerView。在XML布局文件中添加一个...

    点击listview的item在所点击的item的上边弹出popwindow

    在这个场景中,我们需要实现的功能是:当用户点击ListView中的某个条目时,一个PopWindow会从所点击的条目上方弹出,提供类似QQ消息长按后的删除选项。以下将详细讲解如何实现这一功能。 首先,我们需要创建一个...

    RecyclerView添加头部和尾部,实现Item点击事件

    本教程将详细讲解如何在RecyclerView中添加头部和尾部,并实现Item点击事件。 首先,我们需要在布局文件中声明RecyclerView。在XML布局中,RecyclerView可以通过以下方式定义: ```xml android:id="@+id/...

    ListView中嵌入Button ,ListView的item与Button的click事件分别被响应,同时还实现了类似Digg的item点击效果

    此外,我们还将实现一种类似Digg网站的点击效果,即当用户点击item时,其视觉表现会发生变化。 首先,我们需要创建一个自定义的ListView适配器。这个适配器通常继承自`BaseAdapter`,并重写其中的`getView()`方法。...

    解决RecyclerView无法onItemClick问题的两种方法

    总的来说,RecyclerView虽然没有内置的点击事件处理,但通过这两种方式,开发者完全可以根据自己的需求实现点击事件监听。在实际开发中,可以根据项目的规模、需求和团队协作情况来选择合适的方法。同时,...

    点击listView中的图片,在HorizontalScrollView显示出来,在点击item,图片消失

    总之,实现“点击ListView中的图片,在HorizontalScrollView显示出来,在点击item,图片消失”的功能涉及到ListView和HorizontalScrollView的交互,以及图片的加载与管理。理解这两个组件的工作原理并合理利用它们的...

    listview item点击事件冲突问题

    总之,解决ListView item点击事件冲突问题需要对Android的事件传递机制有深入理解,并灵活运用各种策略来处理。合理地配置子View的可点击性和焦点性,以及正确处理手势和点击事件的冲突,都是解决问题的关键。同时,...

    Android下Listview的onItemClick以及onItemLongClick等易模糊问题验证

    在实际开发中,`onItemClick`和`onItemLongClick`可能会冲突,因为如果用户在长按后快速松手,可能会触发点击事件。为避免这种问题,可以在`onItemLongClick`中返回true,阻止点击事件的传播。此外,确保正确设置...

    listview点击item显示隐藏布局

    这个需求在标题和描述中提到的就是“listview点击item显示隐藏布局”,这涉及到ListView的适配器(Adapter)以及点击事件监听(OnItemClickListener)的应用。 首先,我们要创建一个自定义的Adapter,用于填充...

    android的ListView点击item使item展开的做法的实现代码

    本文详细介绍了 Android ListView 点击 Item 展开的实现代码,包括了 ListView 的点击事件处理、Adapter 的实现和 Tag 的实现。通过这篇文章,读者可以了解到如何实现 ListView 点击 Item 展开的做法,并应用于实际...

Global site tag (gtag.js) - Google Analytics