From 0a730b84c41f44129bf5ecc112450d2edf4312c9 Mon Sep 17 00:00:00 2001
From: tj <1378534974@qq.com>
Date: 星期二, 15 四月 2025 17:44:56 +0800
Subject: [PATCH] 1.4 返回按钮
---
app/src/main/java/com/example/firstapp/ui/profile/EditProfileActivity.kt | 119 ++++++++++++++++++++++++++++++++++++++++++++++++++++-------
1 files changed, 105 insertions(+), 14 deletions(-)
diff --git a/app/src/main/java/com/example/firstapp/ui/profile/EditProfileActivity.kt b/app/src/main/java/com/example/firstapp/ui/profile/EditProfileActivity.kt
index 45d4c18..a7f4af1 100644
--- a/app/src/main/java/com/example/firstapp/ui/profile/EditProfileActivity.kt
+++ b/app/src/main/java/com/example/firstapp/ui/profile/EditProfileActivity.kt
@@ -9,17 +9,32 @@
import android.os.Bundle
import android.provider.MediaStore
import android.view.View
+import android.widget.ProgressBar
import android.widget.Toast
import androidx.activity.result.contract.ActivityResultContracts
+import androidx.appcompat.app.AlertDialog
import androidx.appcompat.app.AppCompatActivity
import androidx.core.app.ActivityCompat
import androidx.core.content.ContextCompat
+import androidx.lifecycle.lifecycleScope
import com.bumptech.glide.Glide
+import com.example.firstapp.database.response.UserInfo
import com.example.firstapp.databinding.ActivityEditProfileBinding
+import com.example.firstapp.database.service.ApiService
+import com.example.firstapp.database.service.RetrofitClient
+import com.example.firstapp.utils.PreferencesManager
+import kotlinx.coroutines.launch
+import java.io.File
+import okhttp3.MediaType.Companion.toMediaType
+import okhttp3.MultipartBody
+import okhttp3.RequestBody
+import okhttp3.RequestBody.Companion.asRequestBody
+import okhttp3.RequestBody.Companion.toRequestBody
class EditProfileActivity : AppCompatActivity() {
private lateinit var binding: ActivityEditProfileBinding
private var selectedImageUri: Uri? = null
+ private var loadingDialog: AlertDialog? = null
private val pickImage = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { result ->
if (result.resultCode == Activity.RESULT_OK) {
@@ -69,25 +84,79 @@
binding.btnSaveBottom.setOnClickListener {
saveAndFinish()
}
-
- binding.btnSaveBottom.setOnClickListener {
- saveAndFinish()
- }
}
private fun saveAndFinish() {
- val newNickname = binding.etNickname.text.toString()
- if (newNickname.isEmpty()) {
- Toast.makeText(this, "昵称不能为空", Toast.LENGTH_SHORT).show()
- return
- }
+ lifecycleScope.launch {
+ try {
+ binding.btnSaveBottom.isEnabled = false
+ showLoading()
- val resultIntent = Intent().apply {
- putExtra("nickname", newNickname)
- putExtra("avatar_uri", selectedImageUri?.toString())
+ val newNickname = binding.etNickname.text.toString()
+ if (newNickname.isEmpty()) {
+ Toast.makeText(this@EditProfileActivity, "昵称不能为空", Toast.LENGTH_SHORT).show()
+ return@launch
+ }
+
+ // 准备文件和参数
+ val nicknameBody = newNickname.toRequestBody("text/plain".toMediaType())
+
+ // 如果选择了新头像,处理文件
+ val avatarPart = selectedImageUri?.let { uri ->
+ val inputStream = contentResolver.openInputStream(uri)
+ val file = File(cacheDir, "avatar_temp")
+ inputStream?.use { input ->
+ file.outputStream().use { output ->
+ input.copyTo(output)
+ }
+ }
+
+ val requestFile = file.asRequestBody("image/*".toMediaType())
+ MultipartBody.Part.createFormData("avatar", file.name, requestFile)
+ }
+
+ // 调用更新接口
+ RetrofitClient.apiService.updateProfile(
+ nickname = nicknameBody,
+ avatar = avatarPart
+ )
+
+ Toast.makeText(this@EditProfileActivity, "保存成功", Toast.LENGTH_SHORT).show()
+ // 更新用户信息
+ // 从本地获取保存的手机号
+ val savedPhone = PreferencesManager.getPhone()
+ if (savedPhone.isNullOrEmpty()) {
+ Toast.makeText(this@EditProfileActivity, "用户未登录", Toast.LENGTH_SHORT).show()
+ return@launch
+ }
+ val response = RetrofitClient.apiService.getUserInfo(savedPhone)
+ if (response.code == "0" && response.data != null) {
+ // 保存用户信息
+ val userInfo:UserInfo = response.data
+ // 获取传入的数据
+ val currentNickname = userInfo.name
+ val currentAvatarUrl = userInfo.cover
+
+ // 设置当前数据
+ binding.etNickname.setText(currentNickname)
+ if (!currentAvatarUrl.isNullOrEmpty()) {
+ Glide.with(this@EditProfileActivity)
+ .load(currentAvatarUrl)
+ .circleCrop()
+ .into(binding.ivAvatar)
+ }
+
+ }
+
+ finish()
+
+ } catch (e: Exception) {
+ Toast.makeText(this@EditProfileActivity, "保存失败: ${e.message}", Toast.LENGTH_SHORT).show()
+ } finally {
+ binding.btnSaveBottom.isEnabled = true
+ hideLoading()
+ }
}
- setResult(Activity.RESULT_OK, resultIntent)
- finish()
}
private fun checkAndRequestPermission() {
@@ -130,6 +199,28 @@
pickImage.launch(intent)
}
+ private fun showLoading() {
+ if (loadingDialog == null) {
+ loadingDialog = AlertDialog.Builder(this)
+ .setView(ProgressBar(this))
+ .setCancelable(false)
+ .create()
+ }
+ loadingDialog?.show()
+ }
+
+ private fun hideLoading() {
+ loadingDialog?.dismiss()
+ }
+
+ private fun String.toRequestBody(mediaType: String): RequestBody {
+ return this.toRequestBody(mediaType.toMediaType())
+ }
+
+ private fun File.asRequestBody(mediaType: String): RequestBody {
+ return this.asRequestBody(mediaType.toMediaType())
+ }
+
companion object {
private const val PERMISSION_REQUEST_CODE = 100
}
--
Gitblit v1.9.3