- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在开发一个与电子商务应用程序类似的应用程序。用户可以将产品添加到购物车。
我有两个下面提到的数组列表。
public ArrayList<Design> cartList = new ArrayList<Design>();
public ArrayList<Design> designList = new ArrayList<Design>();
一个用于显示产品列表,另一个用于保存用户添加的产品。我有两项 Activity (参见图片)
此 Activity 是在 recyclerview 中展示产品。在此我在购物车中添加了两项商品。
这是我的第二个 Activity ,显示所有购物车商品。 (用户也可以删除、增加或减少此 Activity 的数量。)
现在我想要的是,当用户返回到第一个 Activity 时,我想比较来自 cartList 的 designList 中的两个列表更新数量(个)。下面的屏幕截图是我按回或重新访问时的第一个 Activity 。
此图像应与第一张图像类似。我将在这里分享我的代码。
Design.java
public class Design implements Serializable {
public int id;
public String qualityId;
public String qualityName;
public String designId;
public String designName;
public String image;
public String name; //use as shade name
public String discPercent;
public String amount;
public int pcs; //consider quantity here.
}
Single_DesignAdapter.java
public class Single_DesignAdapter extends RecyclerView.Adapter<Single_DesignAdapter.ViewHolder> {
public ArrayList<Design> designList;
private Context context;
private LayoutInflater layoutInflater;
public ArrayList<Design> cartList = null;
public Single_DesignAdapter(Context context, ArrayList<Design> designList) {
this.designList = designList;
this.context = context;
this.layoutInflater = LayoutInflater.from(context);
if (cartList != null) {
String cart = getSharePref(context, "cart");
Design[] designs = new Gson().fromJson(cart, Design[].class);
cartList = (ArrayList<Design>) Arrays.asList(designs);
}
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = layoutInflater.inflate(R.layout.single_design, parent, false);
return new ViewHolder(view);
}
@Override
public void onBindViewHolder(final ViewHolder holder, final int position) {
final Design design = designList.get(position);
holder.tvQuality.setText(design.qualityName);
holder.tvDesign.setText(design.designName);
holder.tvShade.setText(design.name);
if (!design.discPercent.equals("0")) {
holder.tvDisPer.setText("-"+design.discPercent+"%");
holder.tvAmount.setPaintFlags(holder.tvAmount.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
int a = Integer.parseInt(design.amount);
float b = Float.parseFloat(design.discPercent) / 100;
holder.tvAmount.setText("₹ " + design.amount);
int c = (int) (a * b);
int d = a-c;
holder.tvDiscAmt.setText("₹ " +d);
Picasso.with(context).load(design.image).into(holder.ivDesign);
} else {
holder.tvAmount.setText("₹ " + design.amount);
Picasso.with(context).load(design.image).into(holder.ivDesign);
holder.tvDisPer.setVisibility(View.INVISIBLE);
holder.tvDiscAmt.setVisibility(View.INVISIBLE);
}
if (cartList != null) {
for (Design d : cartList) {
if (design.id == d.id) {
design.pcs = d.pcs;
}
}
}
if (design.pcs != 0) {
holder.llAdd.setVisibility(View.GONE);
holder.llPlusMinus.setVisibility(View.VISIBLE);
holder.btPcsCount.setText(Integer.toString(design.pcs));
}
holder.btAdd.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
holder.llAdd.setVisibility(View.GONE);
holder.llPlusMinus.setVisibility(View.VISIBLE);
if (cartList != null) {
if (cartList.contains(design)) {
cartList.remove(design);
design.pcs = 1;
cartList.add(design);
saveSharedPref(context, "cart", new Gson().toJson(cartList));
((Activity) context).invalidateOptionsMenu();
} else {
design.pcs = 1;
cartList.add(design);
saveSharedPref(context, "cart", new Gson().toJson(cartList));
((Activity) context).invalidateOptionsMenu();
}
} else {
cartList = new ArrayList<Design>(Arrays.asList(design));
cartList.remove(design);
design.pcs = 1;
cartList.add(design);
saveSharedPref(context, "cart", new Gson().toJson(cartList));
((Activity) context).invalidateOptionsMenu();
}
}
});
holder.btPlus.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (Integer.parseInt(holder.btPcsCount.getText().toString()) >= 1) {
int a = Integer.parseInt(holder.btPcsCount.getText().toString());
a++;
holder.btPcsCount.setText(Integer.toString(a));
if (cartList != null) {
if (cartList.contains(design)) {
cartList.remove(design);
design.pcs = a;
cartList.add(design);
saveSharedPref(context, "cart", new Gson().toJson(cartList));
((Activity) context).invalidateOptionsMenu();
} else {
design.pcs = a;
cartList.add(design);
saveSharedPref(context, "cart", new Gson().toJson(cartList));
((Activity) context).invalidateOptionsMenu();
}
}
}
}
});
holder.btMinus.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (Integer.parseInt(holder.btPcsCount.getText().toString()) <= 1) {
holder.llAdd.setVisibility(View.VISIBLE);
holder.llPlusMinus.setVisibility(View.GONE);
cartList.remove(design);
saveSharedPref(context, "cart", new Gson().toJson(cartList));
((Activity) context).invalidateOptionsMenu();
} else {
int a = Integer.parseInt(holder.btPcsCount.getText().toString());
a--;
holder.btPcsCount.setText(Integer.toString(a));
cartList.remove(design);
design.pcs = a;
cartList.add(design);
saveSharedPref(context, "cart", new Gson().toJson(cartList));
((Activity) context).invalidateOptionsMenu();
}
}
});
}
@Override
public int getItemCount() {
return designList.size();
}
public class ViewHolder extends RecyclerView.ViewHolder {
public LinearLayout llPer, llAdd, llPlusMinus;
public Button btPlus, btMinus, btPcsCount, btAdd;
public ImageView ivDesign;
public TextView tvDesign, tvQuality, tvShade, tvAmount, tvDiscAmt, tvDisPer;
public ViewHolder(View itemView) {
super(itemView);
llAdd = (LinearLayout) itemView.findViewById(R.id.llAdd);
llPlusMinus = (LinearLayout) itemView.findViewById(R.id.llPlusMinus);
btPlus = (Button) itemView.findViewById(R.id.btPlus);
btAdd = (Button) itemView.findViewById(R.id.btAdd);
//other findViewByIds
}
}
}
MainActivity.java
public class MainActivity extends AppCompatActivity {
private RecyclerView recyclerView;
private Single_DesignAdapter adapter;
private ArrayList<Design> designList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
recyclerView = (RecyclerView) findViewById(R.id.recycler_view);
}
@Override
protected void onResume() {
super.onResume();
designList = new ArrayList<Design>();
designList = list();
/*if (cartList != null) {
String cart = getSharePref(MainActivity.this, "cart");
Design[] designs = new Gson().fromJson(cart, Design[].class);
cartList = (ArrayList<Design>) Arrays.asList(designs);
}*/
recyclerView.setLayoutManager(new LinearLayoutManager(MainActivity.this));
recyclerView.setHasFixedSize(true);
adapter = new Single_DesignAdapter(MainActivity.this, designList);
recyclerView.setAdapter(adapter);
invalidateOptionsMenu();
}
public ArrayList<Design> list() {
ArrayList<Design> arrayList = new ArrayList<Design>();
Design design = new Design();
design.id = 1;
design.name = "Black";
design.image = "http://linksolutions.in/Demo/images/1.jpg";
design.designName = "11001";
design.qualityName = "Cotton";
design.amount = "1000";
design.discPercent = "5";
Design design2 = new Design();
design2.id = 2;
design2.name = "Green";
design2.image = "http://linksolutions.in/Demo/images/2.jpg";
design2.designName = "11001";
design2.qualityName = "Cotton";
design2.amount = "900";
design2.discPercent = "9";
Design design3 = new Design();
design3.id = 3;
design3.name = "Green";
design3.image = "http://linksolutions.in/Demo/images/2.jpg";
design3.designName = "11002";
design3.qualityName = "Satin";
design3.amount = "1200";
design3.discPercent = "12";
arrayList.add(design);
arrayList.add(design2);
arrayList.add(design3);
return arrayList;
}
public static void setBadgeCount(Context context, LayerDrawable icon, int count) {
BadgeDrawable badge;
// Reuse drawable if possible
Drawable reuse = icon.findDrawableByLayerId(R.id.ic_badge);
if (reuse != null && reuse instanceof BadgeDrawable) {
badge = (BadgeDrawable) reuse;
} else {
badge = new BadgeDrawable(context);
}
badge.setCount(count);
icon.mutate();
icon.setDrawableByLayerId(R.id.ic_badge, badge);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.cart_menu, menu);
MenuItem itemCart = menu.findItem(R.id.menu_cart);
LayerDrawable icon = (LayerDrawable) itemCart.getIcon();
String list = getSharePref(MainActivity.this, "cart");
if (list != null) {
Design[] designs = new Gson().fromJson(list, Design[].class);
int count = designs.length;
setBadgeCount(MainActivity.this, icon, count);
}
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menu_cart:
Intent intent = new Intent(MainActivity.this, CheckOutActivity.class);
startActivity(intent);
return false;
default:
break;
}
return false;
}
}
我以为这段代码会起作用,但事实并非如此。有没有其他方法可以解决这个问题,请建议。
最佳答案
刚刚更改了以下构造函数代码,它就开始工作了。
public Single_DesignAdapter(Context context, ArrayList<Design> designList) {
this.designList = designList;
this.context = context;
this.layoutInflater = LayoutInflater.from(context);
String cart = getSharePref(context, "cart");
Design[] designs = new Gson().fromJson(cart, Design[].class);
if (cartList != null) {
cartList = new ArrayList<Design>(Arrays.asList(designs));
} else {
if (designs != null) {
cartList = new ArrayList<Design>();
for (Design d : designs) {
cartList.add(d);
}
}
}
}
关于java - 添加到购物车设计在 Android 中工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43471357/
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
.NET 框架:4.5.1 我在 Blend for visual studio 2015 中遇到一个奇怪的错误,我找不到它的来源。 如果我在 VS 中打开我的 WPF 解决方案,它会加载并运行良好。
我经常遇到这样的问题,与 Hierarchical RESTful URL design 非常相似 假设该服务仅提供用户上传文档。 POST, GET /accounts PUT, DELETE /a
在 Rails 应用程序中,我使用 devise 来管理我的用户,而我用来销毁 session 的链接不再有效。它正在工作,现在我添加了事件管理员,但没有。 我的链接是 :delete, :clas
我已经坚持了超过 24 小时,试图按照此处发布的其他解决方案进行操作,但我无法使其正常工作。我是 Rails 新手,需要帮助! 我想让我的/users/edit 页面正常工作,以便我可以简单地更改用户
Devise 在以下情况下不会使用户超时: 用户登录,关闭选项卡,然后在超时 + X 分钟内重新访问该 URL。用户仍处于登录状态。 如果选项卡已打开并且稍后刷新/单击,则超时可以正常工作。这意味着
我想使用这样的 slider 我希望该 slider 根据提供给它的值进行相应调整。到目前为止,我只能应用具有渐变效果的背景,但无法获得这种效果。请通过提供样式代码来帮助我。
您应该为每种方法创建一个请求/响应对象,还是应该为每个服务创建一个? 如果我在所有方法中使用它,我的服务请求对象中将只有 5 个不同的东西,因为我对几乎所有方法使用相同的输入。 响应对象将只有一个字典
我正在尝试在 REST 中对实体的附件进行建模。假设一个缺陷实体可以附加多个附件。每个附件都有描述和一些其他属性(上次修改时间、文件大小...)。附件本身是任何格式的文件(jpeg、doc ...)
我有以下表格: Blogs { BlogName } BlogPosts { BlogName, PostTitle } 博客文章同时建模一个实体和一个关系,根据 6nf(根据第三个宣言)这是无效的。
如果 A 类与 B、C 和 D 类中的每一个都有唯一的交互,那么交互的代码应该在 A 中还是在 B、C 和 D 中? 我正在编写一个小游戏,其中许多对象可以与其他对象进行独特的交互。例如,EMP点击
关于如何记住我与 Omniauth 一起工作似乎有些困惑。 根据这个wiki ,您需要在 OmniauthCallbacksController 中包含以下内容: remember_me(user)
设计问题: 使用 非线程安全 组件(集合,API,...)在/带有 多线程成分 ... 例子 : 组件 1 :多线程套接字服务器谁向消息处理程序发送消息... 组件 2 :非线程安全 消息处理程序 谁
我们目前正在设计一个 RESTful 应用程序。我们决定使用 XML 作为我们的基本表示。 我有以下关于在 XML 中设计/建模应用程序数据的问题。 在 XML 中进行数据建模的方法有哪些?从头开始然
我正在设计一个新的 XSD 来从业务合作伙伴那里获取积分信息。对于每笔交易,合作伙伴必须提供至少一种积分类型的积分值。我有以下几点:
设计支持多个版本的 API 的最佳方法是什么。我如何确保即使我的数据架构发生更改(微小更改),我的 api 的使用者也不会受到影响?任何引用架构、指南都非常有用。 最佳答案 Mark Nottingh
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 4 年前。 Improv
我想用 php 创建一个网站,其工作方式与 https://www.bitcoins.lc/ 相同。确实,就每个页面上具有相同布局但内容会随着您更改链接/页面而改变而言,我如何在 php 中使用lay
我有一个关于编写 Swing UI 的问题。如果我想制作一个带有某些选项的软件,例如在第一个框架上,我有三个按钮(新建、选项、退出)。 现在,如果用户单击新按钮,我想将框架中的整个内容更改为其他内容。
我正在尝试找出并学习将应用程序拥有的一堆Docker容器移至Kubernetes的模式和最佳实践。诸如Pod设计,服务,部署之类的东西。例如,我可以创建一个其中包含单个Web和应用程序容器的Pod,但
我是一名优秀的程序员,十分优秀!