Kotlin高仿微信-第17篇-单聊-转账

2023-12-23 10:59

本文主要是介绍Kotlin高仿微信-第17篇-单聊-转账,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 Kotlin高仿微信-项目实践58篇详细讲解了各个功能点,包括:注册、登录、主页、单聊(文本、表情、语音、图片、小视频、视频通话、语音通话、红包、转账)、群聊、个人信息、朋友圈、支付服务、扫一扫、搜索好友、添加好友、开通VIP等众多功能。

Kotlin高仿微信-项目实践58篇,点击查看详情

效果图:

 

 

实现代码:

我的转账页面

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayoutxmlns:app="http://schemas.android.com/apk/res-auto"xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:gravity="right"><androidx.constraintlayout.widget.ConstraintLayoutandroid:id="@+id/transfer_me_root_layout"android:layout_width="240dp"android:layout_height="90dp"android:background="@drawable/wc_redpacket_right_normal"><TextViewandroid:id="@+id/transfer_me_balance"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginLeft="10dp"android:text="0.01"android:textColor="#ffffff"android:textSize="16sp"android:textStyle="bold"android:layout_marginTop="2dp"android:maxLines="1"android:ellipsize="end"android:singleLine="true"app:layout_constraintTop_toTopOf="@+id/transfer_me_icon"app:layout_constraintStart_toEndOf="@+id/transfer_me_icon"/><TextViewandroid:id="@+id/transfer_me_content"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginLeft="10dp"android:text="你发起了一笔转账"android:textColor="#ffffff"android:textSize="12sp"app:layout_constraintTop_toBottomOf="@+id/transfer_me_balance"app:layout_constraintStart_toEndOf="@+id/transfer_me_icon"/><TextViewandroid:layout_width="match_parent"android:layout_height="0.2dp"android:layout_marginLeft="20dp"android:layout_marginRight="10dp"android:background="#ffffff"app:layout_constraintBottom_toTopOf="@+id/redpacket_tip"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toBottomOf="@+id/transfer_me_icon" /><TextViewandroid:id="@+id/redpacket_tip"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginLeft="20dp"android:layout_marginBottom="6dp"android:text="@string/wc_chat_transfer_tip"android:textColor="#d9d6c3"android:textSize="10sp"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintStart_toStartOf="parent" /><androidx.appcompat.widget.AppCompatImageViewandroid:id="@+id/transfer_me_icon"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginStart="20dp"android:layout_marginTop="12dp"android:src="@drawable/wc_chat_transfer_icon"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent" /></androidx.constraintlayout.widget.ConstraintLayout></RelativeLayout>

好友的转账页面:

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:app="http://schemas.android.com/apk/res-auto"><androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/transfer_other_root_layout"android:layout_width="240dp"android:layout_height="90dp"android:background="@drawable/wc_redpacket_left_normal"><androidx.appcompat.widget.AppCompatImageViewandroid:id="@+id/other_transfer_icon"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginLeft="18dp"android:layout_marginTop="10dp"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"android:background="@drawable/wc_chat_transfer_icon"/><TextViewandroid:id="@+id/transfer_other_balance"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="0.01"android:textSize="16sp"android:textColor="#ffffff"android:textStyle="bold"android:layout_marginTop="2dp"android:layout_marginLeft="10dp"app:layout_constraintStart_toEndOf="@+id/other_transfer_icon"app:layout_constraintTop_toTopOf="@+id/other_transfer_icon"/><TextViewandroid:id="@+id/transfer_other_content"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="请收款"android:textSize="12sp"android:textColor="#ffffff"android:textStyle="bold"android:layout_marginLeft="10dp"app:layout_constraintStart_toEndOf="@+id/other_transfer_icon"app:layout_constraintTop_toBottomOf="@+id/transfer_other_balance"/><TextViewandroid:layout_width="match_parent"android:layout_height="0.2dp"android:background="#ffffff"android:layout_marginLeft="20dp"android:layout_marginRight="10dp"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toBottomOf="@+id/other_transfer_icon"app:layout_constraintBottom_toTopOf="@+id/transfer_tip"/><TextViewandroid:id="@+id/transfer_tip"android:layout_width="wrap_content"android:layout_height="wrap_content"app:layout_constraintStart_toStartOf="parent"app:layout_constraintBottom_toBottomOf="parent"android:layout_marginBottom="6dp"android:layout_marginLeft="20dp"android:text="@string/wc_chat_transfer_tip"android:textSize="10sp"android:textColor="#d9d6c3"/></androidx.constraintlayout.widget.ConstraintLayout>
</layout>

package com.wn.wechatclientdemo.fragment.me.paymentimport android.os.Bundle
import android.view.View
import androidx.fragment.app.viewModels
import androidx.navigation.NavController
import androidx.navigation.fragment.findNavController
import com.wn.wechatclientdemo.R
import com.wn.wechatclientdemo.databinding.WcTransferMainBinding
import com.wn.wechatclientdemo.fragment.base.BaseDataBindingFragment
import com.wn.wechatclientdemo.utils.*
import com.wn.wechatclientdemo.view.BaseDialogUtils
import com.wn.wechatclientdemo.viewmodel.ChatViewModel
import com.wn.wechatclientdemo.viewmodel.UserViewModel
import kotlinx.android.synthetic.main.wc_transfer_main.*/*** Author : wangning* Email : maoning20080809@163.com* Date : 2022/5/22 16:43* Description : 查看转账详情*/
class TransferDetailsFragment : BaseDataBindingFragment<WcTransferMainBinding>(){override fun getLayoutRes() = R.layout.wc_transfer_mainprivate val userViewModel: UserViewModel by viewModels()private val chatViewModel: ChatViewModel by viewModels()private var navController : NavController? = nullprivate var balance: Float = 0.0fprivate var messageId = ""private var toUser = ""override fun onViewCreated(view: View, savedInstanceState: Bundle?) {super.onViewCreated(view, savedInstanceState)super.builder().setTitleContent(R.string.wc_base_top_transfer)arguments?.let {toUser = it.get(CommonUtils.QRCommon.TO_USER) as StringmessageId = it.get(CommonUtils.Chat.MESSAGE_ID) as Stringvar balanceStr  = it.get(CommonUtils.QRCommon.TRANSFER_BALANCE) as StringTagUtils.d("转账:${toUser}, ${messageId}, ${balanceStr}")balance = balanceStr.toFloat()trans_main_balance.text = CommonUtils.Base.getFormatBalanceUnit(balance)}navController = findNavController()var account = DataStoreUtils.getAccount()var userBean = userViewModel.getUserLocalAsync(toUser)var chatBean = chatViewModel.getChatByMessageIdAsync(messageId)trans_main_time.text = CommonUtils.Date.getCurrentDate(chatBean.addTime)if(account.equals(toUser)){if(chatBean.isClick == 1){//已经领取trans_main_icon.setImageResource(R.drawable.wc_transfer_time_complete)trans_main_name.text = BaseUtils.getString(R.string.wc_transfer_receive_other)trans_main_receive.visibility = View.GONE} else {//待收款trans_main_name.text = BaseUtils.getString(R.string.wc_transfer_waitfor_other)trans_main_receive.visibility = View.VISIBLE}} else {trans_main_name.text = BaseUtils.getString(R.string.wc_transfer_name_me, userBean.nickName)trans_main_receive.visibility = View.GONE}userViewModel.balanceLiveData.observe(viewLifecycleOwner){dismissLoadingDialog()if(it >0){chatViewModel.updateChatClickByMessageIdLocal(1, messageId)navController?.popBackStack()} else {TagUtils.d("收款失败!")}}trans_main_receive.setOnClickListener {if(balance < 0){ToastUtils.makeText("转账金额不能小于0")} else {showLoadingDialog()userViewModel.updateBalanceServer(toUser, CommonUtils.User.OPERATOR_PLUS, balance)}}}override fun onDestroy() {super.onDestroy()}private var loadingUtils : BaseDialogUtils? = null//显示加载对话框private fun showLoadingDialog(){loadingUtils = BaseDialogUtils(requireActivity())loadingUtils!!.builder().hideCancel().hideConfirm().setCancelable(true).setOnLoadingClick(object : BaseDialogUtils.OnLoadingClick{override fun onClickCancel() {ToastUtils.makeText(requireActivity(), "对话框取消按钮")}override fun onClickConfirm() {ToastUtils.makeText(requireActivity(), "对话框确定按钮")}})loadingUtils?.show()}//隐藏加载对话框private fun dismissLoadingDialog(){loadingUtils?.dismiss()}}

/*** Author : wangning* Email : maoning20080809@163.com* Date : 2022/5/22 16:43* Description : 转账*/
class PaymentTransferFragment : BaseDataBindingFragment<WcPaymentTransferBinding>(), MyDispatchTouchEventListener {override fun getLayoutRes() = R.layout.wc_payment_transferprivate val userViewModel : UserViewModel by viewModels()private var navController : NavController? = nulloverride fun onViewCreated(view: View, savedInstanceState: Bundle?) {super.onViewCreated(view, savedInstanceState)super.builder().setTitleContent("")var toUser = arguments?.get(CommonUtils.QRCommon.TO_USER) as StringBaseUtils.showAvatarRounded(toUser, transfer_icon, transfer_name, BaseUtils.getDimension(R.dimen.distance_10))DispatchTouchEventUtils.registerDispatchTouchListener(this)navController = findNavController()transfer_balance.showSoftInputOnFocus = falsenum_keyboard_view.initEditText(transfer_balance)num_keyboard_view.setValue(R.string.wc_transfer_txt)transfer_balance.setOnClickListener {num_keyboard_view.visibility = View.VISIBLE}num_keyboard_item_recharge.setOnClickListener {TagUtils.d("转账金额:${transfer_balance.text}")var result = transfer_balance.text.toString()if(TextUtils.isEmpty(result)){ToastUtils.makeText(requireActivity(), "请输入金额")return@setOnClickListener}//减掉服务器金额userViewModel.updateBalanceServer(toUser, CommonUtils.User.OPERATOR_MINUS, transfer_balance.text.toString().toFloat())navController?.previousBackStackEntry?.savedStateHandle?.set(CommonUtils.QRCommon.TRANSFER_BALANCE, transfer_balance.text.toString().toFloat())//弹出的id为fragment,不能为actionnavController?.popBackStack()}}override fun onDestroy() {super.onDestroy()DispatchTouchEventUtils.unregisterDispatchTouchListener(this)}override fun dispatchTouchEvent(ev: MotionEvent) {if (ev.action == MotionEvent.ACTION_DOWN) {if (SoftInputUtils.isInput(transfer_balance, ev)) {num_keyboard_view?.visibility = View.GONE}}}override fun onResume() {super.onResume()transfer_balance.isFocusableInTouchMode = truetransfer_balance.requestFocus()transfer_balance.setOnKeyListener { view, i, keyEvent ->if (i == KeyEvent.KEYCODE_BACK && keyEvent.getAction() == KeyEvent.ACTION_DOWN) {if(num_keyboard_view.visibility == View.VISIBLE){hideNumKeyboardView()true} else {false}} else {false}}}private fun hideNumKeyboardView(){num_keyboard_view.visibility = View.GONE}private fun showNumKeyboardView(){num_keyboard_view.visibility = View.VISIBLE}}

//发送文本、红包、表情
private fun sendMessage(chatBean: ChatBean){if(chatBean == null){ToastUtils.makeText(requireActivity(), "发送信息不能为空")return}var content = chatBean.contentif(TextUtils.isEmpty(content)){ToastUtils.makeText(requireActivity(), "发送信息不能为空")} else {ChatManagerUtils.getInstance().sendMessage(toUserId, content)chat_content.setText("")CoroutineScope(Dispatchers.IO).launch {if(chatBean.contentType == ChatBean.CONTENT_TYPE_REDPACKET){var content = chatBean.contentchatBean.content = CommonUtils.Chat.getRedpacket(content).toString()} else if(chatBean.contentType == ChatBean.CONTENT_TYPE_TRANSFER){var content = chatBean.contentchatBean.content = CommonUtils.Chat.getTransfer(content).toString()}ChatRepository.insertChat(chatBean)}refreshBase(chatBean)}
}/*** 刷新发送、接收聊天信息* @param chatBean ChatBean*/
private fun refreshBase(chatBean: ChatBean){CoroutineScope(Dispatchers.Main).launch {//chatViewModel.insertChat(chatBean)TagUtils.d("ChatFragment refreshBase 刷新聊天信息 ")adapter.refresh(chatBean)if(chatBean.contentType == ChatBean.CONTENT_TYPE_LOCATION){delay(200)}swipe_target.scrollToPosition(adapter.itemCount -1)}
}

 

 

这篇关于Kotlin高仿微信-第17篇-单聊-转账的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/527794

相关文章

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

kotlin的函数forEach示例详解

《kotlin的函数forEach示例详解》在Kotlin中,forEach是一个高阶函数,用于遍历集合中的每个元素并对其执行指定的操作,它的核心特点是简洁、函数式,适用于需要遍历集合且无需返回值的场... 目录一、基本用法1️⃣ 遍历集合2️⃣ 遍历数组3️⃣ 遍历 Map二、与 for 循环的区别三、高

kotlin中的数据转换方法(示例详解)

《kotlin中的数据转换方法(示例详解)》这篇文章介绍了Kotlin中将数字转换为字符串和字符串转换为数字的多种方法,包括使用`toString()`、字符串模板、格式化字符串、处理可空类型等,同时... 目录1. 直接使用 toString() 方法2. 字符串模板(自动转换)3. 格式化字符串(控制输

kotlin中的行为组件及高级用法

《kotlin中的行为组件及高级用法》Jetpack中的四大行为组件:WorkManager、DataBinding、Coroutines和Lifecycle,分别解决了后台任务调度、数据驱动UI、异... 目录WorkManager工作原理最佳实践Data Binding工作原理进阶技巧Coroutine

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

kotlin中的模块化结构组件及工作原理

《kotlin中的模块化结构组件及工作原理》本文介绍了Kotlin中模块化结构组件,包括ViewModel、LiveData、Room和Navigation的工作原理和基础使用,本文通过实例代码给大家... 目录ViewModel 工作原理LiveData 工作原理Room 工作原理Navigation 工