仿淘宝购物车demo---增加和减少商品数量
来源:互联网 发布:kcf跟踪算法原理 编辑:程序博客网 时间:2024/05/05 17:49
在上一篇博客中,小编简单的介绍了如何使用listview来实现购物车,但是仅仅是简单的实现了列表的功能,随之而来一个新的问题,买商品的时候,我们可能不止想买一件商品,想买多个,或许有因为某种原因点错了,本来想买一件来着,小手不小心抖了一下,把数量错点成了三个,这个时候就涉及到一个新的功能,那就是增加和减少商品的数量,今天这篇博文,小编就来和小伙伴们分享一下,如何实现淘宝购物车中增加和减少商品数量的demo。
首先,我们来布局XML文件,具体代码如下所示:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" > <!-- 整体布局,包括增加和减少商品数量的符号以及中间的商品数量 --> <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <!-- 减少商品数量的布局 --> <Button android:id="@+id/addbt" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textColor="#0157D3" android:text="-"> </Button> <!-- 商品数量的布局 --> <EditText android:id="@+id/edt" android:text="0" android:layout_width="wrap_content" android:layout_height="wrap_content"> </EditText> <!-- 增加商品数量的布局 --> <Button android:id="@+id/subbt" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textColor="#0157D3" android:text="+"> </Button> <!-- 显示商品数量的布局 --> <TextView android:id="@+id/ttt" android:layout_width="wrap_content" android:layout_height="wrap_content"> </TextView> </LinearLayout></RelativeLayout>
我们来看一下xml布局的页面会是什么样子的nie,如下图所示:
接着,我们来编写java类里面的代码,具体代码如下所示:
package jczb.shoping.ui;import android.R.string;import android.app.Activity;import android.os.Bundle;import android.text.Editable;import android.text.TextWatcher;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;import android.widget.EditText;import android.widget.Toast;public class ShoppingCartItemActivity extends Activity {private Button btAdd, btReduce;private EditText edtNumber;int num=0; //数量protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_shoppingcart_item); btAdd=(Button)findViewById(R.id.cart_pro_reduce); btReduce=(Button) findViewById(R.id.cart_pro_add); edtNumber=(EditText) findViewById(R.id.cart_pro_count); btAdd.setTag("+"); btReduce.setTag("-"); //设置输入类型为数字 edtNumber.setInputType(android.text.InputType.TYPE_CLASS_NUMBER); edtNumber.setText(String.valueOf(num)); SetViewListener();}/** * 设置文本变化相关监听事件 */private void SetViewListener(){btAdd.setOnClickListener(new OnButtonClickListener());btReduce.setOnClickListener(new OnButtonClickListener());edtNumber.addTextChangedListener(new OnTextChangeListener());}/** * 加减按钮事件监听器 * * */class OnButtonClickListener implements OnClickListener{@Overridepublic void onClick(View v){String numString = edtNumber.getText().toString();if (numString == null || numString.equals("")){num = 0;edtNumber.setText("0");} else{if (v.getTag().equals("-")){if (++num < 0) //先加,再判断{num--;Toast.makeText(ShoppingCartItemActivity.this, "请输入一个大于0的数字",Toast.LENGTH_SHORT).show();} else{edtNumber.setText(String.valueOf(num));}} else if (v.getTag().equals("+")){if (--num < 0) //先减,再判断{num++;Toast.makeText(ShoppingCartItemActivity.this, "请输入一个大于0的数字",Toast.LENGTH_SHORT).show();} else{edtNumber.setText(String.valueOf(num));}}}}}/** * EditText输入变化事件监听器 */class OnTextChangeListener implements TextWatcher{@Overridepublic void afterTextChanged(Editable s){String numString = s.toString();if(numString == null || numString.equals("")){num = 0;}else {int numInt = Integer.parseInt(numString);if (numInt < 0){Toast.makeText(ShoppingCartItemActivity.this, "请输入一个大于0的数字",Toast.LENGTH_SHORT).show();} else{//设置EditText光标位置 为文本末端edtNumber.setSelection(edtNumber.getText().toString().length());num = numInt;}}}@Overridepublic void beforeTextChanged(CharSequence s, int start, int count,int after){}@Overridepublic void onTextChanged(CharSequence s, int start, int before,int count){}}}
最后,我们来看一下运行效果,如下图所示:
小编寄语:该博文小编主要简单的介绍了淘宝中如何实现增加和减少商品数量的小例子,希望可以帮助到有需要的小伙伴们,还是那句话对于小编来说,既是挑战更是机遇,因为知识都是相通的,再者来说,在小编的程序人生中,留下最珍贵的记忆,虽然以后小编不一定从事安卓这个行业,代码世界里,很多种事,有的甜蜜,有的温馨,有的婉转成歌,有的绵延不息,在这些故事里,我们唯一的共通之处就是,某年,某月,某个波澜不惊的日子里,曾经很爱很爱你!爱你--这段实习的日子里,安卓带给小编的种种的惊喜。
4 0
- 仿淘宝购物车demo---增加和减少商品数量
- 简单购物车(增加数量和减少数量)
- 减少购物车中的商品数量
- 购物车的单项增加减少商品和批量减少增加商品以及清空购物车的实例演示
- js——input框实现淘宝一样的点击后商品数量的增加和减少
- HTML 购物车计算总价+添加或者减少商品数量
- Android仿淘宝购物车demo
- jquery来实现的添加商品和减少商品数量,用于购物车等实时改变价格
- Android-----购物车(包含侧滑删除,商品筛选,商品增加和减少,价格计算,店铺分类等)
- ECSHOP商品页加入购物车弹出仿淘宝效果
- 仿淘宝购物车商品颜色、尺寸选择。
- 仿淘宝购物车
- 仿淘宝购物车
- 仿淘宝购物车
- 仿淘宝购物车
- 修改购物车商品数量
- 类似于购物车,点击按钮,购物数量的增加或者减少
- Android自定义控件之高仿京东购物车添加或者减少商品数量功能
- 关于fragment的构造函数问题
- 适配器模式
- 远程执行命令的psexec工具的基本使用——简单、强大
- HDU 2094 产生冠军(拓扑排序)
- spring quartz定时器,及其动态处理方式
- 仿淘宝购物车demo---增加和减少商品数量
- javascript字符串
- HDU 4710 Balls Rearrangement
- 个人对深度优先搜索和广(宽)度优先搜索的理解
- BPM那些事儿——BPM的产生缘由
- UVA 10055 -Hashmat the Brave Warrior
- iOS申请开发者账号问题总结
- Android性能优化(一),总纲
- Nginx发布1.9.0版本,新增支持TCP代理和负载均衡的stream模块