MainActivity
public class MainActivity extends AppCompatActivity implements MainViewListener{
@BindView(R.id.third_recyclerview)
RecyclerView thirdRecyclerview;
@BindView(R.id.third_allselect)
CheckBox checkBoxAll;
@BindView(R.id.third_totalprice)
TextView thirdTotalprice;
@BindView(R.id.third_submit)
TextView thirdSubmit;
@BindView(R.id.third_pay_linear)
LinearLayout thirdPayLinear;
@BindView(R.id.third_totalnum)
TextView third_totalnum;
private MyPresenter presenter;
private MyAdapter myAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ButterKnife.bind(this);
presenter = new MyPresenter(this);
//获取数据
presenter.getData();
myAdapter = new MyAdapter(this);
thirdRecyclerview.setAdapter(myAdapter);
LinearLayoutManager manager = new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false);
thirdRecyclerview.setLayoutManager(manager);
/**
* MyAdapter.UpdateUiListener接口回调 设置总价、件数
*/
myAdapter.setListener(new MyAdapter.UpdateUiListener() {
@Override
public void setTotal(String total, String num, boolean allCheck) {
checkBoxAll.setChecked(allCheck);
third_totalnum.setText(num);
thirdTotalprice.setText(total);
}
});
}
//全选
@OnClick(R.id.third_allselect)
public void onViewClicked() {
myAdapter.selectAll(checkBoxAll.isChecked());
}
/**
* 把bean里的数据传到MainViewListener
* @param bean
*/
@Override
public void success(ShopBean bean) {
myAdapter.add(bean);
}
@Override
public void failure(Exception e) {
Toast.makeText(this, "error", Toast.LENGTH_SHORT).show();
}
/**
* 防止内存泄漏
*/
@Override
protected void onDestroy() {
super.onDestroy();
presenter.detach();
}
}
MainViewListener
public interface MainViewListener {
public void success(ShopBean bean);
public void failure(Exception e);
}
Model
public class MainModel {
public void getData(final MainModelCallback callback){
OkhttpUtils.getInstance().asy(null, "http://120.27.23.105/product/getCarts?uid=100", new OnUiCallback<ShopBean>() {
@Override
public void success(ShopBean bean) {
callback.success(bean);
}
@Override
public void failure(Exception e) {
callback.failure(e);
}
});
}
}
ModelCallback
public interface MainModelCallback {
public void success(ShopBean bean);
public void failure(Exception e);
}
Presenter
public class MyPresenter {
private MainViewListener listener;
private MainModel mainModel;
public MyPresenter(MainViewListener listener) {
this.mainModel = new MainModel();
this.listener = listener;
}
public void getData(){
mainModel.getData(new MainModelCallback() {
@Override
public void success(ShopBean bean) {
if (listener != null) {
listener.success(bean);
}
}
@Override
public void failure(Exception e) {
if (listener != null) {
listener.failure(e);
}
}
});
}
public void detach(){
this.listener = null;
}
}
适配器Adapter
public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {
public UpdateUiListener listener;
private Context context;
private List<ShopBean.DataBean.ListBean> list;
private Map<String, String> map = new HashMap<>();
public MyAdapter(Context context) {
this.context = context;
}
//将数据封装到list集合
public void add(ShopBean bean) {
if (this.list == null) {
this.list = new ArrayList<>();
}
/**
* 两次遍历,外层遍历商家,内层遍历商品
*/
for (ShopBean.DataBean shop : bean.getData()) {
map.put(shop.getSellerid(), shop.getSellerName());
for (int i = 0; i < shop.getList().size(); i++) {
this.list.add(shop.getList().get(i));
}
}
setFirst(this.list);
notifyDataSetChanged();
}
/**
* 二级购物车,控制商家的现实与隐藏,在ShopBean中自定义isFirst属性,1:显示,2:隐藏
* 根据sellerid字段实现,如果一个商品的selllerid等于前一个sellerid,把isFirst设为1,否则设为2
*
* @param list
*/
private void setFirst(List<ShopBean.DataBean.ListBean> list) {
if (list.size() > 0) {
list.get(0).setIsFirst(1);
for (int i = 1; i < list.size(); i++) {
if (list.get(i).getSellerid() == list.get(i - 1).getSellerid()) {
list.get(i).setIsFirst(2);
} else {
list.get(i).setIsFirst(1);
}
}
}
}
/**
* 加载布局
*
* @param parent
* @param viewType
* @return
*/
@Override
public MyAdapter.MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
// View view=LayoutInflater.from(context).inflate(R.layout.adapter_layout,null);
View view = View.inflate(context, R.layout.adapter_layout, null);
return new MyViewHolder(view);
}
@Override
public void onBindViewHolder(final MyAdapter.MyViewHolder holder, final int position) {
/**
* 通过isFirst属性判断商家的显示与隐藏
*/
if (list.get(position).getIsFirst() == 1) {
//显示商品checkbox
holder.shop_checkbox.setVisibility(View.VISIBLE);
//显示商品名
holder.tvItemShopcartShopname.setVisibility(View.VISIBLE);
holder.shop_checkbox.setChecked(list.get(position).isShopSelected());
holder.tvItemShopcartShopname.setText(map.get(String.valueOf(list.get(position).getSellerid())));
} else {
//隐藏商家checkbox
holder.shop_checkbox.setVisibility(View.GONE);
//隐藏商家名
holder.tvItemShopcartShopname.setVisibility(View.GONE);
}
//控制商品的CheckBox
holder.item_checkbox.setChecked(list.get(position).isItemSelected());
String[] url = list.get(position).getImages().split("\\|");
ImageLoader.getInstance().displayImage(url[0], holder.item_pic);
holder.item_name.setText(list.get(position).getTitle());
holder.item_price.setText(list.get(position).getPrice() + "");
holder.plusViewId.setEditText(list.get(position).getNum());
/**
* 点击商家CheckBox,选中本商家所有商品
*/
holder.shop_checkbox.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//商家CheckBox
list.get(position).setShopSelected(holder.shop_checkbox.isChecked());
for (int i = 0; i < list.size(); i++) {
//如果是同一商家,设置商品CheckBox选中
if (list.get(position).getSellerid() == list.get(i).getSellerid()) {
list.get(i).setItemSelected(holder.shop_checkbox.isChecked());
}
}
notifyDataSetChanged();
//计算总价
sum(list);
}
});
// 商品的checkbox
holder.item_checkbox.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//通过CheckBox的Boolean值设置商品是否选中
list.get(position).setItemSelected(holder.item_checkbox.isChecked());
/**
* 如果i商品和j商品为同一商家,并且为j商品选中状态取反(不取反会把所有商家选中)
*/
for (int i = 0; i < list.size(); i++) {
for (int j = 0; j < list.size(); j++) {
if (list.get(i).getSellerid() == list.get(j).getSellerid() && !list.get(j).isItemSelected()) {
list.get(i).setShopSelected(false);
break;
} else {
list.get(i).setShopSelected(true);
}
}
}
notifyDataSetChanged();
//计算价格
sum(list);
}
});
//删除
holder.item_del.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//移除
list.remove(position);
setFirst(list);
notifyDataSetChanged();
sum(list);
}
});
//加减
holder.plusViewId.setLister(new PlusView.ClickLister() {
@Override
public void click(int count) {
list.get(position).setNum(count);
notifyDataSetChanged();
sum(list);
}
});
}
/**
* 计算总价
*
* @param list
*/
private void sum(List<ShopBean.DataBean.ListBean> list) {
int totalNum = 0;
float totalMoney = 0.0f;
boolean allCheck = true;
for (int i = 0; i < list.size(); i++) {
if (list.get(i).isItemSelected()) {
totalNum += list.get(i).getNum();
totalMoney += list.get(i).getNum() * list.get(i).getPrice();
} else {
allCheck = false;
}
}
//UpdateUiListener接口
listener.setTotal(totalMoney + "", totalNum + "", allCheck);
}
//全选
public void selectAll(boolean check) {
for (int i = 0; i < list.size(); i++) {
list.get(i).setShopSelected(check);
list.get(i).setItemSelected(check);
}
notifyDataSetChanged();
sum(list);
}
//接口回调的监听
public void setListener(UpdateUiListener listener) {
this.listener = listener;
}
@Override
public int getItemCount() {
return list == null ? 0 : list.size();
}
//用来更新总价、件数的接口
interface UpdateUiListener {
public void setTotal(String total, String num, boolean allCheck);
}
static class MyViewHolder extends RecyclerView.ViewHolder {
CheckBox shop_checkbox, item_checkbox;
TextView tvItemShopcartShopname, item_name, item_price;
ImageView item_pic, item_del;
PlusView plusViewId;
public MyViewHolder(View itemView) {
super(itemView);
shop_checkbox = itemView.findViewById(R.id.shop_checkbox);
item_checkbox = itemView.findViewById(R.id.item_checkbox);
tvItemShopcartShopname = itemView.findViewById(R.id.tv_item_shopcart_shopname);
item_name = itemView.findViewById(R.id.item_name);
item_price = itemView.findViewById(R.id.item_price);
plusViewId = itemView.findViewById(R.id.plus_view_id);
item_pic = itemView.findViewById(R.id.item_pic);
item_del = itemView.findViewById(R.id.item_del);
}
}
}
自定义控件
public class PlusView extends LinearLayout {
public ClickLister lister;
private EditText editText;
private Button reverse;
private Button add;
private int mCount = 1;
public PlusView(Context context) {
super(context);
}
public PlusView(Context context, AttributeSet attrs) {
super(context, attrs);
View view = LayoutInflater.from(context).inflate(R.layout.plus_layout,null,false);
reverse = view.findViewById(R.id.reverse);
add = view.findViewById(R.id.add);
editText = view.findViewById(R.id.content);
/**
* 点击-1
*/
reverse.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
String content = editText.getText().toString().trim();
int count = Integer.valueOf(content);
if(count > 1){
mCount = count - 1;
editText.setText(mCount + "");
if (lister != null) {
lister.click(mCount);
}
}
}
});
/**
* 点击+1
*/
add.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
String content = editText.getText().toString().trim();
int count = Integer.valueOf(content) + 1;
mCount = count;
editText.setText(count+"");
if (lister != null) {
lister.click(count);
}
}
});
/**
* ****&&&***¥¥¥***
*/
addView(view);
}
public PlusView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
/**
* 点击之后改变件数
* @param num
*/
public void setEditText(int num){
if (editText != null) {
editText.setText(num + "");
}
}
public void setLister(ClickLister lister){
this.lister = lister;
}
/**
* 加减点击事件
*/
public interface ClickLister{
public void click(int count);
}
}
bean
// 1 显示商家 2 隐藏商家
private int isFirst;
// true 表示商家选中 false 相反
private boolean shopSelected;
// true 表示 当前商品是选中的 false 相反
private boolean itemSelected;
接下来是布局
这是adapter的布局
<?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="wrap_content"
android:orientation="vertical">
<LinearLayout
android:id="@+id/ll_shopcart_header"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical">
<CheckBox
android:id="@+id/shop_checkbox"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingBottom="10dp"
android:paddingLeft="15dp"
android:paddingRight="15dp"
android:paddingTop="10dp"
android:src="@drawable/shopcart_selected" />
<TextView
android:id="@+id/tv_item_shopcart_shopname"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:drawableLeft="@drawable/shopcart_shop"
android:drawablePadding="5dp"
android:padding="10dp"
android:text="宝儿家服装"
android:textColor="@android:color/black" />
</LinearLayout>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:orientation="horizontal">
<CheckBox
android:id="@+id/item_checkbox"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="15dp" />
<ImageView
android:id="@+id/item_pic"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_margin="10dp"
android:src="@mipmap/ic_launcher"/>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:orientation="vertical">
<TextView
android:id="@+id/item_price"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="¥185"
android:textSize="24sp" />
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="5dp"
android:layout_marginTop="5dp">
<TextView
android:id="@+id/item_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="颜色:黑色" />
<TextView
android:id="@+id/tv_item_shopcart_shopname_cloth_size"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:text="尺寸" />
</LinearLayout>
<com.bwie.huang.shopcar.PlusView
android:id="@+id/plus_view_id"
android:layout_width="100dp"
android:layout_height="wrap_content" />
</LinearLayout>
<ImageView
android:id="@+id/item_del"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="20dp"
android:src="@drawable/shopcart_delete" />
</LinearLayout>
</LinearLayout>
</LinearLayout>
</LinearLayout>
这是MainActivity的布局
<?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.support.v7.widget.RecyclerView
android:id="@+id/third_recyclerview"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" />
<LinearLayout
android:id="@+id/third_pay_linear"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="0"
android:background="#FFFFFF"
android:gravity="center_vertical"
android:orientation="horizontal">
<CheckBox
android:id="@+id/third_allselect"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:drawableLeft="@drawable/shopcart_selected"
android:text="全选"
/>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:orientation="vertical">
<TextView
android:id="@+id/third_totalprice"
android:layout_width="200dp"
android:layout_height="wrap_content"
android:text="总价:" />
<TextView
android:id="@+id/third_totalnum"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="共0件商品"
/>
</LinearLayout>
<TextView
android:id="@+id/third_submit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/login_btn"
android:text="去结算"
android:textColor="#000000" />
</LinearLayout>
</LinearLayout>
这是自定义控件
<?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">
<Button
android:id="@+id/reverse"
android:layout_width="10dp"
android:layout_height="wrap_content"
android:text="-"
android:background="#00ffffff"/>
<EditText
android:id="@+id/content"
android:inputType="number"
android:text="1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<Button
android:id="@+id/add"
android:background="#00FFFFFF"
android:layout_width="10dp"
android:layout_height="wrap_content"
android:text="+"/>
</LinearLayout>