From 32b40371a31b3984e01f5a072e8e9c7a1e6acc2b Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期三, 12 三月 2025 17:00:38 +0800
Subject: [PATCH] fix: 1

---
 app/src/main/java/com/example/firstapp/ui/dashboard/DashboardFragment.kt |   71 +++++++++++++++++++++++++----------
 1 files changed, 51 insertions(+), 20 deletions(-)

diff --git a/app/src/main/java/com/example/firstapp/ui/dashboard/DashboardFragment.kt b/app/src/main/java/com/example/firstapp/ui/dashboard/DashboardFragment.kt
index 794ece9..967a83c 100644
--- a/app/src/main/java/com/example/firstapp/ui/dashboard/DashboardFragment.kt
+++ b/app/src/main/java/com/example/firstapp/ui/dashboard/DashboardFragment.kt
@@ -23,6 +23,7 @@
 import android.graphics.Color
 import android.widget.GridLayout
 import com.example.firstapp.model.DailyStat
+import com.github.mikephil.charting.components.YAxis
 
 class DashboardFragment : Fragment() {
 
@@ -163,7 +164,8 @@
                 setDrawGridLines(false)
                 granularity = 1f
                 labelRotationAngle = 0f
-                textSize = 12f
+                textSize = 10f  //标签字体
+                setExtraLeftOffset(5f)  // 减少左侧留白
                 setExtraBottomOffset(15f)
             }
 
@@ -189,6 +191,8 @@
             setExtraOffsets(10f, 10f, 10f, 20f)
         }
 
+
+        
         updateBarChartData()
     }
     private fun updateBarChartData() {
@@ -423,24 +427,44 @@
 
             // 更新UI
             binding.layoutWeekStats.heatmapYearly.apply {
-                // 清除现有的子视图
                 removeAllViews()
                 
-                // 创建网格布局
                 val gridLayout = GridLayout(context).apply {
-                    rowCount = 7
-                    columnCount = 52
+                    rowCount = 8 // 增加一行用于显示月份
+                    columnCount = 53 // 增加一列用于显示星期标签
                 }
 
-                // 添加日期标签
-                val dayLabels = arrayOf("周日", "周一", "周二", "周三", "周四", "周五", "周六")
-                for (i in 0..6) {
+                // 添加月份标签
+                val months = arrayOf("1月", "2月", "3月", "4月", "5月", "6月", 
+                                   "7月", "8月", "9月", "10月", "11月", "12月")
+                months.forEachIndexed { index, month ->
                     val label = TextView(context).apply {
-                        text = dayLabels[i]
+                        text = month
                         textSize = 10f
-                        setPadding(0, 0, 8, 0)
+                        setPadding(0, 0, 8, 4)
+                        // 计算每个月份标签的位置
+                        val weekPosition = (index * 4.3).toInt()
+                        val params = GridLayout.LayoutParams()
+                        params.columnSpec = GridLayout.spec(weekPosition + 1)
+                        params.rowSpec = GridLayout.spec(0)
+                        layoutParams = params
                     }
                     gridLayout.addView(label)
+                }
+
+                // 添加星期标签
+                val dayLabels = arrayOf("周一", "周二", "周三", "周四", "周五", "周六", "周日")
+                dayLabels.forEachIndexed { index, label ->
+                    val textView = TextView(context).apply {
+                        text = label
+                        textSize = 10f
+                        setPadding(4, 0, 8, 0)
+                        val params = GridLayout.LayoutParams()
+                        params.columnSpec = GridLayout.spec(0)
+                        params.rowSpec = GridLayout.spec(index + 1)
+                        layoutParams = params
+                    }
+                    gridLayout.addView(textView)
                 }
 
                 // 添加热力图单元格
@@ -448,12 +472,15 @@
                     for (week in 0..51) {
                         val count = heatmapMatrix[day][week]
                         val cell = View(context).apply {
-                            layoutParams = ViewGroup.LayoutParams(
-                                resources.getDimensionPixelSize(R.dimen.heatmap_cell_size),
-                                resources.getDimensionPixelSize(R.dimen.heatmap_cell_size)
-                            )
+                            val params = GridLayout.LayoutParams().apply {
+                                width = resources.getDimensionPixelSize(R.dimen.heatmap_cell_size)
+                                height = resources.getDimensionPixelSize(R.dimen.heatmap_cell_size)
+                                columnSpec = GridLayout.spec(week + 1)
+                                rowSpec = GridLayout.spec(day + 1)
+                                setMargins(1, 1, 1, 1)
+                            }
+                            layoutParams = params
                             setBackgroundColor(getHeatmapColor(count))
-                            setPadding(1, 1, 1, 1)
                         }
                         gridLayout.addView(cell)
                     }
@@ -465,12 +492,11 @@
     }
 
     private fun getHeatmapColor(count: Int): Int {
-        // 根据数量返回不同深浅的颜色
         return when {
             count == 0 -> Color.parseColor("#EBEDF0")
-            count <= 2 -> Color.parseColor("#9BE9A8")
-            count <= 4 -> Color.parseColor("#40C463")
-            count <= 6 -> Color.parseColor("#30A14E")
+            count == 1 -> Color.parseColor("#9BE9A8")
+            count == 2 -> Color.parseColor("#40C463")
+            count <= 4 -> Color.parseColor("#30A14E")
             else -> Color.parseColor("#216E39")
         }
     }
@@ -482,6 +508,7 @@
                 binding.recyclerPackages.visibility = View.VISIBLE
                 binding.layoutWeekStats.root.visibility = View.GONE
                 binding.layoutYearStats.root.visibility = View.GONE
+                binding.cardPackageStats.visibility = View.VISIBLE
             }
             DateType.WEEK, DateType.MONTH -> {
                 // 周和月视图显示柱状图和饼图,隐藏包裹列表
@@ -489,7 +516,9 @@
                 binding.layoutWeekStats.root.visibility = View.VISIBLE
                 binding.layoutYearStats.root.visibility = View.GONE
                 binding.layoutWeekStats.chartDailyPackages.visibility = View.VISIBLE
+                (binding.layoutWeekStats.chartDailyPackages.parent as? View)?.visibility = View.VISIBLE
                 binding.layoutWeekStats.heatmapYearly.visibility = View.GONE
+                binding.cardPackageStats.visibility = View.VISIBLE
                 updateBarChartData()
                 updatePieChartData()
             }
@@ -498,10 +527,12 @@
                 binding.recyclerPackages.visibility = View.GONE
                 binding.layoutWeekStats.root.visibility = View.VISIBLE
                 binding.layoutYearStats.root.visibility = View.VISIBLE
-                binding.layoutWeekStats.chartDailyPackages.visibility = View.GONE
+                (binding.layoutWeekStats.chartDailyPackages.parent as? View)?.visibility = View.GONE
                 binding.layoutWeekStats.heatmapYearly.visibility = View.VISIBLE
+                binding.cardPackageStats.visibility = View.GONE
                 updateHeatmapData()
                 updatePieChartData()
+                updateYearlyStats()
             }
         }
     }

--
Gitblit v1.9.3