android listview固定内容,Android ListView 列表分隔,条目中添加分类信息(文字,图片等)...

自定义新建TextView实现listView列表分隔

在ListView的Adapter类中的getView方法下获取到需插入分隔行的位置

该位置可以添加textview、imageview等组件

复写adapter中的isEnabled方法,屏蔽分个组件的点击事件,否则会发生异常

返回item项目时需在getItem方法中做相应业务逻辑处理

private class Page2ListViewAdapter extends BaseAdapter{

private LayoutInflater mILayoutInflater;

public Page2ListViewAdapter(){

mILayoutInflater=(LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);

}

@Override

public int getCount() {

boolean isdisplaysystem = sp.getBoolean(Const.IS_SHOW_SYSTEM_TASK, true);

if(isdisplaysystem){

return userTasks.size()+systemTasks.size()+2;

}else{

return userTasks.size() + 1;

}

}

@Override

public boolean isEnabled(int position) {

if(position==0){

return false;

}else if(position==userTasks.size()+1){

return false;

}

return super.isEnabled(position);

}

@Override

public Object getItem(int position) {

if(position==0){

return null;

}else if(position<=userTasks.size()){

return userTasks.get(position-1);

}else if(position==userTasks.size()+1){

return null;

}else{

return systemTasks.get(position-userTasks.size()-2);

}

}

@Override

public long getItemId(int position) {

return position;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

View view=null;

ViewHolder holder=null;

if(position==0){

TextView userText=new TextView(getBaseContext());

userText.setText("流行音乐("+userTasks.size()+")");

userText.setTextSize(20);

userText.setBackgroundColor(Color.GRAY);

return userText;

}else if(position<=userTasks.size()){

//....................列表填充

return view;

}else if(position==userTasks.size()+1){

TextView sysText=new TextView(getBaseContext());

sysText.setText("纯音乐("+systemTasks.size()+")");

sysText.setTextSize(20);

sysText.setBackgroundColor(Color.GRAY);

return sysText;

}else{

//.............................

}

}

/**

* 处理第二页次第二页 listview缓存,利用缓存可以提高listview的性能优化

*/

static class ViewHolder{

ImageView processIcon;

TextView processName;

TextView processMemory;

CheckBox processCheck;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在ListView添加图片和产品信息,你可以使用自定义的ListView适配器来完成。 下面是一些基本步骤: 1. 创建一个自定义的布局文件,该布局文件包含一个ImageView和TextView来显示产品信息图片。 2. 创建一个适配器类,继承自BaseAdapter类,并实现getView()方法。 3. 在getView()方法,使用LayoutInflater来加载自定义的布局文件,并将产品信息图片设置到相应的视图。 4. 在Activity,实例化ListView对象,并将适配器对象设置给ListView对象。 下面是一个简单的示例代码: ```java public class ProductListAdapter extends BaseAdapter { private List<Product> productList; private Context context; public ProductListAdapter(Context context, List<Product> productList) { this.context = context; this.productList = productList; } @Override public int getCount() { return productList.size(); } @Override public Object getItem(int position) { return productList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if (convertView == null) { convertView = LayoutInflater.from(context).inflate(R.layout.list_item_product, parent, false); viewHolder = new ViewHolder(); viewHolder.productImage = (ImageView) convertView.findViewById(R.id.product_image); viewHolder.productName = (TextView) convertView.findViewById(R.id.product_name); viewHolder.productPrice = (TextView) convertView.findViewById(R.id.product_price); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); } Product product = productList.get(position); viewHolder.productImage.setImageResource(product.getImageResource()); viewHolder.productName.setText(product.getName()); viewHolder.productPrice.setText(product.getPrice()); return convertView; } private static class ViewHolder { ImageView productImage; TextView productName; TextView productPrice; } } ``` 在这个示例,我们创建了一个自定义的适配器ProductListAdapter,并在getView()方法加载了一个自定义的布局文件list_item_product.xml。该布局文件包含了一个ImageView和两个TextView,用来显示产品图片和产品信息。 我们还使用了ViewHolder模式来优化ListView的性能。ViewHolder模式可以避免重复findViewById()的开销,从而提高ListView的滚动流畅性。 在Activity,我们可以像下面这样使用ProductListAdapter: ```java List<Product> productList = new ArrayList<>(); productList.add(new Product(R.drawable.product1, "Product 1", "$10.00")); productList.add(new Product(R.drawable.product2, "Product 2", "$20.00")); productList.add(new Product(R.drawable.product3, "Product 3", "$30.00")); ProductListAdapter adapter = new ProductListAdapter(this, productList); ListView listView = (ListView) findViewById(R.id.list_view); listView.setAdapter(adapter); ``` 在这个示例,我们创建了一个包含三个产品的列表,并将其设置给ProductListAdapter。然后,我们实例化了一个ListView对象,并将ProductListAdapter对象设置给ListView对象。 当我们运行应用程序时,ListView将会显示产品列表,包括产品图片和产品信息
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值