From 1831c2a6304496729fc16af624c37e299beae83e Mon Sep 17 00:00:00 2001 From: cloudroam <cloudroam> Date: 星期二, 01 四月 2025 11:36:19 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- app/src/main/java/com/example/firstapp/ui/vip/MemberInfoCardFragment.kt | 54 ++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 48 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/com/example/firstapp/ui/vip/MemberInfoCardFragment.kt b/app/src/main/java/com/example/firstapp/ui/vip/MemberInfoCardFragment.kt index 3671d10..eb1c203 100644 --- a/app/src/main/java/com/example/firstapp/ui/vip/MemberInfoCardFragment.kt +++ b/app/src/main/java/com/example/firstapp/ui/vip/MemberInfoCardFragment.kt @@ -1,5 +1,6 @@ package com.example.firstapp.ui.vip +import android.graphics.Color import android.graphics.drawable.Drawable import androidx.fragment.app.viewModels import android.os.Bundle @@ -8,8 +9,7 @@ import android.view.LayoutInflater import android.view.View import android.view.ViewGroup -import android.widget.ImageView -import androidx.databinding.DataBindingUtil +import androidx.lifecycle.lifecycleScope import com.bumptech.glide.Glide import com.bumptech.glide.load.engine.GlideException import com.bumptech.glide.load.resource.bitmap.RoundedCorners @@ -17,7 +17,9 @@ import com.bumptech.glide.request.target.Target import com.bumptech.glide.load.DataSource import com.example.firstapp.R + import com.example.firstapp.databinding.FragmentMemberInfoCardBinding +import kotlinx.coroutines.launch class MemberInfoCardFragment : Fragment() { @@ -26,11 +28,12 @@ fun newInstance() = MemberInfoCardFragment() } - private val viewModel: MemberInfoCardViewModel by viewModels() + val viewModel: MemberInfoCardViewModel by viewModels() // 绑定变量 private var _binding: FragmentMemberInfoCardBinding? = null private val binding get() = _binding!! + override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) @@ -49,7 +52,7 @@ // 绑定头像 Glide.with(this) - .load("http://192.168.1.201:9000/sms/avatar/avatar.jpg") + .load(viewModel.cover) .transform(RoundedCorners(100)) // 设置圆角 .error(R.drawable.error_placeholder) // 如果加载失败,显示占位图 .listener(object : RequestListener<Drawable> { @@ -80,7 +83,7 @@ // 绑定会员徽章 Glide.with(this) - .load("http://192.168.1.201:9000/sms/member/vip_no.png") + .load(viewModel.vipCover) .transform(RoundedCorners(100)) // 设置圆角 .error(R.drawable.error_placeholder) // 如果加载失败,显示占位图 .listener(object : RequestListener<Drawable> { @@ -107,12 +110,51 @@ }) .into(binding.memberImageView) + + // 监听 cover 变化 + viewLifecycleOwner.lifecycleScope.launch { + viewModel.cover.collect { coverUrl -> + Glide.with(this@MemberInfoCardFragment) + .load(coverUrl) + .transform(RoundedCorners(100)) + .error(R.drawable.error_placeholder) + .into(binding.memberAvatarView) + } + } + + // 监听 vipCover 变化 + viewLifecycleOwner.lifecycleScope.launch { + viewModel.vipCover.collect { vipCoverUrl -> + Glide.with(this@MemberInfoCardFragment) + .load(vipCoverUrl) + .transform(RoundedCorners(100)) + .error(R.drawable.error_placeholder) + .into(binding.memberImageView) + } + } + + // 监听 background 变化 + viewLifecycleOwner.lifecycleScope.launch { + viewModel.background.collect { backgroundColor -> +// binding.memberCardCardView.setBackgroundColor(Color.parseColor(backgroundColor)) + binding.memberCardCardView.setBackgroundResource(backgroundColor) + } + } + + viewLifecycleOwner.lifecycleScope.launch { + viewModel.color.collect { color -> + binding.phoneNumberText.setTextColor(Color.parseColor(color)) + binding.memberStatus.setTextColor(Color.parseColor(color)) + } + } + return binding.root } - override fun onDestroyView() { super.onDestroyView() _binding = null } + + } \ No newline at end of file -- Gitblit v1.9.3