Android studio模拟制作-简易的订餐交易小案例
一、最终呈现效果
订餐支付小案例效果
二、布局设计activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity" ><TextViewandroid:id="@+id/textView5"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="欢迎来到老王订餐助手"android:textSize="35sp"app:layout_constraintBottom_toTopOf="@+id/imageView6"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent" /><ImageViewandroid:id="@+id/imageView5"android:layout_width="130dp"android:layout_height="150dp"android:layout_marginTop="148dp"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:srcCompat="@drawable/cx" /><ImageViewandroid:id="@+id/imageView6"android:layout_width="126dp"android:layout_height="150dp"android:layout_marginStart="12dp"android:layout_marginLeft="12dp"android:layout_marginTop="148dp"app:layout_constraintStart_toEndOf="@+id/imageView5"app:layout_constraintTop_toTopOf="parent"app:srcCompat="@drawable/hx" /><ImageViewandroid:id="@+id/imageView7"android:layout_width="130dp"android:layout_height="150dp"android:layout_marginStart="12dp"android:layout_marginLeft="12dp"android:layout_marginTop="148dp"app:layout_constraintStart_toEndOf="@+id/imageView6"app:layout_constraintTop_toTopOf="parent"app:srcCompat="@drawable/jhj" /><CheckBoxandroid:id="@+id/cb1"android:layout_width="95dp"android:layout_height="45dp"android:layout_marginStart="16dp"android:layout_marginLeft="16dp"android:layout_marginTop="28dp"android:text="川香排骨(45元)"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toBottomOf="@+id/imageView5" /><CheckBoxandroid:id="@+id/cb2"android:layout_width="100dp"android:layout_height="45dp"android:layout_marginStart="44dp"android:layout_marginLeft="44dp"android:layout_marginTop="28dp"android:text="海鲜美食(60元)"app:layout_constraintStart_toEndOf="@+id/cb1"app:layout_constraintTop_toBottomOf="@+id/imageView6" /><CheckBoxandroid:id="@+id/cb3"android:layout_width="96dp"android:layout_height="45dp"android:layout_marginStart="44dp"android:layout_marginLeft="44dp"android:layout_marginTop="28dp"android:text="叫花鸡(55元)"app:layout_constraintStart_toEndOf="@+id/cb2"app:layout_constraintTop_toBottomOf="@+id/imageView7" /><Buttonandroid:id="@+id/pay"android:layout_width="143dp"android:layout_height="51dp"android:layout_marginTop="68dp"android:text="付款"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintHorizontal_bias="0.518"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toBottomOf="@+id/cb2" /></androidx.constraintlayout.widget.ConstraintLayout>
三、layout目录中创建qian.xml布局文件(用于自定义弹框)
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><ImageViewandroid:id="@+id/imageView"android:layout_width="match_parent"android:layout_height="45dp"app:srcCompat="@drawable/q" /><TextViewandroid:id="@+id/tv"android:layout_width="match_parent"android:layout_height="wrap_content"android:gravity="center_horizontal"android:text="TextView"android:textSize="24sp" />
</LinearLayout>
四、功能实现MainActivity.java
package com.itlaowang.myapptest;import androidx.appcompat.app.AppCompatActivity;import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.TextView;
import android.widget.Toast;public class MainActivity extends AppCompatActivity implements View.OnClickListener{CheckBox cb1,cb2,cb3;//声明复选按钮1/2/3变量分别为cb1/cb2/cb3Button pay;//声明付款按钮控件变量为 payprivate int count=0;//用于结算总付价格@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);cb1=findViewById(R.id.cb1);//寻找复选按钮1的IDcb2=findViewById(R.id.cb2);//寻找复选按钮2的IDcb3=findViewById(R.id.cb3);//寻找复选按钮3的IDpay=findViewById(R.id.pay);//寻找付款按钮的ID// cb1.setOnCheckedChangeListener(this);//给复选按钮1安装监听器(OnCheckedChangeListener)
// cb2.setOnCheckedChangeListener(this);//给复选按钮2安装监听器(OnCheckedChangeListener)
// cb3.setOnCheckedChangeListener(this);//给复选按钮3安装监听器(OnCheckedChangeListener)pay.setOnClickListener(this);//给付款按钮安装监听器(OnClickListener)}//实现按钮支付功能@Overridepublic void onClick(View v) {if (cb1.isChecked()) { //如果选中复选按钮1 商品(川香排骨)需要支付45元count += 45;}if (cb2.isChecked()) { //如果选中复选按钮2 商品(海鲜美食)需要支付60元count += 60;}if (cb3.isChecked()) { //如果选中复选按钮3 商品(叫花鸡)需要支付55元count += 55;}// 普通Toast弹出框方法(默认显示在当前Activity最下面)
// Toast.makeText(this, "您支付了"+count+"元", Toast.LENGTH_SHORT).show();//弹框输出:您支付了XXX元(弹框默认在最小角出现,出现时间较短,会自动消失)//自定义弹框方法LayoutInflater inflater=getLayoutInflater();// 创建LayoutInflater(布局加载器)将布局文件孵化为View对象View layout=inflater.inflate(R.layout.qian,null);//孵化方法为inflate(作用:指定将孵化的View布局视图存放在什么容器,一般使用null)TextView tv=layout.findViewById(R.id.tv);//寻找布局内中的文本标签控件(id为tv)的idtv.setText("您支付了"+count+"元");//文本标签控件输出内容Toast toast=new Toast(MainActivity.this);//创建一个Toast对象需要一个上下文参数(参数设置当前的本地类MainActivity)toast.setView(layout);//设置toast弹出框输出布局视图文件中的内容toast.setDuration(Toast.LENGTH_SHORT);//设置toast弹出框设置显示内容持续时间(设置为Toast.LENGTH_SHORT短时间)toast.show();//设置toast弹出框显示count=0;//付款总额清零}}
五、总结
本次练习新增知识点,主要
①掌握Toast用法实现弹框,实现支付交易成功。
②自定义弹框实现支付交易(提升用户体验感)其中提到了孵化方法inflate,本次新增的知识点并不多,更多的对旧的知识点加以巩固。