From 2e1edcb7518f20dec30dbd6e1686e9e6b558ec15 Mon Sep 17 00:00:00 2001 From: tj <1378534974@qq.com> Date: 星期三, 16 四月 2025 17:05:12 +0800 Subject: [PATCH] 43 首页登录->首页登录 1.首页弹窗协议同意后,不能默认自动勾选,还需要用户手动勾选 2.退出登录后,再次登录需要手动勾选与用户协议(目前是默认勾选了) 44 首页登录->邀请码 邀请码默认填入“邀请码(选填) 47 数据统计->饼状图数据分类统计问题 1、只统计快递 无需统计还款其他分类 2、图形上下间隔过大" 48 数据统计 天、周、月、年 1.数据统计只统计快递类的,其他分类不需要统计展示,例如取件码记录 2.包括周、月、年的统计环状图,只需要统计快递分类的 --- app/src/main/java/com/example/firstapp/ui/dashboard/DashboardFragment.kt | 293 ++++++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 272 insertions(+), 21 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 f8808f2..0c5316d 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 android.widget.Toast +import androidx.cardview.widget.CardView import androidx.lifecycle.lifecycleScope import com.example.firstapp.database.response.UserInfo import com.example.firstapp.database.service.RetrofitClient @@ -39,11 +40,14 @@ private var currentDateType = DateType.DAY private lateinit var barChart: BarChart private lateinit var pieChart: PieChart + private lateinit var chartCourierDistriBution:CardView private lateinit var heatmapView: View private var currentUserInfo: UserInfo? = null // 确保使用你的实际数据类 private var startDateCur:String = "" private var endDateCur:String = "" + private lateinit var bar_title:TextView + private lateinit var pie_title:TextView enum class DateType { @@ -113,11 +117,13 @@ private fun setupTabLayout() { val weekStatsView = binding.layoutWeekStats.root - val bar_title:TextView = weekStatsView.findViewById(R.id.bar_title) - val pie_title:TextView = weekStatsView.findViewById(R.id.pie_title) + bar_title = weekStatsView.findViewById(R.id.bar_title) + pie_title = weekStatsView.findViewById(R.id.pie_title) binding.tabDateRange.addOnTabSelectedListener(object : TabLayout.OnTabSelectedListener { override fun onTabSelected(tab: TabLayout.Tab?) { + currentDate = Calendar.getInstance() + currentDateType = when(tab?.position) { 0 -> DateType.DAY 1 -> DateType.WEEK @@ -191,6 +197,81 @@ private fun updateDateDisplay() { val dateFormat = when (currentDateType) { + DateType.DAY -> { + // 获取当天的起始和结束时间 + val calendar = currentDate.clone() as Calendar + // 设置为当天的 00:00:00 + calendar.set(Calendar.HOUR_OF_DAY, 0) + calendar.set(Calendar.MINUTE, 0) + calendar.set(Calendar.SECOND, 0) + calendar.set(Calendar.MILLISECOND, 0) + startDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + // 设置为当天的 23:59:59 + calendar.set(Calendar.HOUR_OF_DAY, 23) + calendar.set(Calendar.MINUTE, 59) + calendar.set(Calendar.SECOND, 59) + calendar.set(Calendar.MILLISECOND, 999) + endDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + // 返回当天的日期格式 + SimpleDateFormat("yyyy年MM月dd日", Locale.getDefault()).format(currentDate.time) + } + DateType.WEEK -> { + // 获取本周的起始和结束日期 + val calendar = currentDate.clone() as Calendar + calendar.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY) + val startDate = SimpleDateFormat("MM月dd日", Locale.getDefault()).format(calendar.time) + startDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + calendar.add(Calendar.DAY_OF_WEEK, 6) + val endDate = SimpleDateFormat("MM月dd日", Locale.getDefault()).format(calendar.time) + endDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + "$startDate-$endDate" + } + DateType.MONTH -> { + // 获取本月的起始和结束日期 + val calendar = currentDate.clone() as Calendar + calendar.set(Calendar.DAY_OF_MONTH, 1) + startDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + calendar.add(Calendar.MONTH, 1) + calendar.set(Calendar.DAY_OF_MONTH, 0) + endDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + "yyyy年MM月" + } + DateType.YEAR -> { + // 获取当前年的起始和结束日期 + val calendar = currentDate.clone() as Calendar + + // 设置为当前年份的 1 月 1 日 + calendar.set(Calendar.MONTH, Calendar.JANUARY) + calendar.set(Calendar.DAY_OF_MONTH, 1) + startDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + // 设置为当前年份的 12 月 31 日 + calendar.set(Calendar.MONTH, Calendar.DECEMBER) + calendar.set(Calendar.DAY_OF_MONTH, 31) + endDateCur = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()).format(calendar.time) + + + "yyyy年" + } + } + + // 更新界面显示 + if (currentDateType == DateType.WEEK) { + binding.textCurrentDate.text = dateFormat + } else { + binding.textCurrentDate.text = SimpleDateFormat(dateFormat, Locale.getDefault()) + .format(currentDate.time) + } + } + + private fun updateDateDisplay_bak() { + val dateFormat = when (currentDateType) { DateType.DAY -> "yyyy年MM月dd日" DateType.WEEK -> { // 获取本周的起始和结束日期 @@ -221,6 +302,7 @@ val weekStatsView = binding.layoutWeekStats.root barChart = weekStatsView.findViewById(R.id.chart_daily_packages) + chartCourierDistriBution=weekStatsView.findViewById(R.id.chart_courier_card_view) pieChart = weekStatsView.findViewById(R.id.chart_courier_distribution) heatmapView = weekStatsView.findViewById(R.id.heatmap_yearly) @@ -431,31 +513,200 @@ PieEntry(stat.count.toFloat(), "${stat.courierName}(${stat.count})") } - val dataSet = PieDataSet(entries, "快递公司分布") - dataSet.colors = listOf( - resources.getColor(R.color.purple_500), - resources.getColor(R.color.teal_200), - resources.getColor(R.color.purple_200), - resources.getColor(R.color.teal_700) - ) - dataSet.valueTextSize = 14f // 增大数值文字大小 + if (entries.isNotEmpty()) { + val dataSet = PieDataSet(entries, "快递公司分布") + dataSet.colors = listOf( + resources.getColor(R.color.light_blue_600_1), + resources.getColor(R.color.sunflower), + resources.getColor(R.color.light_blue), + resources.getColor(R.color.vermillion), + resources.getColor(R.color.fish_belly_white), + resources.getColor(R.color.light_green), + resources.getColor(R.color.crimson), + resources.getColor(R.color.sky_blue), + resources.getColor(R.color.gold), + resources.getColor(R.color.light_purple), + resources.getColor(R.color.yellow), + resources.getColor(R.color.canary_yellow), + resources.getColor(R.color.red_purple), + resources.getColor(R.color.light_cyan), + resources.getColor(R.color.orange), + resources.getColor(R.color.magenta), + resources.getColor(R.color.light_purple_2), + resources.getColor(R.color.bright_yellow), + resources.getColor(R.color.emerald_green), + resources.getColor(R.color.turmeric), + resources.getColor(R.color.red_gold), + resources.getColor(R.color.off_white), + resources.getColor(R.color.tangerine), + resources.getColor(R.color.aqua_blue), + resources.getColor(R.color.frost), + resources.getColor(R.color.wisteria), + resources.getColor(R.color.cyan) + ) + dataSet.valueTextSize = 14f // 增大数值文字大小 - val pieData = PieData(dataSet) - pieData.setValueFormatter(object : ValueFormatter() { - override fun getFormattedValue(value: Float): String { - return value.toInt().toString() - } - }) + val pieData = PieData(dataSet) + pieData.setValueFormatter(object : ValueFormatter() { + override fun getFormattedValue(value: Float): String { + return value.toInt().toString() + } + }) - pieChart.data = pieData - pieChart.invalidate() + pieChart.data = pieData + pieChart.invalidate() + + pieChart.visibility = View.VISIBLE // 例如:隐藏 PieChart + + pie_title.visibility = View.VISIBLE + + chartCourierDistriBution.visibility =View.VISIBLE + + } else { + // 如果 entries 为空,可以选择隐藏图表或设置一个默认显示 + pieChart.visibility = View.GONE // 例如:隐藏 PieChart + + pie_title.visibility = View.GONE + + chartCourierDistriBution.visibility =View.GONE + + } + + +// val dataSet = PieDataSet(entries, "快递公司分布") +// dataSet.colors = listOf( +// resources.getColor(R.color.purple_500), +// resources.getColor(R.color.teal_200), +// resources.getColor(R.color.purple_200), +// resources.getColor(R.color.teal_700) +// ) +// dataSet.valueTextSize = 14f // 增大数值文字大小 +// +// val pieData = PieData(dataSet) +// pieData.setValueFormatter(object : ValueFormatter() { +// override fun getFormattedValue(value: Float): String { +// return value.toInt().toString() +// } +// }) +// +// pieChart.data = pieData +// pieChart.invalidate() } } private fun getDayLabels(): Array<String> { return arrayOf("周一", "周二", "周三", "周四", "周五", "周六", "周日") } - private fun loadPackages() { + private fun loadPackages(){ + + + +// 根据日、周、月、年 获取统计数字 + when (currentDateType) { + DateType.DAY -> { + + viewModel.getCurrentDayStatsByType(startDateCur,endDateCur,"快递") .observe(viewLifecycleOwner) { stats -> + binding.textPackageCount.text = "${stats}个" + } + + // 获取取件记录 + viewModel.getPackagesReaded(currentDate.timeInMillis, + currentDateType.name) + .observe(viewLifecycleOwner) { unpackages-> + // 只读取未取件的包裹 + packageAdapter.updatePackages(unpackages) + } + + + } + DateType.WEEK -> { + + viewModel.getCurrentDayStatsByType(startDateCur,endDateCur,"快递") .observe(viewLifecycleOwner) { stats -> + binding.textPackageCount.text = "${stats}个" + } + } + DateType.MONTH -> { + + viewModel.getCurrentDayStatsByType(startDateCur,endDateCur,"快递") .observe(viewLifecycleOwner) { stats -> + binding.textPackageCount.text = "${stats}个" + } + } + DateType.YEAR -> { + + viewModel.getCurrentDayStatsByType(startDateCur,endDateCur,"快递") .observe(viewLifecycleOwner) { stats -> + binding.layoutYearStats.textTotalPackages.text = "${stats}个" + } + } + } + } + + private fun loadPackages_bak2(){ + + val formatter = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()) + +// 根据日、周、月、年 获取统计数字 + when (currentDateType) { + DateType.DAY -> { + val today = Calendar.getInstance() + val tmpCurDateStart = formatter.format(currentDate.time) + val tmpCurDateEnd = formatter.format(currentDate.time) + viewModel.getCurrentDayStatsByType(tmpCurDateStart,tmpCurDateEnd,"快递") .observe(viewLifecycleOwner) { stats -> + binding.textPackageCount.text = "${stats}个" + } + + // 获取本周统计 + viewModel.getPackagesReaded(currentDate.timeInMillis, + currentDateType.name) + .observe(viewLifecycleOwner) { unpackages-> + // 只读取未取件的包裹 + packageAdapter.updatePackages(unpackages) + } + + + } + DateType.WEEK -> { + val today = Calendar.getInstance() + + // 获取本周的周一(第一天) + today.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY) + val firstDayOfWeek = formatter.format(today.time) + // 获取本周的周日(最后一天) + today.add(Calendar.DATE, 6) // 加6天 + val lastDayOfWeek = formatter.format(today.time) + viewModel.getCurrentDayStatsByType(firstDayOfWeek,lastDayOfWeek,"快递") .observe(viewLifecycleOwner) { stats -> + binding.textPackageCount.text = "${stats}个" + } + } + DateType.MONTH -> { + val today = Calendar.getInstance() + today.set(Calendar.DAY_OF_MONTH, 1) // 设置为本月第一天 + val firstDayOfMonth = formatter.format(today.time) + + today.add(Calendar.MONTH, 1) // 移动到下个月 + today.set(Calendar.DAY_OF_MONTH, 0) // 设置为下个月的最后一天 + val lastDayOfMonth = formatter.format(today.time) + viewModel.getCurrentDayStatsByType(firstDayOfMonth,lastDayOfMonth,"快递") .observe(viewLifecycleOwner) { stats -> + binding.textPackageCount.text = "${stats}个" + } + } + DateType.YEAR -> { + val today = Calendar.getInstance() + today.set(Calendar.MONTH, Calendar.JANUARY) // 设置为第一月 + today.set(Calendar.DAY_OF_MONTH, 1) // 设置为第一天 + val firstDayOfYear = formatter.format(today.time) + + today.add(Calendar.YEAR, 1) // 移动到下一年 + today.set(Calendar.MONTH, Calendar.DECEMBER) // 设置为最后一月 + today.set(Calendar.DAY_OF_MONTH, 31) // 设置为最后一天 + val lastDayOfYear = formatter.format(today.time) + viewModel.getCurrentDayStatsByType(firstDayOfYear,lastDayOfYear,"快递") .observe(viewLifecycleOwner) { stats -> +// binding.textPackageCount.text = "${stats}个" + binding.layoutYearStats.textTotalPackages.text = "${stats}个" + } + } + } + } + private fun loadPackages_bak() { viewModel.getPackages( currentDate.timeInMillis, currentDateType.name @@ -465,7 +716,7 @@ binding.textPackageCount.text = "${packages.size}个" // 获取本周统计 - viewModel.getPackagesUnread(currentDate.timeInMillis, + viewModel.getPackagesReaded(currentDate.timeInMillis, currentDateType.name) .observe(viewLifecycleOwner) { unpackages-> // 只读取未取件的包裹 @@ -643,7 +894,7 @@ if (stats.isEmpty()) return@observe // 更新年度包裹总数 - binding.layoutYearStats.textTotalPackages.text = "${stats.sumOf { it.count }}个" +// binding.layoutYearStats.textTotalPackages.text = "${stats.sumOf { it.count }}个" // 更新平均每天包裹数 val avgDaily = stats.sumOf { it.count }.toFloat() / 365 -- Gitblit v1.9.3