From 2f63393f18ec593659520927e4c015f84c2b1cf9 Mon Sep 17 00:00:00 2001 From: cloudroam <cloudroam> Date: 星期四, 06 三月 2025 14:34:05 +0800 Subject: [PATCH] fix: 热力图矩阵 --- app/src/main/java/com/example/firstapp/ui/dashboard/DashboardFragment.kt | 62 ++++++++++++++++++++++--------- 1 files changed, 44 insertions(+), 18 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..dadbe96 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 @@ -423,24 +423,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 +468,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 +488,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 +504,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 -> { // 周和月视图显示柱状图和饼图,隐藏包裹列表 @@ -490,6 +513,7 @@ binding.layoutYearStats.root.visibility = View.GONE binding.layoutWeekStats.chartDailyPackages.visibility = View.VISIBLE binding.layoutWeekStats.heatmapYearly.visibility = View.GONE + binding.cardPackageStats.visibility = View.VISIBLE // 显示包裹统计卡片 updateBarChartData() updatePieChartData() } @@ -500,8 +524,10 @@ binding.layoutYearStats.root.visibility = View.VISIBLE binding.layoutWeekStats.chartDailyPackages.visibility = View.GONE binding.layoutWeekStats.heatmapYearly.visibility = View.VISIBLE + binding.cardPackageStats.visibility = View.GONE // 隐藏包裹统计卡片 updateHeatmapData() updatePieChartData() + updateYearlyStats() // 更新年度统计数据 } } } -- Gitblit v1.9.3