wemall app商城源码中实现带图片和checkbox的listview
wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改。本文分享其中实现带图片和checkbox的listview,供技术员参考学习。
import com.inuoer.util.AsyncImageLoader.ImageCallback;
import com.inuoer.wemall.R;
public class MainAdapter extends BaseAdapter {
private LayoutInflater mInflater;// 得到一个LayoutInfalter对象用来导入布局
private ArrayList<Map<String, Object>> getDate;
private Context mContext;
public MainAdapter(Context context , ArrayList<Map<String, Object>> getDate) {
this.mContext = context;
this.mInflater = LayoutInflater.from(context);
this.getDate = getDate;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return getDate.size();// 返回数组的长度
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return getDate.get(position);
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
@SuppressLint("NewApi")
@Override
public View getView(final int position, View convertView,
ViewGroup parent) {
// TODO Auto-generated method stub
final ViewHolder holder;
if (convertView == null) {
holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.itemlist_shop, null);
holder.image = (ImageView) convertView
.findViewById(R.id.itemlist_image);
holder.name = (TextView) convertView
.findViewById(R.id.itemlist_shopname);
holder.price = (TextView) convertView
.findViewById(R.id.waimai_shopmenu_adapter_item_price);
holder.plusButton = (ImageButton) convertView
.findViewById(R.id.plus_btn);
holder.minusButton = (ImageButton) convertView
.findViewById(R.id.minus_btn);
holder.numTextView = (TextView) convertView
.findViewById(R.id.count);
convertView.setTag(holder);// 绑定ViewHolder对象
} else {
holder = (ViewHolder) convertView.getTag();// 取出ViewHolder对象
}
convertView.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
final LinearLayout layout = (LinearLayout) mInflater.inflate(R.layout.dialog_detail, null);
final Dialog dialog = new Dialog(mContext);
dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
dialog.setContentView(layout);
dialog.show();
final ImageView imageView = (ImageView) layout.findViewById(R.id.dialog_detail_big_image);
new AsyncImageLoader(mContext).downloadImage(getDate.get(position).get("image").toString(),true,
new ImageCallback() {
@Override
public void onImageLoaded(Bitmap bitmap, String imageUrl) {
// TODO Auto-generated method stub
imageView.setImageBitmap(bitmap);
}
});
TextView textViewPrice = (TextView)layout.findViewById(R.id.dialog_detail_single_price);
textViewPrice.setText(holder.price.getText().toString());
TextView textViewNum = (TextView) layout.findViewById(R.id.count);
textViewNum.setText(holder.numTextView.getText().toString());
layout.findViewById(R.id.dialog_detail_close).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
dialog.dismiss();
}
});
layout.findViewById(R.id.dialog_detail_addcart).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
dialog.dismiss();
}
});
final TextView textViewin = (TextView) layout.findViewById(R.id.count);
layout.findViewById(R.id.plus_btn).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
holder.plusButton.callOnClick();
textViewin.setText(holder.numTextView.getText().toString());
}
});
layout.findViewById(R.id.minus_btn).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
holder.minusButton.callOnClick();
textViewin.setText(holder.numTextView.getText().toString());
}
});
}
});
// String imgUrl = getDate.get(position).get("image").toString();
// AsyncImageLoader loader = new AsyncImageLoader(mContext);
// //将图片缓存至外部文件中
// loader.setCache2File(true); //false
// //设置外部缓存文件夹
// loader.setCachedDir(mContext.getCacheDir().getAbsolutePath());
//下载图片,第二个参数是否缓存至内存中
// loader.downloadImage(imgUrl, false, new AsyncImageLoader.ImageCallback() {
// @Override
// public void onImageLoaded(Bitmap bitmap, String imageUrl) {
// if(bitmap != null){
// holder.image.setImageBitmap(bitmap);
// }else{
// //下载失败,设置默认图片
// holder.image.setImageResource(R.drawable.about_logo);
// }
// }
// });
new AsyncImageLoader(mContext).downloadImage(getDate.get(position).get("image").toString(),true,
new ImageCallback() {
@Override
public void onImageLoaded(Bitmap bitmap, String imageUrl) {
// TODO Auto-generated method stub
holder.image.setImageBitmap(bitmap);
}
});
holder.name.setText(getDate.get(position).get("name")
.toString());
holder.price.setText(getDate.get(position).get("price")
.toString());
holder.numTextView.setText(String.valueOf(CartData.findCart(position)));
holder.plusButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
int num = Integer.parseInt(holder.numTextView.getText()
.toString()) + 1;
holder.numTextView.setText(String.valueOf(num));
CartData.editCart(getDate.get(position).get("id").toString(),
getDate.get(position).get("name").toString(),
getDate.get(position).get("price").toString(),
String.valueOf(num),
getDate.get(position).get("image").toString());
}
});
holder.minusButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
int num = Integer.parseInt(holder.numTextView.getText()
.toString()) - 1;
if (num >= 0) {
holder.numTextView.setText(String.valueOf(num));
if (num == 0) {
CartData.removeCart(getDate.get(position)
.get("id").toString());
} else {
CartData.editCart(getDate.get(position).get("id").toString(),
getDate.get(position).get("name").toString(),
getDate.get(position).get("price").toString(),
String.valueOf(num),
getDate.get(position).get("image").toString());
}
}
}
});
return convertView;
}
}
原文详情地址:http://git.oschina.net/einsqing/wemall-mobile
wemall-mobile商城详情地址:http://www.koahub.com/home/product/56
wemall官网地址:http://www.wemallshop.com
WeMall - 开源微商城 微信商城 商城源码 分销商城 b2b2c商城系统

wemall app商城源码中实现带图片和checkbox的listview的更多相关文章
- wemall app商城源码中android按钮的三种响应事件
wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码中android按 ...
- wemall app商城源码中基于JAVA的Android异步加载图片管理器代码
wemall doraemon是Android客户端程序,服务端采用wemall微信商城,不对原商城做任何修改,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可随意定制修改.本文分享其中 ...
- wemall app商城源码中基于JAVA的绑定和处理fragments和viewpager之间的逻辑关系代码
wemall doraemon是Android客户端程序,服务端采用wemall微信商城,不对原商城做任何修改,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可随意定制修改.本文分享其中 ...
- wemall app商城源码中基于PHP的ThinkPHP惯例配置文件代码
wemall doraemon是Android客户端程序,服务端采用wemall微信商城,不对原商城做任何修改,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可随意定制修改.本文分享其中 ...
- wemall app商城源码中基于JAVA通过Http请求获取json字符串的代码
wemall-mobile是基于WeMall的Android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.分享其中关于通过Http请求获取json字符串的代码供 ...
- wemall app商城源码中ScrollView中嵌套ListView主要代码
很多时间我们在scorllview中嵌入listview的时候,都只能看到listview显示一行数据,而我们的要求是显示多行,即我们数据的行数, 当ListView的高度设定一定的值时,ListVi ...
- wemall app商城源码中基于PHP的通用的树型类代码
wemall doraemon是Android客户端程序,服务端采用wemall微信商城,不对原商城做任何修改,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可随意定制修改.本文分享其中 ...
- wemall app商城源码Android之支付宝通知处理类
wemall-mobile是基于WeMall的Android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之处 ...
- wemall app商城源码Android之支付宝接口公用函数
wemall-mobile是基于WeMall的Android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之 ...
随机推荐
- java发送邮件完整实例 java邮件工具类
http://yuncode.net/code/c_552a2e2dc593894 package com.srie.mail; import java.util.Properties; import ...
- Android项目中打jar包 和 使用
第一步,把普通的android project设置成库项目 库项目也是一个标准的android项目,因此你先创建一个普通的android项目. 这个项目可以起任何的名称,任何的报名,设置其他需要设置的 ...
- .NET 通用高扩展性的细粒度权限管理架构(webApi/Mvc)
一. 权限场景分析: 1. 系统具有角色概念, 部门概念, 且都具有相应不同的权限 2. 用户具有多个角色, 多个部门等关系, 并且能给单个用户指派独有的权限 3. 具有细粒度权限控制到资源的RBAC ...
- SQL SERVER分区具体例子详解
在日常工作中,我们会遇到以下的情况,一个表每日数万级的增长,而查询的数据通常是在本月或今年,以前的数据偶尔会用到,但查询和插入的效率越来越慢,用数据库分区会有助于解决这个问题.关于分区的理论知识网上很 ...
- HDU5832
A water problem Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- 安装Ubuntu时的硬盘分区
根目录 大小:60G~100G(用来安装程序) 新分区的类型:主分区 新分区的位置:空间起始位置 用于:EXT4日志文件系统 挂载点:"/" 大小:4G 新分区的类型:逻辑分区 新 ...
- CSS3中字体平滑处理和抗锯齿渲染
在围观Drupal官方主题的时候,发现了一个有意思的非标准CSS选择器-webkit-font-smoothing,于是上手把玩了一番.如何使用css3字体平滑显示呢 要知道,W3C对CSS中字体的抗 ...
- block之--- 基本使用
block的类型:对象 官方文档描述如下 “Blocks are Objective-C objects, which means they can be added to collections l ...
- JAVA--可变长参数
可变长参数: 可变长参数可以接受任意个数的实参,形参实际上是一个数组. 语法形式: 方法名称(类型 参数1,类型 参数2,类型...可变长参数) *可变长参数一定是方法的最后一个参数 public v ...
- 小机器人自动回复(python,可扩展开发微信公众号的小机器人)
api来之图灵机器人.我们都知道微信公众号可以有自动回复,我们先用python脚本编写一个简单的自动回复的脚本,利用图灵机器人的api. http://www.tuling123.com/help/h ...