Android仿淘宝商品订单评价功能

龙旋

共 4970字,需浏览 10分钟

 ·

2021-07-12 14:54

前言

近期在做一个商城类项目,需要实现对一个订单里的多个商品分别评价的功能(类似于淘宝的评价),花费了一点时间把效果做了出来,并在这里分享出来也权当做了记录,图个日后使用方便。


设计原理


因为每个订单可能有多个商品,所以我直接用一个RecyclerView来展示多个商品,这里主要的难点在于Item的布局。



EvaluationView和EvaluationChoiceImageView是两个自定义View,
分别用来选择评价类型和选择评价图片的。

EvaluationView内部原理比较简单主要是
在LinearLayout内部嵌套了EvaluationItem。



EvaluationChoiceImageView的内部原理主要是使用FlowLayout(流式布局),然后将选择的图片添加到FlowLayout中,FlowLayout的好处就是它能够实现自动换行。



另外EvaluationChoiceImageView可以通过添加监听事件来进行相应的操作

//当点击选择图片的时候(这里一般通过调用addImage()方法进行添加图片操作)itemRegularevaluationEvaluationchoiceimageview.setOnClickAddImageListener(new EvaluationChoiceImageView.OnClickAddImageListener() {                    @Override                    public void onClickAddImage() {                        itemRegularevaluationEvaluationchoiceimageview.addImage("图片的路径地址");                    }                });                //当点击右上方叉号的时候触发此事件(一般用来删除数据)                itemRegularevaluationEvaluationchoiceimageview.setOnClickDeleteImageListener(new EvaluationChoiceImageView.OnClickDeleteImageListener() {                    @Override                    public void onClickDeleteImage(int position) {                       //position是删除图片的位置                    }                });                //当点击图片的时候触发此事件(一般用来查看图片)                itemRegularevaluationEvaluationchoiceimageview.setOnClickImageListener(new EvaluationChoiceImageView.OnClickImageListener() {                    @Override                    public void onClickImage(int position) {                        //position是查看图片的位置                    }                });


代码解释

这里首先是创建一个EvaluationBean用来存放每个商品需要提交的信息。

public class EvaluationBean {    //这里还可以加上其他的信息比如商品的Id    private int evaluatinType=1;//默认好评    private String evaluationContent;//评价内容    private List<File> evaluationImages;//评价图片集合
public EvaluationBean() { if(evaluationImages==null){ evaluationImages=new ArrayList<>(); } }
public int getEvaluatinType() { return evaluatinType; }
public void setEvaluatinType(int evaluatinType) { this.evaluatinType = evaluatinType; }
public String getEvaluationContent() { return evaluationContent; }
public void setEvaluationContent(String evaluationContent) { this.evaluationContent = evaluationContent; }
public List<File> getEvaluationImages() { return evaluationImages; }
public void setEvaluationImages(List<File> evaluationImages) { this.evaluationImages = evaluationImages; }
@Override public String toString() { return "EvaluationBean{" + "evaluatinType=" + evaluatinType + ", evaluationContent='" + evaluationContent + '\'' + ", evaluationImages=" + evaluationImages + '}'; }}


然后再建立一个存放EvaluationBean的集合,

集合的大小与订单中商品的数量相同。

private void initDatas() {        //        添加测试数据(简单的添加图片地址模拟订单)        if(mTempDatas==null){            mTempDatas=new ArrayList<>();            for (int x=0;x<4;x++){                mTempDatas.add(""+x);            }        }        if(evaluationBeans==null){            evaluationBeans=new ArrayList<>();        }        for(int x=0;x<mTempDatas.size();x++){            EvaluationBean evaluationBean=new EvaluationBean();            evaluationBean.setEvaluatinType(1);            evaluationBeans.add(evaluationBean);        }    }


最后将选择好的数据通过遍历集合的方式传到服务器。

for (EvaluationBean evaluationBean:evaluationBeans){                    Log.e("测试",evaluationBean.toString());                    HashMap<String,String> parama=new HashMap<>();                    parama.put("evaluationType",evaluationBean.getEvaluatinType()+"");                    parama.put("evaluationContent",evaluationBean.getEvaluationContent());                    HashMap<String, RequestBody> pics=new HashMap<>();                    for (File file:evaluationBean.getEvaluationImages()){                        pics.put(file.getName(),RequestBody.create(MediaType.parse("image/*"), file));                    }                    RetrofitUtils.getInstance().getApiServier(Api.class)                            .submitEvaluation(parama,pics)                            .subscribeOn(Schedulers.io())                            .observeOn(AndroidSchedulers.mainThread())                            .subscribe(new Consumer<ResultBean>() {                                @Override                                public void accept(ResultBean resultBean) throws Exception {
} }, new Consumer<Throwable>() { @Override public void accept(Throwable throwable) throws Exception {
} }); }


源码地址:

https://github.com/myml666/EvaluationDemo


到这里就结束啦。
浏览 100
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报