Android 购物车加减功能的实现代码

Android 实现购物车加减功能,效果图如下所示:

public class adderView extends LinearLayout implements View.OnClickListener, TextWatcher {
 private int amount = 0; //购买数量
 private int goods_storage = Integer.MAX_VALUE; //商品库存
 private OnAmountChangeListener mListener;
 private EditText etAmount;
 private Button btnDecrease;
 private Button btnIncrease;
 public adderView(Context context) {
  this(context, null);
 }
 public adderView(Context context, AttributeSet attrs) {
  super(context, attrs);
  LayoutInflater.from(context).inflate(R.layout.number_adder, this);
  etAmount = (EditText) findViewById(R.id.etAmount);
  btnDecrease = (Button) findViewById(R.id.btnDecrease);
  btnIncrease = (Button) findViewById(R.id.btnIncrease);
  btnDecrease.setOnClickListener(this);
  btnIncrease.setOnClickListener(this);
  etAmount.addTextChangedListener(this);
  TypedArray obtainStyledAttributes = getContext().obtainStyledAttributes(attrs, R.styleable.AmountView);
  int btnWidth = obtainStyledAttributes.getDimensionPixelSize(R.styleable.AmountView_btnWidth, 100);
  int tvWidth = obtainStyledAttributes.getDimensionPixelSize(R.styleable.AmountView_tvWidth, 200);
  int tvTextSize = obtainStyledAttributes.getDimensionPixelSize(R.styleable.AmountView_tvTextSize, 0);
  int btnTextSize = obtainStyledAttributes.getDimensionPixelSize(R.styleable.AmountView_btnTextSize, 0);
  obtainStyledAttributes.recycle();
  LayoutParams btnParams = new LayoutParams(btnWidth, LayoutParams.MATCH_PARENT);
  btnDecrease.setLayoutParams(btnParams);
  btnIncrease.setLayoutParams(btnParams);
  if (btnTextSize != 0) {
   btnDecrease.setTextSize(TypedValue.COMPLEX_UNIT_PX, btnTextSize);
   btnIncrease.setTextSize(TypedValue.COMPLEX_UNIT_PX, btnTextSize);
  }
  LayoutParams textParams = new LayoutParams(tvWidth, LayoutParams.MATCH_PARENT);
  etAmount.setLayoutParams(textParams);
  if (tvTextSize != 0) {
   etAmount.setTextSize(tvTextSize);
  }
 }
 public void setOnAmountChangeListener(OnAmountChangeListener onAmountChangeListener) {
  this.mListener = onAmountChangeListener;
 }
 public void setGoods_storage(int goods_storage) {
  this.goods_storage = goods_storage;
 }
 public void setTextCount(int count){
  this.amount = count;
  this.etAmount.setText(amount+"");
 }
 @Override
 public void onClick(View v) {
  int i = v.getId();
  if (i == R.id.btnDecrease) {
   if (amount > 0) {
    amount--;
    etAmount.setText(amount + "");
   }
  } else if (i == R.id.btnIncrease) {
   if (amount < goods_storage) {
    amount++;
    etAmount.setText(amount + "");
   }
  }
  etAmount.clearFocus();
  if (mListener != null) {
   mListener.onAmountChange(this, amount);
  }
 }
 @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) {
  if (s.toString().isEmpty())
   return;
  amount = Integer.valueOf(s.toString());
  if (amount > goods_storage) {
   etAmount.setText(goods_storage + "");
   return;
  }
  if (amount == 0){
//   btnDecrease.setBackgroundResource(R.drawable.jian);
  }
  if (amount > 0){
//   btnDecrease.setBackgroundResource(R.drawable.lvjian);
  }
  if (mListener != null) {
   mListener.onAmountChange(this, amount);
  }
 }
 public interface OnAmountChangeListener {
  void onAmountChange(View view, int amount);
 }
<?xml version="1.0" encoding="utf-8"?>
<com.zhy.autolayout.AutoLinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="90px"
 android:focusable="true"
 android:divider="@drawable/divder"
 android:background="@drawable/bg_amout_layout"
 android:showDividers="middle"
 android:orientation="horizontal">
 <Button
  android:id="@+id/btnDecrease"
  android:layout_width="0dp"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:gravity="center"
  android:background="@drawable/jian"/>
 <EditText
  android:id="@+id/etAmount"
  android:layout_width="200px"
  android:layout_height="match_parent"
  android:minWidth="150px"
  android:layout_weight="2"
  android:background="@null"
  android:inputType="number"
  android:textSize="13sp"
  android:text="0"
  android:gravity="center"/>
 <Button
  android:id="@+id/btnIncrease"
  android:layout_width="0dp"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:gravity="center"
  android:background="@drawable/jia"/>
</com.zhy.autolayout.AutoLinearLayout>

到此这篇关于Android 购物车加减功能的实现代码的文章就介绍到这了,更多相关android 购物车加减内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Android组合式自定义控件实现购物车加减商品操作

    本文实例为大家分享了Android实现购物车加减商品操作的具体代码,供大家参考,具体内容如下 MainActivity.java public class MainActivity extends AppCompatActivity { private Addand mAddand; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setConte

  • Android自定义商品购买数量加减控件

    在购买商品时,大家可以自定义数字加减控件,来确定购买商品的实际数量,如何实现此控件,请参考下文: 1.自定义数字加减控件的要求 创建Module -NumberAddSubView A_输入的只能是数字,而且不能通过键盘输入 B_通过加减按钮操作数字 C_监听加减按钮 D_数组有最小值和最大值的限制 E_自定义属性 2.提供接口,让外界监听到数字的变化 1_设置接口 @Override public void onClick(View v) { if (v.getId() == R.id.btn

  • Android 购物车加减功能的实现代码

    Android 实现购物车加减功能,效果图如下所示: public class adderView extends LinearLayout implements View.OnClickListener, TextWatcher { private int amount = 0; //购买数量 private int goods_storage = Integer.MAX_VALUE; //商品库存 private OnAmountChangeListener mListener; priva

  • android自定义加减按钮

    本文实例为大家分享了android自定义加减按钮的具体代码,供大家参考,具体内容如下 1.定义两个shape: my_button_shape_normal.xml: <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectang

  • jQuery实现的购物车物品数量加减功能代码

    本文实例讲述了jQuery实现的购物车物品数量加减功能.分享给大家供大家参考,具体如下: 今天网友翠儿在用Jquery实现购物车物品数量的加减特效的时候遇到问题来问我,我后来帮她解决了这个Jquery特效,现在把它整理出来分享给大家用,虽然功能比较简单,但是很实用. 主要包括了以下功能: 1.数量增加操作功能 2.数量减少操作功能 3.总价计算功能 4.自动判断数量到1的时候,减少操作按钮禁止点击,数量增加时自动恢复 5.保留小数点位数toFixed()函数非常实用 功能代码如下: $(func

  • vue中子组件向父组件传递数据的实例代码(实现加减功能)

    这里讲解一下子组件向父组件传递值的常用方式. 这里通过一个加减法的实例向大家说明一下,这个的原理. 如下图所示: 当没有任何操作的时候父组件的值是 0 当点击加号以后父组件的值是 1 当点击减号以后父组件的值是减一变成 0 具体代码我直接贴出来,刚出炉的代码. <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name=&qu

  • js实现购物车加减以及价格计算功能

    本文实例为大家分享了js实现购物车加减以及价格计算的具体代码,供大家参考,具体内容如下 需求说明: 1.单击"半闭"按钮时,关闭当前页面购物车页面 2.单击"移入收藏"弹出收藏提示 3.单击"删除"弹出确认删除提示 4.单击"结算"按钮,弹出结算信息页面窗口 5.自动计算商品总计 6.单击"删除"按钮,使用parentNode访问当前节点的父亲节点等,使用removeChild( )删除当前商品 效果图:

  • 微信小程序外卖选购页实现切换分类与数量加减功能案例

    本文实例讲述了微信小程序外卖选购页实现切换分类与数量加减功能.分享给大家供大家参考,具体如下: 关于微信小程序外卖界面实现选购切换分类与数量加减功能开发步骤: 效果图 实现以下功能 一. 点击分类项,切换右边的食品,并高亮自身 这个实现比较简单,给一个states数组,用于记录每一项分类的状态,点击设为true,wxml渲染时三目运算判断即可. categoryStates = categoryStates.map(function (item, i) { if (index == i) { i

  • js实现购物车加减和价格运算

    本文实例为大家分享了js实现购物车加减和价格运算的具体代码,供大家参考,具体内容如下 主要实现功能:购物车的加减,单件商品价格的运算,总价格的运算.价格保留两位小数. <div class="content"> <div class="logo"> <img src="images/dd_logo.jpg"><span onclick="guan()">关闭</span&g

  • vue数据操作之点击事件实现num加减功能示例

    本文实例讲述了vue数据操作之点击事件实现num加减功能.分享给大家供大家参考,具体如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Vue num加减</title> <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></scrip

  • vue实现购物车加减

    本文实例为大家分享了vue实现购物车加减的具体代码,供大家参考,具体内容如下 通常我们会在模板中绑定表达式,模板是用来描述视图结构的.如果模板中的表达式存在过多的逻辑,模板会变得臃肿不堪,维护变得非常困难.因此,为了简化逻辑,当某个属性的值依赖于其他属性的值时,我们可以使用计算属性. 那么什么是计算属性呢? 计算属性就是当其依赖属性的值发生变化是,这个属性的值会自动更新,与之相关的DOM部份也会同步自动更新. 实现的效果图如下: 我是使用了bootstrap跟Vue去完成这个效果的. 首先导入包

随机推荐