简单实现ListView选中后的效果-创新互联

1、创建activity界面布局.xml

创新互联公司专注于房山企业网站建设,响应式网站建设,商城网站制作。房山网站建设公司,为房山等地区提供建站服务。全流程定制网站,专业设计,全程项目跟踪,创新互联公司专业和态度为您提供的服务

 version="1.0" encoding="utf-8"?>

 xmlns:android="http://schemas.android.com/apk/res/android"

              android:orientation="vertical"

              android:layout_width="match_parent"

              android:layout_height="match_parent">

         android:id="@+id/listview"

             android:layout_width="match_parent"

             android:layout_height="match_parent"

            android:cacheColorHint="#00000000" />

2、自定义列表的适配器adapter

package com.example.t;

import java.util.ArrayList;

import android.content.Context;
import android.graphics.Bitmap;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.LinearLayout;
import android.widget.TextView;

public class MyListviewAdapter extends BaseAdapter {

 private LayoutInflater inflater = null;
 private ArrayList arraylist = null;
 private Bitmap icon;

 private int selectedPosition = -1;
 private Context context;

 public void setSelectedPosition(int position) {
  selectedPosition = position;
 }

 public void setDatas(ArrayList tmp) {
  // 保存适配器中的每项的文字信息
  this.arraylist.clear();
  this.arraylist.addAll(tmp);
  notifyDataSetChanged();
 }

 public MyListviewAdapter(Context context) {
  this.context = context;
  // LayoutInflater用来加载界面
  inflater = LayoutInflater.from(context);
 }

 @Override
 public int getCount() {
  return arraylist.size();
 }

 @Override
 public Object getItem(int position) {
  return arraylist.get(position);
 }

 @Override
 public long getItemId(int position) {
  return position;
 }

 // 保存每项中的控件的引用
 class ViewHolder {
  TextView text;
  LinearLayout layout;
 }

 @Override
 public View getView(int position, View convert, ViewGroup parent) {
  ViewHolder holder;
  if (convert == null) // 实现复用行布局
  {
   // 调用LayoutInflater的inflate方法加载layout文件夹中的界面
   convert = inflater.inflate(R.layout.lists, null);
   holder = new ViewHolder();
   holder.text = (TextView) convert.findViewById(R.id.text);
   holder.layout = (LinearLayout) convert.findViewById(R.id.layout);
   // 保存包含当前项控件的对象
   convert.setTag(holder);
  } else {
   // 获取包含当前项控件的对象
   holder = (ViewHolder) convert.getTag();
  }
  // 设置当前项的内容
  holder.text.setText(arraylist.get(position));
  // 设置选中效果
  if (selectedPosition == position) {
   holder.text.setTextColor(context.getResources().getColor(R.color.textcolor_select));
   holder.layout.setBackgroundResource(R.drawable.list_select)
  } else {
   holder.text.setTextColor(context.getResources().getColor(R.color.textcolor_normal));
   holder.layout.setBackgroundResource(R.drawable.list_normal)
  }
  return convert;
 }
}

3、列表的布局

 version="1.0" encoding="utf-8"?>

 xmlns:Android="http://schemas.android.com/apk/res/android"

              android:orientation="vertical"

              android:layout_width="match_parent"

              android:layout_height="match_parent"

    android:orientation="horizontal"

          android:layout_width="match_parent"

          android:layout_height="40px"

          android:id="@+id/layout"

         android:padding="6px">

         android:id="@+id/text"

              android:layout_gravity="center_horizontal"

              android:layout_width="match_parent"

              android:layout_height="wrap_content" />

    

4、在activity中

     // 添加列表框项目点击事件

        listview.setOnItemClickListener(new OnItemClickListener() {

        @Override

         public void onItemClick(AdapterView parent, View view, int position, long id) {

            // 设置适配器的选中项

            listAdapter.setSelectedPosition(position);

           // 更新列表框

            listAdapter.notifyDataSetInvalidated();

       }

   });

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网页标题:简单实现ListView选中后的效果-创新互联
文章位置:http://scyanting.com/article/dhihjo.html