40.我的订单(使用NineGrilView,显示九宫格图片)
来源:互联网 发布:如何做淘宝海外买手 编辑:程序博客网 时间:2024/06/06 12:25
我们在编写我的订单的时候会,运用到recyclerview来显示商品图片,但是这个需要在recyclerview中再嵌套recyclerview,使用很不方便,所以我们这里使用了NineGirdView
使用地址;https://github.com/w4lle/NineGridView
1.首先添加依赖
compile 'com.w4lle.library:NineLayout:1.0.0'
2.布局文件中使用控件
<com.w4lle.library.NineGridlayout android:layout_marginTop="8dp" android:id="@+id/iv_ngrid_layout" android:layout_height="wrap_content" android:layout_width="match_parent" />
3.在adapter中使用ninegridlayout:
我们将ninegridlayout写在父类的adapter中,传入的数据时list<ShoppingCart> list,将这个list中的数据放入到九宫格中,然后在viewholder中实例化ninegridlayout对象,然后在父类的adapter中使用
package zuo.com.ui.adapter;import android.content.Context;import android.graphics.Color;import android.graphics.drawable.ColorDrawable;import android.media.Image;import android.net.Uri;import android.support.v7.widget.RecyclerView;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.Button;import android.widget.ImageView;import android.widget.TextView;import android.widget.Toast;import com.facebook.drawee.backends.pipeline.Fresco;import com.facebook.drawee.backends.pipeline.PipelineDraweeController;import com.facebook.drawee.view.SimpleDraweeView;import com.facebook.imagepipeline.request.ImageRequest;import com.facebook.imagepipeline.request.ImageRequestBuilder;import com.squareup.picasso.Picasso;import com.w4lle.library.NineGridAdapter;import com.w4lle.library.NineGridlayout;import java.util.ArrayList;import java.util.List;import zuo.com.ui.R;import zuo.com.ui.bean.OrderBean;import zuo.com.ui.bean.ShoppingCart;import zuo.com.ui.fragment.CartFragment;/** * Created by Administrator on 2016/11/8. */public class MyOrderAdapter extends RecyclerView.Adapter<MyOrderAdapter.ViewHolder> { private LayoutInflater layoutInflater; private List<OrderBean> list=new ArrayList<>(); private List<OrderBean> lists=new ArrayList<>(); private Context context; public MyOrderAdapter(List<OrderBean> list, List<OrderBean> lists,Context context){ this.list=list; this.lists=lists; this.context=context; } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { layoutInflater=LayoutInflater.from(parent.getContext()); View view=layoutInflater.inflate(R.layout.item_my_order,parent,false); return new ViewHolder(view); } @Override public void onBindViewHolder(final ViewHolder holder, final int position) { holder.textView.setText(list.get(position).getPrice()); holder.nTextView.setText("订单编号:"+"413116905"+position);// Uri uri = Uri.parse(list.get(position).getList().get(0).getImgUrl());// ImageRequest request = ImageRequestBuilder.newBuilderWithSource(uri)// .setProgressiveRenderingEnabled(true)// .build();// PipelineDraweeController controller = (PipelineDraweeController) Fresco.newDraweeControllerBuilder()// .setImageRequest(request)// .build();// holder.simpleDraweeView.setController(controller); // holder.nineGridlayout.setAdapter(new Adapter(context,list.get(position).getList())); holder.button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) {// HotGoodsAdapter.hashMap.get("123").add(list.get(position).getList()); HotGoodsAdapter.hashMap.put("123", lists.get(position).getList()); HotGoodsAdapter.hashMap.put("456", lists.get(position).getList()); HotGoodsAdapter.hashMap.put("789", lists.get(position).getList());// HotGoodsAdapter.hashMap.get("123").subList(0,1);// HotGoodsAdapter.hashMap.get("123").subList(0,1); // CartFragment.carts=list.get(position).getList(); Toast.makeText(context, "成功添加到购物车", Toast.LENGTH_SHORT).show(); // holder.nineGridlayout.setAdapter(new Adapter(context,list.get(position).getList())); } }); } @Override public int getItemCount() { return list.size(); } class ViewHolder extends RecyclerView.ViewHolder{ private TextView textView,nTextView;// private SimpleDraweeView simpleDraweeView; private NineGridlayout nineGridlayout; private Button button; public ViewHolder(View itemView) { super(itemView); nTextView= (TextView) itemView.findViewById(R.id.number_text_view); textView= (TextView) itemView.findViewById(R.id.text_view_price); // simpleDraweeView= (SimpleDraweeView) itemView.findViewById(R.id.drawee_view); nineGridlayout= (NineGridlayout) itemView.findViewById(R.id.iv_ngrid_layout); button= (Button) itemView.findViewById(R.id.button_buy_again); } }************************************************************************************************************ class Adapter extends NineGridAdapter { private List<ShoppingCart> lists; public Adapter(Context context, List<ShoppingCart> lists) { super(context, lists); this.lists=lists; } @Override public int getCount() { return (lists == null) ? 0 : lists.size(); } @Override public String getUrl(int position) { ShoppingCart shoppingCart=lists.get(position); return shoppingCart.getImgUrl(); } @Override public ShoppingCart getItem(int position) { return (lists == null) ? null : lists.get(position); } @Override public long getItemId(int position) { ShoppingCart shoppingCart=lists.get(position); return shoppingCart==null?0:shoppingCart.getId(); } @Override public View getView(int i, View view) { ImageView iv = new ImageView(context); iv.setScaleType(ImageView.ScaleType.CENTER_CROP); iv.setBackgroundColor(Color.parseColor("#f5f5f5")); Picasso.with(context).load(getUrl(i)).placeholder(new ColorDrawable(Color.parseColor("#f5f5f5"))).into(iv); return iv; } }}
4.就能实现效果:
0 0
- 40.我的订单(使用NineGrilView,显示九宫格图片)
- MultiImageView九宫格图片显示
- NineGridLayout九宫格图片使用
- 安卓九宫格图片显示
- 我的九宫格算法
- 九宫格的使用
- 使用九宫格来调整图片
- Qt使用九宫格原理缩放图片
- iOS学习笔记--如何使九宫格布局图片的显示自适应大小
- 九宫格CCScale9Sprite的使用
- EaselJS的九宫格缩放图片
- 自定义九宫格控件NineGridLayout ,实现微信朋友圈图片九宫格显示
- 代码写个九宫格布局显示图片
- 九宫格显示控件
- 绘制九宫格图片
- Magento 后台订单显示图片
- 如何在JSP显示我的订单内容(界面和表如下图)
- 如何在JSP显示我的订单内容(界面和表如下图)
- 数据库设计三大范式
- 有关与java初学者的面试题
- 嵌入式linux面试题解析——Linux应用编程部分
- 【jzoj4870】【涂色游戏】【动态规划】【矩阵快速幂】
- 欢迎使用CSDN-markdown编辑器
- 40.我的订单(使用NineGrilView,显示九宫格图片)
- from序列化后台取值
- Servlet Mapping 中/ 和 /*的区别
- 一天一条Linux指令-basename
- 各大网站css初始化代码
- Python基础-切片和迭代
- uva1030 Image Is Everything
- linux中的共享内存
- springMvc中的@InitBinder