当前位置: 首页 > 编程笔记 >

Android实现仿淘宝购物车增加和减少商品数量功能demo示例

松正阳
2023-03-14
本文向大家介绍Android实现仿淘宝购物车增加和减少商品数量功能demo示例,包括了Android实现仿淘宝购物车增加和减少商品数量功能demo示例的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了Android实现仿淘宝购物车增加和减少商品数量功能。分享给大家供大家参考,具体如下:

在前面一篇《Android实现的仿淘宝购物车demo示例》中,小编简单的介绍了如何使用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
  {
    @Override
    public 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
  {
    @Override
    public 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;
        }
      }
    }
    @Override
    public void beforeTextChanged(CharSequence s, int start, int count,
        int after)
    {
    }
    @Override
    public void onTextChanged(CharSequence s, int start, int before,
        int count)
    {
    }
  }
}

最后,我们来看一下运行效果,如下图所示:

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android布局layout技巧总结》、《Android视图View技巧总结》、《Android编程之activity操作技巧总结》、《Android操作SQLite数据库技巧总结》、《Android操作json格式数据技巧总结》、《Android数据库操作技巧总结》、《Android文件操作技巧汇总》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

 类似资料:
  • 本文向大家介绍vue实现的仿淘宝购物车功能详解,包括了vue实现的仿淘宝购物车功能详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了vue实现的仿淘宝购物车功能。分享给大家供大家参考,具体如下: 下面是一张众所周知的淘宝购物车页面,今天要讲解的案例就是用vue.js做一个类似的页面 首先简单介绍一下可能会用到的一些vue.js的用法: v-bind,绑定属性;例如v-bind:class

  • 本文向大家介绍原生js实现淘宝购物车功能,包括了原生js实现淘宝购物车功能的使用技巧和注意事项,需要的朋友参考一下 js淘宝购物车功能描述:  1、点击“+”,单个商品数量加1,总数量加1;单个商品价格添加,总价也添加。  2、点击“-”,单个商品数量减1,总数量减1;单个商品价格减少,总价也减少。  当该商品数量为0时,点击依然为0;  3、显示出总价,总数量和其中最贵的那个商品的价格。  瞄一

  • 本文向大家介绍jQuery模拟淘宝购物车功能,包括了jQuery模拟淘宝购物车功能的使用技巧和注意事项,需要的朋友参考一下 首先我们要实现的内容的需求有如下几点: 1.在购物车页面中,当选中“全选”复选框时,所有商品前的复选框被选中,否则所有商品的复选框取消选中。 2.当所有商品前的复选框选中时,“全选”复选框被选中,否则“全选”复选框取消选中。 3.单击图标-的时候数量减一而且不能让物品小于0并

  • 本文向大家介绍Android 购物车加减功能的实现代码,包括了Android 购物车加减功能的实现代码的使用技巧和注意事项,需要的朋友参考一下 Android 实现购物车加减功能,效果图如下所示: 到此这篇关于Android 购物车加减功能的实现代码的文章就介绍到这了,更多相关android 购物车加减内容请搜索呐喊教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持呐喊教程!

  • 本文向大家介绍纯jquery实现模仿淘宝购物车结算,包括了纯jquery实现模仿淘宝购物车结算的使用技巧和注意事项,需要的朋友参考一下 这篇文章里,将会提到购物车里的所有功能。包括全选、单选金额改变。在增加数量时金额也会相应改变。 效果图展示: 说下大致的思路吧: 1、首先是计算一行的价格。这个功能在上篇博客里有提到,这里就不列举出来了。 2、遍历选中的几行,将每行的数值相加。 3、将值赋给总金额

  • 本文向大家介绍Android实现购物车功能,包括了Android实现购物车功能的使用技巧和注意事项,需要的朋友参考一下 最近看了一些淘宝购物车的demo,于是也写了一个。 效果图如下: 主要代码如下: actvity中的代码: actvity中XML的代码: -XML中头部可以到网上找一个这里就不放上来了 .checkbox和button的样式可以根据个人喜好设置。 Adaper中的代码: Ada

  • 本文向大家介绍Android实现购物车添加商品特效,包括了Android实现购物车添加商品特效的使用技巧和注意事项,需要的朋友参考一下 一、引言 以前在饿了么上面订餐的时候,曾经看到过这么一个特效,就是将商品加入订单时,会有一个小球呈抛物线状落入购物车中,然后购物车中的数量会改变。具体的效果如下图。 效果很简单,就是一个抛物线的动画,那么我们应该用什么技术来实现呢?想了想,动画层是不个错的选择!下

  • 本文向大家介绍Android实现购物车添加商品动画,包括了Android实现购物车添加商品动画的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android实现购物车添加商品动画的具体代码,供大家参考,具体内容如下 实现需求: 在商品列表页面,从列表Item 添加商品的时候,需要一个动画,仿佛是是往购物车里添加商品。 实现思路: 获取起始点与终点的坐标,利用PathMeasure 绘