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