Android 多商品訂單評價(類似淘寶)
前幾日一商城類項目,有一需求,需要對一份訂單的里面幾個商品進行分別評價(圖片,文字內容,星級);以前都是對一份訂單所有商品一起評價,那種簡單的多;
后來,承蒙老大細心指導,終于弄出來個看起來還算湊活的,還是先貼一下效果圖吧。。。
抖動的有點卡,gif圖的問題

圖片的相關操作展示.gif

具體評價實現
*上面這張圖是訂單列表,可以看到有幾個商品,要對這幾個商品進行分條評價;
*這個gif圖是具體的對每一個商品進行上傳圖片,內容,星級評價操作
好了,下面就來分析一下怎么寫出這玩意, 先從布局開始 :
布局很好寫,一看就可看出是一個listview,外加一個提交評論的按鈕,給listview設置layout_weight屬性,固定一下提交按鈕的位置。
android:layout_weight="1"
然后就是listview的item,主要說下上傳圖片那一塊,我添了三個imgview,比較low,做了一些判斷,選擇圖片的控件是單選的,只好一個一個選,這樣也好,比較簡單清楚。
畫了張草圖,大家可以看一下,方便理解;

評價示意圖.png
著重說一下代碼實現:
1,首先,從上個訂單頁面傳過來每個商品的id,圖片,圖片用于顯示,商品id用來判定評價的是哪個商品,id 和圖片用兩個數組存起來;
//demo中在Mainactivity.java
private List<String> img = new ArrayList<>();
private List<String> ids = new ArrayList<>();
2,要給listview 填充數據,和獲得item里面的每條數據,我們就先建一個實體類GoodsAssessBean.java,數據是下面幾個,里面有幾個方法,列出來(因為這是每條item的數據,所以,拿到相應的東西和方法相對好實現);
private String id;//商品id
private String icon;//商品圖片
private String content ="";//商品評價內容
private ArrayList<String> imgList = new ArrayList<>();//七牛返回的圖片url
private ArrayList<Bitmap> bitmapList = new ArrayList<>();//本地的bitmap
private String starts="0";//商品星級評定
/**
* 添加或更換圖片
* @param bitmap 本地 bitmap
* @param index 圖片的二級位置 0 或 1 或 2;初始值為0 需要加1與 bitmapList.size()比較
* @param url 七牛返回的圖片地址
*/
public void addOrSetImage(Bitmap bitmap, int index, String url){
//如果小于等于證明需要更換圖片;
if(index + 1 <= bitmapList.size()){
imgList.set(index, url);
bitmapList.set(index, bitmap);
}else{
//大于的話新增圖片;
addBitMap(bitmap);
save(url);
}
}
/**
* 添加Bitmap
* @param bitmap
*/
public void addBitMap(Bitmap bitmap){
if(bitmapList.size()<3){
bitmapList.add(bitmap);
}
}
/**
*
* @param url 每個item里面的URL
*/
public void save(String url){
imgList.add(url);
}
/**
* 這個方法是把七牛返回的圖片地址進行拼接,用“;”隔開
* @return
*/
public String getItemUrl(){
String urls="";
if(imgList.size() > 0){
for(int i=0;i<imgList.size();i++){
urls+= imgList.get(i)+";";
}
return urls.substring(0,urls.length()-1);
}else {
return " ";
}
}
/**
* 刪除第幾張圖片
* @param index 第二層位置
*/
public void deleteImg(int index){
if(imgList.size()>index){
imgList.remove(index);
bitmapList.remove(index);
}
}
/**
* 把每個 item(每個商品)的評價內容,星級,圖片等轉成json格式;
* @return
*/
public String toSString(){
String str = "";
ReturnBean rb = new ReturnBean();
rb.setContent(getContent());
rb.setComment_img(getItemUrl());
rb.setGoods_num(getStarts());
rb.setOrdergoods_id(getId());
try {
str = JsonUtil.toJsonString(rb);
} catch (IOException e) {
e.printStackTrace();
}
return str;
}
public ReturnBean getReturnBean(){
ReturnBean rb = new ReturnBean();
rb.setContent(getContent());
rb.setComment_img(getItemUrl());
rb.setGoods_num(getStarts());
rb.setOrdergoods_id(getId());
return rb;
}
3,在自己寫一個圖片幫助類AssessImgHelp。在這個類里,我們把寫一個方法,把拿到的商品id,和商品圖片存到實體類里,在這里面也有些方法,列出來。
public ArrayList<GoodsAssessBean> mBeanList = new ArrayList<>();
public AssessImgHelp(List<String> ids,List<String> icon){
for(int i=0;i<ids.size();i++){
mBeanList.add(new GoodsAssessBean(ids.get(i), icon.get(i)));
}
}
public ArrayList<GoodsAssessBean> getBeanList(){
return mBeanList;
}·
/**
*
* @param outIndex item的位置 相當于position
* @param bitmap bitmap用于本地顯士
* @param url 七牛返回地址
* @param inIndex 圖片位置
*/
public void doQiNiuDone(int outIndex, Bitmap bitmap, String url,int inIndex){
//哪個item調用GoodsAssessBean.java里的方法,也就是添加更換圖片
mBeanList.get(outIndex).addOrSetImage(BitmapUtils.compressImage(bitmap), inIndex, url);
}
//長按刪除圖片
public void longDelete(int outIndex,int inIndex){
//調用GoodsAssessBean.java里的刪除方法
mBeanList.get(outIndex).deleteImg(inIndex);
}
//生成json串
public String jsonSString(){
String str="";
ArrayList<ReturnBean> beanList = new ArrayList<>();
for(int i=0; i< getBeanList().size(); i++){
str += getBeanList().get(i).toSString();
beanList.add(getBeanList().get(i).getReturnBean());
}
Log.e("123", "beanList" + JsonUtil.object2JSON(beanList));
return JsonUtil.object2JSON(beanList);
}
4,最后一個幫助類AssessBeanUtils.java;存入list的position和每個item里面圖片的位置,貼一下;
private int outIndex;
private int inIndex;
public void setBean(int outIndex,int inIndex){
this.outIndex = outIndex;
this.inIndex = inIndex;
}
public int getOutIndex() {
return outIndex;
}
public int getInIndex() {
return inIndex;
}
5,好的,現在到目前為止,我們所有的數據都能拿的到,還有一些圖片的刪除,更換,添加等等方法全部準備完畢,剩下的只是在MainActivity中調用即可(demo中的MainActivity),著重看幾個地方;
//list之外的星級判定,物流,描述等獲取可以用setOnRatingBarChangeListener()方法;
mRatingBarMiaoshu.setOnRatingBarChangeListener(new RatingBar.OnRatingBarChangeListener() {
@Override
public void onRatingChanged(RatingBar ratingBar, float rating, boolean fromUser) {
miaoshu = rating + "";
}
});
/*
* 填充數據
* */
private void showData() {
//長按圖片抖動效果
final Animation anim = AnimationUtils.loadAnimation(MainActivity.this, R.anim.myanim);
mAdapter = new CommonAdapter<GoodsAssessBean>(MainActivity.this, assessImgHelp.getBeanList(), R.layout.item_assess) {
@Override
public void convert(ViewHolder helper, final GoodsAssessBean item, final int position) {
//加載商品圖片
ImageLoad.loadImgDefault(MainActivity.this, (ImageView) helper.getView(R.id.m_assess), item.getIcon());
//獲取商品星級評價
((RatingBar) helper.getView(R.id.m_ratingBar_shop)).setOnRatingBarChangeListener(new RatingBar.OnRatingBarChangeListener() {
@Override
public void onRatingChanged(RatingBar ratingBar, float rating, boolean fromUser) {
item.setStarts(rating + "");
}
});
//獲取評價內容
((EditText) helper.getView(R.id.m_assess_edt)).addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
item.setContent(s + "");
}
});
//三個imageView和三個刪除按鈕
final ImageView img1 = helper.getView(R.id.m_menmian1_icon);
final ImageView img2 = helper.getView(R.id.m_menmian2_icon);
final ImageView img3 = helper.getView(R.id.m_menmian3_icon);
final ImageView imgclose1 = helper.getView(R.id.m_image_one);
final ImageView imgclose2 = helper.getView(R.id.m_image_two);
final ImageView imgclose3 = helper.getView(R.id.m_image_three);
img1.setScaleType(ImageView.ScaleType.CENTER_CROP);//CENTER_CROP FIT_XY
img2.setScaleType(ImageView.ScaleType.CENTER_CROP);//CENTER_CROP FIT_XY
img3.setScaleType(ImageView.ScaleType.CENTER_CROP);//CENTER_CROP FIT_XY
//獲取本地圖片數量。分別對應相應的顯示
int size = item.getBitMapListSize();
if (size == 0) {
setImageViewVisibility(img1, true, img2, false, img3, false);
img1.setImageResource(R.mipmap.pj_tj);//默認圖片
} else if (size == 1) {
setImageViewVisibility(img1, true, img2, true, img3, false);
img1.setImageBitmap(item.getBitmapList().get(0));
img2.setImageResource(R.mipmap.pj_tj);
} else if (size == 2) {
setImageViewVisibility(img1, true, img2, true, img3, true);
img1.setImageBitmap(item.getBitmapList().get(0));
img2.setImageBitmap(item.getBitmapList().get(1));
img3.setImageResource(R.mipmap.pj_tj);
} else if (size == 3) {
setImageViewVisibility(img1, true, img2, true, img3, true);
img1.setImageBitmap(item.getBitmapList().get(0));
img2.setImageBitmap(item.getBitmapList().get(1));
img3.setImageBitmap(item.getBitmapList().get(2));
}
//點擊事件
img1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Log.e("123", "img: " + img1.getId());
mAssessBean.setBean(position, 0);//存儲一級二級位置
new PopupWindows(MainActivity.this);//彈出選擇頭像,相冊
}
});
img2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mAssessBean.setBean(position, 1);
new PopupWindows(MainActivity.this);
}
});
img3.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mAssessBean.setBean(position, 2);
new PopupWindows(MainActivity.this);
}
});
img1.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
//一些小細節判斷,如果第一張沒有圖片,長按提示請選擇圖片
if (assessImgHelp.getBeanList().get(position).getImgListSize() > 0) {
img1.startAnimation(anim);//抖動效果
imgclose1.setVisibility(View.VISIBLE);//顯示刪除按鈕
} else {
toast("請添加圖片");
}
return true;
}
});
//刪除按鈕點擊事件
imgclose1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
assessImgHelp.longDelete(position, 0);//調用刪除方法
mAdapter.notifyDataSetChanged();
imgclose1.setVisibility(View.GONE);
toast("刪除成功");
}
});
img2.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
if (assessImgHelp.getBeanList().get(position).getImgListSize() > 1) {
img2.startAnimation(anim);
imgclose2.setVisibility(View.VISIBLE);
} else {
toast("請添加圖片");
}
return true;
}
});
imgclose2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
assessImgHelp.longDelete(position, 1);
mAdapter.notifyDataSetChanged();
imgclose2.setVisibility(View.GONE);
toast("刪除成功");
}
});
img3.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
if (assessImgHelp.getBeanList().get(position).getImgListSize() > 2) {
img3.startAnimation(anim);
imgclose3.setVisibility(View.VISIBLE);
} else {
toast("請添加圖片");
}
return true;
}
});
imgclose3.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
assessImgHelp.longDelete(position, 2);
mAdapter.notifyDataSetChanged();
imgclose3.setVisibility(View.GONE);
toast("刪除成功");
}
});
}
};
mAssessList.setAdapter(mAdapter);
}
//圖片的顯示與隱藏
public void setImageViewVisibility(ImageView img1, boolean boo1, ImageView img2, boolean boo2, ImageView img3, boolean boo3) {
img1.setVisibility(boo1 ? View.VISIBLE : View.GONE);
img2.setVisibility(boo2 ? View.VISIBLE : View.GONE);
img3.setVisibility(boo3 ? View.VISIBLE : View.GONE);
}
后面的就是一些調用相冊,相機,選取圖片,上傳七牛,還有就是6.0權限問題也有判斷。
七牛上傳成功之后,調這個方法:
//第一個是position,第三個是七牛返回的圖片地址,第四個是圖片位置;
assessImgHelp.doQiNiuDone(mAssessBean.getOutIndex(), bitmap, key, mAssessBean.getInIndex());
來自:http://www.jianshu.com/p/17763c96bfc4